Import Export
Чтобы сделать объекты, функции, классы или переменные доступными для внешнего мира, достаточно просто экспортировать их, а затем импортировать, где это необходимо, в другие файлы проекта.
Видео
«Hello, World!» на Node.js
Node.js®
— это JavaScript окружение построенное на движке Chrome V8.
Начнем работу с Node.js
просто набрав node в консоли:
$ node
>
Если он у вас не стоит, то скачайте его и установите на свой компьютер.
А теперь давайте попробуем что-то напечатать:
$ node
> console.log('hello from Node.js')
// После нажатия Enter вы получите следующее:
hello from Node.js
undefined
Не стесняйтесь эспериментировать с Node.js
с помощью этого интерфейса: обычно тестируют небольшие фрагменты кода здесь, если не целесообразно помещать их сразу в файл.
Пришло время создать наше приложение Hello Node.js!
Начнем с создания файла index.js
. Следующей командой мы создаем папку myProject
и входим в нее.
mkdir myProject && cd myProject
Теперь создаем сам файл index.js
touch index.js
Откройте свой редактор кода или скачайте и установите его. Мы рекомендуем VS Code.
Откройте редактор кода и добавьте в него папку созданого нами проекта.
Теперь откройте боковое меню нажав этот значок.
Cкопируйте в него следующий фрагмент кода:
// index.js
console.log('hello from Node.js')
Чтобы запустить этот файл, вы должны снова открыть свой терминал и перейти в каталог, в котором размещён index.js
.
В VS Code
это можно сделать нажав на эти значки.
И выбрать таб TERMINAL
Как только вы успешно переместитесь в нужное место, запустите файл, используя команду
node index.js
Вы увидите, что эта команда будет выдавать тот же результат, что и раньше, выводя строку непосредственно в терминале.
Модульность приложения
Пришло время перейти на следующий уровень! Давайте создадим что-то более сложное, разделив наш исходный код на несколько JavaScript-файлов с целью удобочитаемости и поддерживаемости.
Структура проекта
Создайте следующую структуру каталогов (с пустыми файлами), но пока не создавайте package.json,
мы сгенерируем его автоматически на следующем шаге:
├── app
| ├── calc.js
| └── index.js
├── index.js
└── package.json
Чтобы создать новый файл или папку в VS Code
нажмите соответствующую иконку как показано на картинке.
package.json
Каждый проект Node.js
начинается с создания файла package.json
. Вы можете думать о нем как о JSON-представлении приложения и его зависимостей. Он содержит имя вашего приложения, автора (вас) и все зависимости, необходимые для запуска приложения. Это карта вашего проекта.
Вы можете интерактивно генерировать файл package.json
с помощью команды
npm init
в терминале. После запуска команды вас попросят ввести некоторые данные, например имя вашего приложения, версию, описание и так далее. Не нужно беспокоиться, просто нажимайте Enter
, пока не получите сформированный JSON и вопрос is it ok
?. Нажмите Enter
в последний раз и вуаля: ваш package.json
был автоматически сгенерирован и помещен в папку вашего приложения. Если вы откроете этот файл в своей IDE, он будет очень похож на фрагмент кода ниже.
// package.json
{
"name": "myproject",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC"
}
Хорошей практикой является добавление стартового скрипта в ваш пакет package.json
. Поэтому добавьте в объект scripts
строчку:
"scripts": {
"start": "node index.js", // эту строчку
"test": "echo \"Error: no test specified\" && exit 1"
}
Как только вы это сделаете, вы можете запустить приложение с помощью команды npm start
.
Импорт
Теперь давайте вернемся к первому созданному вами файлу под названием index.js
. Рекомендуется оставить этот файл очень компактным: только подключение самого приложения (файл index.js
из подкаталога /app
, созданного ранее). Скопируйте следующий код в свой файл index.js
и сохраните:
// index.js
require('./app/index')
или сокращеная запись для всех файлов index.js
// index.js
require('./app')
Если не указан конкретный файл, то интерпретатор кода ищет файл index.js
и заходит в него. Вот так просто мы подключили свой первый файл в проект.
Экспорт
Теперь пришло время приступить к созданию реального приложения. Откройте файл index.js
из папки /app
, чтобы создать очень простой пример: добавление массива чисел. В этом случае файл index.js
будет содержать только числа, которые мы хотим добавить, а логика, требующая вычислений, должна быть помещена в отдельный модуль в файле calc.js
.
Вставьте этот код в файл index.js
в каталоге /app
.
// app/index.js
const calc = require('./calc')
const numbersToAdd = [3, 4, 10, 2]
const result = calc.sum(numbersToAdd)
console.log(`The result is: ${result}`)
Теперь вставьте фактическую бизнес-логику в файл calc.js,
который можно найти в той же папке.
// app/calc.js
const sum = arr => {
return arr.reduce((a, b) => a + b, 0)
}
module.exports.sum = sum // export
В этом файле мы создали функцию sum
и экспортировали ее, сделали доступными в других файлах проекта.
Чтобы проверить, всё ли вы сделали правильно, сохраните эти файлы, откройте терминал и введите npm start
или node index.js
. Если все сделали правильно, то получите ответ: 19.
Если что-то пошло не так, внимательно просмотрите лог в консоли и найдите проблему на его основе.
Итого
Вот мы и завершили с вами подготовительный, перед курсом по мобильной разработке, курс по JavaScript.
Проблемы?
Пишите в Telegram или ВКонтакте, а также подписывайтесь на наши новости
Вопросы:
Чтобы сделать объекты, функции, классы или переменные доступными для внешнего мира, необходимо:
- Экспортировать их, а затем импортировать
- Импортировать их, а затем экспортировать
Node.js®
это:
- Язык программирования
- JavaScript окружение построенное на движке Chrome V8
- Браузер
package.json
это:
- JavaScript окружение построенное на движке Chrome V8
- JSON-представление приложения и его зависимостей
- Язык программирования JSON
Для того чтобы понять насколько вы усвоили этот урок пройдите тест в мобильном приложении в нашей школы по этой теме.
Ссылки:
- MDN web doc. Статья "Модули в ECMAScript 6: будущее уже сейчас"
- Статья "ES6 Modules and How to Use Import and Export in JavaScript"
- Статья "require против ES6 import / export"
Contributors ✨
Thanks goes to these wonderful people (emoji key):
Dmitriy K. | Dmitriy Vasilev 💵 | Resoner2005 🐛 🎨 🖋 | Navernoss 🖋 🐛 🎨 |