Каково оно учить JavaScript в 2016

Aug 03, 2018 12:04

сурс https://m.habr.com/post/312022/

- Эй, я получил новый веб-проект, но, если честно, я не занимался веб-кодингом в течение нескольких лет, и я слышал, все немного поменялось. Ты же самый современный веб-разработчик, правда?

- Это теперь называется Front-End инженер, но да, я - именно он. Я работаю с вебом в 2016. Визуализации, музыкальные плееры, летающие дроны, которые играют в футбол, все что угодно. Я только что вернулся из JsConf и ReactConf, так что я знаю новейшие технологии для создания веб-приложений.

- Круто. Мне нужно создать страницу, которая отображает последние действия со стороны пользователей, так что мне просто нужно получить данные от REST и отобразить их в какой-то фильтруемой таблице, ну и обновлять её, если что-то изменится на сервере. Я думал, может быть, использовать JQuery для извлечения и отображения данных?

- О, Мой Бог! Нет! Никто больше не использует JQuery. Ты должен попробовать React: это - 2016!

- Интересно. Что такое React?

- Это - очень крутая библиотека, сделанная ребятами из Facebook. Она реально дает полный контроль и повышает производительность приложения, позволяя очень легко обрабатывать любые изменения представлений.

- Звучит заманчиво. Могу ли я использовать React для отображения данных с сервера?

- Ага, но сначала нужно добавить React и React DOM в виде библиотек.

- Подожди, почему две библиотеки?

- Ну, одна - это сама библиотека, а вторая - для манипулирования DOM, который ты теперь можешь описать в JSX.

- JSX? Что такое JSX?

- JSX - это просто расширение синтаксиса JavaScript, который выглядит очень похоже на XML. Это своего рода еще один способ описать DOM. Думай о нем, как об улучшенном HTML.

- Что случилось с HTML?

- Это 2016. Никто больше не пишет на сыром HTML.

- Ну хорошо. Если я добавляю эти две библиотеки, то я могу использовать React?

- Не совсем. Нужно добавить Babel, а затем можно использовать React.

- Другая библиотека? Что за Babel?

- О, Babel - это транспайлер, он позволяет ориентироваться на конкретные версии JavaScript, в то время как пишешь код в любой версии JavaScript. Тебе не обязательно добавлять Babel для того, чтобы писать на ReactJS, но если ты это не сделаешь, то ты застрял с ES5, ну а это 2016, ты должен кодить в ES2016+ как и все крутые чуваки.

- ES5? ES2016+? Я потерялся. Что за ES5 и ES2016+?

- ES5 означает ECMAScript 5. Это версия, на которую ориентируется большинство, поскольку она реализована в большинстве браузеров на сегодняшний день.

- ECMAScript?

- Да, знаешь стандарт JavaScript, который был основан в 1999 году после его первоначального выпуска в 1995 году? Тогда, когда JavaScript был назван LiveScript и только работал в Netscape Navigator. Это было очень запутано тогда, но, к счастью, теперь все ясно, и у нас есть 7 версий этой реализации.

- 7 версий. Серьезно. А ES5 и ES2016+ это?…

- Пятое и седьмое издание соответственно.

- Подожди, а что случилось с шестым?

- ES6? Да, каждое издание является надстройкой предыдущего, так что если ты используешь ES2016+, то ты используешь все функции предыдущих версий.

- Хорошо. А зачем использовать ES2016+ над ES6 тогда?

- Ну, ты можешь использовать ES6, но для интересных штук, типа async и await, тебе нужно использовать ES2016+. В противном случае ты застрял с ES6 генераторами и сопрограммами для блокировки асинхронных вызовов и нормального управления потоком.

- Я понятия не имею, что ты только что сказал, и все эти имена запутаны. Слушай, я просто хочу загрузить кучу данных с сервера, просто подключить JQuery из CDN и просто получить данные с помощью AJAX. Почему я не могу сделать это?

- Чувак, это 2016. Никто не использует JQuery больше, это заканчивается кучей запутанного кода. Все же это знают.

- Ясно. Так что моя альтернатива - это загрузить три библиотеки для извлечения данных и отображения таблицы HTML.

- Ну, ты включаешь эти три библиотеки, но связываешь их с менеджером модулей, чтобы загрузить только один файл.

- Понятно. А что за менеджер модулей?

- Определение зависит от окружающей среды, но для веба мы обычно подразумеваем все, что поддерживает модули AMD или CommonJS.

- Хорошооооо. А AMD и CommonJS это?…

- Определения. Есть куча способов, чтобы описать, как несколько библиотек и классов JavaScript должны взаимодействовать. Ты можешь написать несколько файлов JavaScript, определяющих API AMD или CommonJS, и использовать что-то вроде Browserify, чтобы связывать их.

- Хорошо, имеет смысл… наверное. А что такое Browserify?

- Это инструмент, который позволяет связать CommonJS описанния зависимостей для файлов, которые могут быть запущены в браузере. Он был создан, потому что большинство людей публикуют эти зависимости в NPM.

- NPM?

- Это очень большое общественное хранилище, где умные люди постят код и зависимости в виде модулей.

- Как CDN?

- На самом деле, нет. Это больше похоже на централизованную базу данных, где каждый желающий может опубликовать и скачать библиотеки, так что ты можешь использовать их локально для разработки, а затем загрузить их на CDN, если захочешь.

- О, как Bower!

- Да, но это 2016, сейчас никто больше не использует Bower.

- Хм, ясно… так мне нужно загрузить библиотеки из NPM?

- Да. Например, если ты хочешь использовать React, то загружаешь модуль React и импортируешь его в коде. Это можно сделать для почти каждой популярной библиотеки JavaScript.

- О, это как в Angular!

- Angular это слишком 2015. Но да. Angular тоже там есть, наряду с VueJS, RxJS и другими интересными библиотеками из 2016. Хочешь узнать о них?

- Давай придерживаться React, я уже узнал слишком много о нем. Так что, если мне нужно использовать React, я вытяну его из этого NPM, а затем использую Browserify?

- Да.

- Это кажется слишком сложным, чтобы просто взять кучу зависимостей и связать их вместе.

- Ага, именно поэтому ты используешь менеджер задач, типа как Grunt или Gulp, или Broccoli для автоматизации запуска Browserify. Ты даже можешь использовать Mimosa.

- Grunt? Gulp? Broccoli? Mimosa? Черт возьми, о чём мы говорим сейчас?

- Task менеджеры. Но они уже не такие крутые. Мы использовали их в стиле 2015 с Makefiles, но теперь мы перешли на Webpack.

- Makefiles? Я думал, что в основном это используется для C или C++ проектов.

- Ага, но, видимо, в вебе мы любим делать вещи сложными, а затем вернуться к основам. Мы делаем это типа каждый год. Ты подожди, через год или два мы еще запилим сборки (assemblies) в вебе.

- Пффф. Ты упомянул что-то под названием Webpack?

- Это другой менеджер модулей для браузера, в то же время он и своего рода Task менеджер. Это как улучшенная версия Browserify.

- ОК. А почему он лучше?

- Ну, может быть не лучше, но более гибкий в плане того, как зависимости связаны. Webpack позволяет использовать различные менеджеры модулей, а не только CommonJS. Например, родные модули ES6.

- Я очень запутался в этих CommonJS/ES6.

- Да все в этом запутались, но можешь больше не париться, потому что есть SystemJS.

- О, Боже, опять что-то-JS. Хорошо, а что это за SystemJS?

- Ну, в отличие от Browserify и WebPack 1.x, SystemJS представляет собой динамический модуль загрузчика, который позволяет связать несколько модулей в нескольких файлах, а не связывая их в один большой файл.

- Подожди, я думал, что мы хотели объединить наши библиотеки в один большой файл и загрузить его!

- Да, но из-за HTTP/2 несколько HTTP запросов на самом деле лучше.

- Стоять! Так чего же мы не можем просто добавить три оригинальные библиотеки для React?

- Ты, конечно, можешь добавить их в качестве внешних скриптов с CDN, но все равно нужно будет добавить Babel.

- Эх. И это плохо, не так ли?

- Да, придется включить полностью Babel-core, а это не будет эффективным для production. На production необходимо выполнить ряд предварительных задач, чтобы проект был полностью готов, а это ритуал, в сравнении с которым вызвать дьявола - это рецепт как сварить яйцо. Надо будет минимизировать файлы, сделать uglify, поиграться со стилями, подумать о загрузке скриптов…

- Понял, понял. Но если не скачивать библиотеки непосредственно с CDN, то как иначе?

- Я бы сделал транспайл из TypeScript с помощью комбо Webpack + SystemJS + Babel.

- TypeScript? Я думал, что мы пишем код на JavaScript!

- Typescript - это и есть JavaScript, или, лучше сказать, надмножество JavaScript. Более конкретно - JavaScript на версии ES6. Ну, та шестая версия, о которой мы говорили.

- Я думал, что ES2016+ - уже надмножество ES6! Почему нам сейчас нужен еще и TypeScript?

- Потому что это позволяет нам использовать JavaScript как типизированный язык и уменьшить количество ошибок во время выполнения. Это 2016, надо добавить некоторые типы в код на JavaScript.

- И TypeScript, очевидно, делает это.

- И Flow, хотя он проверяет только типы, в то время как TypeScript является надстройкой JavaScript, который нужно скомпилировать.

- Эээ… и Flow?

- Это - инструмент для проверки статической типизации, сделанный парнями из Facebook. Они написали его на OCaml, так как функциональное программирование является удивительно крутым.

- OCaml? Функциональное программирование?

- Ну это то, что сегодня юзают крутые пацаны, ну типа, знаешь, 2016. Функциональное программирование. Функции высокого порядка. Currying. Pure функции.

- Я понятия не имею, что это.

- Никто не понимает, в начале. Надо просто знать, что функциональное программирование лучше, чем объектно-ориентированное программирование, и это то, что мы должны использовать в 2016 году.

- Подожди, я учил ООП в универе, я думал, что это круто?

- Ну так было пока Oracle не купил Java. Я имею в виду, что ООП был хорош раньше, и его используют до сих пор, но теперь каждый понимает, что манипулировать состояниями эквивалентно пинанию младенцев, так что теперь все движется к immutable объектам и функциональному программированию. Ребята из Haskell уже 100 лет кричат об этом, и это я еще не упоминал Elm. Но, к счастью, в сети теперь у нас есть такие библиотеки, как Ramda, которые позволяют нам использовать функциональное программирование на простом JavaScript.

- Ты что, просто придумываешь имена? Что еще за Ramnda?

- Нет. Ramda. Как и Lambda. Ну, знаешь, библиотека Дэвида Чембера?

- Дэвида кого?

- Дэвида Чембера. Крутой чел. Один из авторов Ramda. Глянь еще работы Эрика Мейера, если серьезно относишься к изучению функционального программирования.

- А Эрик Мейер это?…

- Тоже функциональщик. Крутой чел. У него есть куча презентаций, где он в странной цветной футболке громит Agile. Еще глянь что делают Tj, Jash Kenas, Sindre Sorhus, Paul Irish, Addy Osmani…

- ОК. Притормози. Все это хорошо и прекрасно, но я думаю, что все это слишком сложно и ненужно для простой выборки данных и их отображения. Я уверен, что я не должен знать этих людей или все эти вещи, чтобы создать таблицу с динамическими данными. Давай вернемся к React. Как я могу извлечь данные с сервера в React?

- Ну, на самом деле для выборки данных не надо React, он отображает данные.

- О, черт. Так а что используется для выборки данных?

- Используй Fetch для получения данных с сервера.

- Использовать Fetch для выборки данных? Тот, кто называет эти вещи, нуждается в тезаурусе.

- О, да. Fetch это имя нативной реализации для выполнения XMLHttpRequests.

- О, AJAX.

- AJAX это просто запросы XMLHttpRequest. А Fetch позволяет делать AJAX на основе промисов, которые затем можно резолвить, чтобы избежать callback hell.

- Callback hell?

- Да. Каждый раз, когда выполняется асинхронный запрос, ты должен ждать его ответа, который заставляет добавить функцию внутри функции, которая называется пирамида callback hell.

- О, хорошо. А промисы решают эту проблему?

- Еще бы! Манипулируя коллбеками через промисы, ты можешь писать более понятный код, тестировать его, а также выполнять несколько одновременных запросов одновременно и ждать, пока все они отработают.

- И это можно сделать с помощью Fetch?

- Да, но только в некоторых браузерах, в противном случае необходимо включить Fetch polyfill или использовать Request, Bluebird или Axios.

- Сколько библиотек мне нужно знать, ради бога? Сколько из них?

- Это JavaScript. Тут тысячи библиотек, которые делают одно и то же. Мы знаем эти библиотеки. Наши библиотеки огрооооомные, а иногда мы добавляем картинки с Guy Fieri в них.

- Guy Fieri? Давай покончим с этим. Что эти Bluebird, Request и Axios делают?

- Это библиотеки для выполнения XMLHttpRequests, которые возвращают промисы.

- А методы AJAX JQuery не возвращают промисы?

- Мы больше не используем «J» в 2016. Просто используйте Fetch polyfill или Bluebird, Request или Axios. Затем управляй промисами с async, await и Бац!, у тебя правильный поток управления.

- Это третий раз, когда ты говоришь о await, но я понятия не имею, что это такое.

- Await позволяет блокировать асинхронный вызов, что позволяет лучше все контролировать во время получения данных и увеличивает читаемость кода. Это потрясающе, просто нужно, чтобы убедиться, что ты добавил stage-3 в Babel, или использовать синтаксис асинхронных функций и плагин transform-async-to-generator.

- Это безумие.

- Нет, безумие - что нужно перекомпилировать код TypeScript, а затем транспайлить его с Babel, чтобы использовать await.

- Шта!? Это не входит в TypeScript?

- Входит в следующей версии, но в версии 1.7 он только ES6, так что если хочешь использовать await в браузере, сначала нужно скомпилировать код TypeScript в ES6, а затем транспайлить с Babel в ES5.

- Я не знаю, что сказать.

- Слушай, это легко. Пиши весь код в TypeScript. Все модули, использующие Fetch компилируй в ES6, транспайль их с Babel с stage-3, и загружай с SystemJS. Если у тебя нет Fetch, используй polyfill, или Bluebird, Request или Axios, и обрабатывай промисы с await.

- У нас очень разные определения «легко». Так, с этим ритуалом я, наконец, получил данные и теперь я могу показать их с помощью React правильно?

- А приложение будет обрабатывать любые изменения состояния?

- Грр, я не думаю. Мне просто нужно отобразить данные.

- О, слава богу. В противном случае мне пришлось бы объяснить Flux и реализации, такие как Flummox, Alt, Fluxible. Хотя, если быть честным ты должен использовать Redux.

- Как же достали эти имена. Опять же, мне просто нужно отобразить данные.

- А, если просто отобразить данные, не надо начинать с React. Можно взять движок шаблонов.

- Ты шутишь, что ли? Думаешь, это смешно?

- Да я просто объяснил, что ты мог бы использовать.

- Стоп. Просто остановись.

- Я имею в виду, даже если просто использовать шаблонизатор, я бы все равно использовал комбо TypeScript + SystemJS + Babel на твоем месте.

- Мне нужно отобразить данные на странице, а не выполнить оригинальный фаталити Sub Zero из Мортал Комбат. Просто скажи мне, какой движок шаблонов использовать.

- Их много, с каким ты знаком?

- Уф, не могу вспомнить название. Это было давно.

- jTemplates? jQote? PURE?

- Не то. Еще один?

- Transparency? JSRender? MarkupJS? KnockoutJS?

- Другой

- PlatesJS? JQuery-tmpl? Handlebars? Некоторые люди до сих пор используют его.

- Может быть. А есть что-то похожее на последний?

- Mustache, underscore? Я думаю, что теперь даже у lodash есть шаблонизатор, но это своего рода 2014.

- Грр… возможно он был поновее.

- Jade? DustJS?

- Нет.

- DotJS? EJS?

- Нет.

- Nunjucks? ЕСТ?

- Нет.

- Чувак, никто не любит синтаксис CoffeeScript в любом случае. Jade?

- Нет, ты уже сказал Jade.

- Ну я имел в виду Pug. Я имел в виду Jade. Я имею в виду, Jade теперь Pug.

- Пф. Нет. Не помню. Какой из них ты бы использовал?

- Наверное, нативный ES6 template strings.

- Дай угадаю. Это требует ES6.

- Да.

- Который, в зависимости от того, какой браузер я использую требует Babel.

- Да.

- Который, если я хочу включить без добавления всей библиотеки, нужно, загрузить в качестве модуля NPM.

- Да.

- Который, требует Browserify или Wepback, или, скорее всего, SystemJS.

- Да.

- Который, если это не Webpack, в идеале должен управляться Task runner-ом.

- Да.

- Но, так как я должен использовать функциональное программирование и типизированные языки, я в первую очередь должен предварительно скомпилировать TypeScript или добавить этот Flow.

- Да.

- А потом отправить это на обработку в Babel, если я хочу использовать await.

- Да.

- Так что я могу затем использовать Fetch, промисы и управление потоком и всю эту магию.

- Только не забудь polyfill Fetch, если он не поддерживается, Safari до сих пор не может справиться с этим.

- Знаешь что. Я думаю, мы закончим здесь. На самом деле, я думаю, я закончил. Я закончил с этим вебом и с JavaScript в целом.

- Хорошо, через несколько лет мы все будем кодить в Elm или WebAssembly.

- Я просто хочу вернуться к бэкэнду. Я не могу справиться со всеми этими изменениями, версиями, изданиями, компиляторами и транспайлерами. Сообщество JavaScript безумно, если оно думает, что кто-то может идти в ногу с этим.

- Понятно. Тебе тогда надо попробовать сообщество Python.

- Почему?

- Слышал о Python 3?
Previous post
Up