Существует множество способов писать код для веб-приложений: от текстовых редакторов до облачных сред разработки. Трудно сразу решить, какая среда лучше подходит для поставленных задач. Чтобы сэкономить вам время, выбрали наиболее популярные:

В конце каждого раздела размещена сводная таблица, в которой можно наглядно увидеть сравнение функций редакторов для веб-разработки. В статье рассмотрены исключительно бесплатные кроссплатформенные решения, поэтому популярные проприетарные редакторы вроде Sublime Text не вошли в подборку.

Текстовые редакторы для веб-разработки

Komodo Edit

Основные возможности:

  • бесконечная история отмены,
  • обширное количество плагинов,
  • поддержка сотен языков программирования и форматов файлов,
  • мощный поиск и замена,
  • интеграция со сторонними инструментами.

GNU Emacs

Настольные интегрированные среды разработки (IDE)

Eclipse

Облачные IDE

Большинство десктопных приложений перешли в «облако», поэтому нет ничего удивительного, что облачные среды также становятся популярными среди программистов. Не каждый сразу доверяет облачным IDE, но популярные инструменты вроде Github и Pastebin помогают привыкнуть к тому, что исходный код хранится не на локальной машине, а на стороннем сервере.

Cloud9

После нескольких минут работы в Cloud9 создаётся впечатление, что попал в рай для программистов. Интерфейс написан на JavaScript, а серверная часть - на NodeJS. Хотя Cloud9 облюбовали разработчики и дизайнеры интерфейсов, поддерживается подсветка синтаксиса C#, C++, Python, Perl, Ruby, Scala и некоторых других языков.

Встроенный режим Vim - приятный штрих, как и поддержка популярных систем контроля версий вроде Git, Mercurial и SVN. Благодаря наличию CSSLint и JSBeautify это одна из красивейших сред разработки.

Codeanywhere

Ещё один инструмент для создания приложений, который часто возглавляет списки лучших - Codeanywhere. Эта дружественная облачная IDE поддерживает подсветку кода HTML, CSS, JavaScript, PHP, MySQL и других языков. Благодаря наличию приложений для iOS, Android и BlackBerry, с помощью Codeanywhere программисты работают где угодно.

Кроме того, Codeanywhere поддерживает Dropbox и SFTP, которые помогают легко создавать резервные копии файлов проекта и обмениваться ими с коллегами. Это не самая полнофункциональная среда, но свою работу выполняет на отлично.

Система платная, но есть бесплатный тарифный план.

Eclipse Che

Eclipse Che - облачное рабочее пространство разработчика и встроенная IDE. Che предоставляет удалённую платформу с открытым исходным кодом для многопользовательского создания приложений.

Основные возможности:

  • рабочие пространства, включающие среды выполнения и IDE,
  • сервер рабочих мест с RESTful веб-сервисами,
  • облачная IDE,
  • плагины для языков, платформы и инструменты,
  • SDK для создания плагинов и сборок.

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

Многопользовательская предоставляет мультиарендность. Учётные записи пользователей и рабочие места изолированы, а для регистрации, управления и аутентификации используется механизм KeyCloak . Permissions API регламентируют доступ к объектам вроде пространств, стеков и организаций. Сведения о пользователях хранятся в базе данных, поддерживающей миграцию (PostgreSQL).

"Все вот думал, когда же наступит тот момент, когда мне придется сказать в стиле "да я в твои годы!.. и т.д.". И вот... Этот момент, скорее всего, настал. Вам, - как видно из вашего недавнего поста, - 16 лет, и вы позиционируете себя как молодого человека, увлекшегося программированием. То вы собираетесь использовать Go для масштабного веб-проекта, то не можете подобрать цветовую схему для редактора Sublime Text 3, чтобы начать программировать, причем одну тему для дневной работы, а вторую - для ночной. И все это для того, чтобы, как вы в том же посте и выразились, в ближайшее время опять же - начать писать на языке golang. Теперь вот уже и сам IDE стоит под вопросом.

Я в ваши годы, а точнее, с 12 лет и где-то до 16-ти, сидел дома за гудящим компьютером ЕС-1840, оснащенным черно-белым монитором "Электроника". Там, поверьте мне, не было никаких тем - ни ночных, ни дневных. Я не говорю уже о том, что понятие "графика" сводилось к алгоритмам отображения простых геометрических фигур, причем практически, если так можно выразиться, "попиксельно". Не было и никаких навороченных IDE, а пиком эргономичности UI считались Norton/Volkov Commander. Windows и графический интерфейс? Не, не слышали.. Там был MS-DOS во всей его красе.

Но зато, мой юный друг, были Borland TurboPascal, Borland C++, Microsoft GW-BASIC и другие - простейшие в смысле графической оболочки (если понятие таковой вообще там можно было найти), но необходимые среды разработки под MS-DOS, благодаря которым многие стали профессионалами без всяких ночных тем. О да, забыл упомянуть: тогда не было никакого Интернета и ответ на вопрос типа "А как сделать, чтобы..." нельзя было найти с помощью Google. И книг не было. Разве что книга В. Э. Фигурнова "IBM PC для пользователя" - почти что единственная библия нашего поколения и скудные сканы с документаций, поставлявшимися с официальными версиями вышеозначенных программ и считавшимися ценнее золота.

Как я уже вам писал, я знаю людей (да и многие знают), которые годами собираются выучить Java, но никак не могут определиться, что лучше - Eclipse или NetBeans. В результате они остались на месте, не выучив ровным счетом ничего. А все потому что походили к процессу не с той стороны, явно полагая, что корень их непонимания азов программирования связан с использованием неудобного IDE.

Я желаю вам прогресса, а поэтому прошу: не повторяйте опыт неудачников и не наступайте на эти затертые чужие грабли. Учитесь и начинайте программировать, а темы оставьте на потом.

Компилятор преобразует исходный код (файлов *.с, *.cpp) в работающую программу. Если у вас нет компилятора, необходимо его установить, прежде чем начать программировать. Есть много компиляторов, которые доступны в Интернете для скачивания. Если вы являетесь пользователем Mac OS X, Linux или других *nix систем (например, Unix или FreeBSD), вероятно, у вас уже установлены компиляторы, такие как GCC или G++.

Основные понятия

Компилятор — программа, транслирующая исходный (высокоуровневый) код программы в конечный (низкоуровневый) код.
Компиляция — процесс преобразования высокоуровневого исходного текста программы, в эквивалентный текст программы, но уже на низкоуровневом языке.
Компоновщик (Линкер) — программа, которая генерирует исполнимый модуль путём связывания объектных файлов проекта.
IDE (Интегрированная среда разработки) — сочетание текстового редактора и компилятора. Разработка, компиляция и запуск своих программы осуществляется непосредственно в IDE. Интегрированные среды разработки упрощают процесс составления программ, так как написание кода компиляция и запуск программ выполняются в одной программе — IDE. Ещё одной важной особенностью IDE является то, что IDE помогает быстро найти и исправить ошибки компиляции.

Понимание процессов компиляции

Процессы компиляции и компоновкикраткое описание того, что именно происходит, когда вы компилируете программу.
Ошибки компиляции , в некоторых строках компилятор находит ошибки, которые нужно ликвидировать.
Предупреждения компилятора — что такое предупреждения компилятора, как и почему их устраняют.
В чём разница между объявлениями и определениями в С/C++ . Узнайте разницу между объявлением и определением в Си/C++, и почему это так важно.

Выбор компиляторов (IDE)

Для ОС Windows:
Code::Blocks с Mingw — рекомендуемая нами, бесплатная IDE! Code::Blocks также доступна на Linux. Посмотреть, как установить эту IDE можно в нашей статье Установка Code::Blocks и MINGW.
Microsoft Visual C++ — читайте о Visual C++. Руководство по установке Microsoft Visual Studio 2012