Работы по JavaScript. JavaScript с Ильей Кантором
Скачать 0.61 Mb.
|
Открыть код в новом окне Содержимое файла /files/tutorial/browser/script/rabbits.js:
Открыть код в новом окне Можно указать и полный URL, например:
Вы также можете использовать путь относительно текущей страницы, например src="script.js" если скрипт находится в том же каталоге, что и страница. Чтобы подключить несколько скриптов, используйте несколько тегов:
Как правило, в HTML пишут только самые простые скрипты, а сложные выносят в отдельный файл. Благодаря этому один и тот же скрипт, например, меню или библиотека функций, может использоваться на разных страницах. Браузер скачает его только первый раз и в дальнейшем, при правильной настройке сервера, будет брать из своего кэша. Если указан атрибут src, то содержимое тега игнорируется. В одном теге SCRIPT нельзя одновременно подключить внешний скрипт и указать код. Вот так не cработает:
Нужно выбрать: либо SCRIPT идёт с src, либо содержит код. Тег выше следует разбить на два: один — с src, другой с кодом:
Структура кода
В этой главе мы рассмотрим общую структуру кода, команды и их разделение. Команды Например, можно вместо одного вызова alert сделать два:
Как правило, новая команда занимает отдельную строку — так код лучше читается:
Точку с запятой во многих случаях можно не ставить, если есть переход на новую строку. Так тоже будет работать:
В этом случае JavaScript интерпретирует переход на новую строчку как разделитель команд и автоматически вставляет «виртуальную» точку с запятой между ними. Однако, внутренние правила по вставке точки с запятой не идеальны. В примере выше они сработали, но в некоторых ситуациях JavaScript «забывает» вставить точку с запятой там, где она нужна. Таких ситуаций не так много, но они все же есть, и ошибки, которые при этом появляются, достаточно сложно исправлять. Поэтому рекомендуется точки с запятой ставить. Сейчас это, фактически, стандарт. Комментарии Со временем программа становится большой и сложной. Появляется необходимость добавить комментарии, которые объясняют, что происходит и почему. Комментарии могут находиться в любом месте программы и никак не влияют на ее выполнение. Интерпретатор JavaScript попросту игнорирует их. Однострочные комментарии начинаются с двойного слэша //. Текст считается комментарием до конца строки:
Многострочные комментарии начинаются слешем-звездочкой "/*" и заканчиваются звездочкой-слэшем "*/", вот так:
Все содержимое комментария игнорируется. Если поместить код внутрь /* ... */ или после // — он не выполнится.
Вложенные комментарии не поддерживаются! В этом коде будет ошибка:
В многострочных комментариях всё очень просто — комментарий длится от открытия /* до закрытия */. Таким образом, код выше будет интерпретирован так: Комментарий открывается /* и закрывается */:
Код (лишние символы сверху вызывают ошибку):
Виды комментариев Существует три типа комментариев.
Эти комментарии бывают особенно полезны, если используются неочевидные алгоритмы.
При создании кода мы принимаем много решений, выбираем лучший вариант из нескольких возможных. Иногда для правильного выбора нужно многое изучить, посмотреть. Когда вы остановились на чём-то — не выбрасывайте проделанную работу, укажите, хотя бы кратко, что вы посмотрели и почему остановились именно на этом варианте. Особенно это важно, если выбранный вариант не очевиден, а существует другое, более очевидное, но неправильное решение. Ведь в будущем, вернувшись к этому коду, мы можем захотеть переписать «сложное» решение на более «явное» или «оптимальное», тут-то и комментарий и поможет понять, что к чему. Например: «Я выбрал здесь анимацию при помощи JavaScript вместо CSS, поскольку IE именно в этом месте ведёт себя некорректно».
Например: «Эти значения отформатированы именно так, чтобы их можно было передать на сервер». Не бойтесь комментариев. Чем больше кода в проекте — тем они важнее. Что же касается увеличения размера кода — это не страшно, т.к. существуют инструменты сжатия JavaScript, которые при публикации кода легко их удалят. На следующих занятиях мы поговорим о переменных, блоках и других структурных элементах программы на JavaScript. Переменные
В зависимости от того, для чего вы делаете скрипт, понадобится работать с информацией. Если это электронный магазин - то это товары, корзина. Если чат - посетители, сообщения и так далее. Чтобы хранить информацию, используются переменные. Переменная Переменная состоит из имени и выделенной области памяти, которая ему соответствует. Для объявления или, другими словами, создания переменной используется ключевое слово var:
После объявления, можно записать в переменную данные:
Эти данные будут сохранены в соответствующей области памяти и в дальнейшем доступны при обращении по имени:
Для краткости можно совместить объявление переменной и запись данных:
Аналогия из жизни Проще всего понять переменную, если представить ее как «коробку» для данных, с уникальным именем. Например, переменная message - это коробка, в которой хранится значение "Привет": В коробку можно положить любое значение, а позже - поменять его. Значение в переменной можно изменять сколько угодно раз:
При изменении значения старое содержимое переменной удаляется. Существуют функциональные языки программирования, в которых значение переменной менять нельзя. В таких языках положил один раз значение в коробку - и оно хранится там вечно, ни удалить ни изменить. А нужно что-то другое сохранить - изволь создать новую коробку (объявить новую переменную), повторное использование невозможно. С виду - не очень удобно, но, как ни странно, и на таких языках вполне можно успешно программировать. Изучение какого-нибудь функционального языка рекомендуется для расширения кругозора. Отличный кандидат для этого — язык Erlang . Копирование значений Переменные в JavaScript могут хранить не только строки, но и другие данные, например, числа. Объявим две переменные, положим в одну - строку, а в другую - число. Как вы можете видеть, переменной без разницы, что хранить:
Значение можно копировать из одной переменной в другую.
Значение из num перезаписывает текущее в message. В «коробке» message меняется значение: После этого присваивания в обеих коробках num и message находится одно и то же значение 100500. Важность директивыvar В JavaScript вы можете создать переменную и без var, достаточно просто присвоить ей значение:
Технически, это не вызовет ошибки, но делать так все-таки не стоит. Всегда определяйте переменные через var. Это хороший тон в программировании и помогает избежать ошибок. Откройте пример в IE в новом окне:
Открыть код в новом окне Значение не выведется, будет ошибка. Если в IE включена отладка или открыта панель разработки - вы увидите ее. Дело в том, что почти все современные браузеры создают переменные для элементов, у которых есть id. Переменная test в них в любом случае существует, запустите, к примеру:
..Но в IE<9 такую переменную изменять нельзя. Всё будет хорошо, если объявить test, используя var: Правильный код:
Самое «забавное» — то, что, эта ошибка будет только в IE<9, и только если на странице присутствует элемент с совпадающимid. Такие ошибки особенно весело исправлять и отлаживать. Есть и еще ситуации, когда отсутствие var может привести к ошибкам. Надеюсь, вы убедились в необходимости всегда ставить var. Важность: 2
Решение [Открыть задачу в новом окне] Константы Константа — это переменная, которая никогда не меняется. Как правило, их называют большими буквами, через подчёркивание. Например: показать чистый исходник в новом окнеСкрыть/показать номера строкпечать кода с сохранением подсветки
Технически, константа является обычной переменной, то есть её можно изменить. Но мы договариваемся этого не делать. Зачем нужны константы? Почему бы просто не использовать "#F00" или "#0F0"?
Константы используют вместо строк и цифр, чтобы сделать программу понятнее и избежать ошибок. Имена переменных
Один из самых важных навыков программиста — умение называть переменные правильно. Имена переменных На имя переменной в JavaScript наложены всего два ограничения.
Например:
Что здесь особенно интересно - доллар '$' и знак подчеркивания '_' являются такими же обычными символами, как буквы:
А такие переменные были бы неправильными:
Регистр букв имеет значение Переменные apple и AppLE - две разные переменные. Русские буквы допустимы, но не рекомендуются Можно использовать и русские буквы:
Технически, ошибки здесь нет, но на практике сложилась традиция использовать в именах только английские буквы. Зарезервированные имена Существует список зарезервированных слов, которые нельзя использовать при именовании переменных, так как они используются самим языком, например: var, class, return, implements и др. Некоторые слова, например, class, не используются в современном JavaScript, но они заняты на будущее. Некоторые браузеры позволяют их использовать, но это может привести к ошибкам. Следующий пример будет работать во многих старых браузерах, которые допускают использование слова 'class' и не сработает в современных. Они выдадут синтаксическую ошибку, попробуйте, запустите:
Правильный выбор имени Правильный выбор имени переменной - одна из самых важных и сложных вещей в программировании, которая отличает начинающего от гуру. Дело в том, что большинство времени мы тратим не на изначальное написание кода, а на его развитие. А что такое развитие? Это когда я вчера написал код, а сегодня (или спустя неделю) прихожу и хочу его поменять. Например, вывести сообщение не так, а эдак.. Обработать товары по-другому, добавить функционал.. А где у меня там сообщение хранится?.. Гораздо проще найти нужные данные, если они правильно помечены, т.е. переменная названа правильно.
Неприемлемы:
Подойдут:
Если вы вдруг не знаете английский - самое время выучить. Все равно ведь придется…
Называть переменные именами, не несущими смысловой нагрузки, например a, e, p, mg - можно только в том случае, если они используются в небольшом фрагменте кода и их применение очевидно. Вообще же, название переменной должно быть понятным. Иногда для этого нужно использовать несколько слов.
Например:
Этот способ записи называется «верблюжьей нотацией» или, по-английски, «camelCase». Существует альтернативный стандарт, когда несколько слов пишутся через знак подчеркивания '_':
Преимущественно в JavaScript используется вариант borderLeftWidth, в частности во встроенных языковых и браузерных функциях. Поэтому целесообразно остановиться на нём. Ещё одна причина выбрать «верблюжью нотацию» — запись в ней немного короче, чем c подчеркиванием, т.к. не нужно вставлять '_'.
Придумывание таких имен - одновременно коротких и точных, приходит с опытом, но только если сознательно стремиться к этому. Позвольте поделиться одним небольшим секретом, который позволит улучшить ваши названия переменных и сэкономит вам время. Бывает так, что вы написали код, через некоторое время к нему возвращаетесь, и вам надо что-то поправить. Например, изменить какую-то рамку «border…» … И вы помните, что переменная, в которой хранится нужное вам значение, называется примерно так: borderLeftWidth. Вы ищете ее в коде, не находите, разбираетесь, и обнаруживаете, что на самом деле переменная называлась вот так: leftBorderWidth. После чего вносите нужные правки. В этом случае, самый лучший ход - это переименовать переменную на ту, которую вы искали изначально. То есть, у вас в кодеleftBorderWidth, а вы ее переименовываете на borderLeftWidth. Зачем? Дело в том, что в следующий раз, когда вы захотите что-то поправить, то вы будете искать по тому же самому имени. Соответственно, это сэкономит вам время. Кроме того, поскольку именно это имя переменной пришло вам в голову - скорее всего, оно больше соответствует хранимым там данным, чем то, которое вы придумали изначально. Смысл имени переменной - это «имя на коробке», по которому мы сможем максимально быстро находить нужные нам данные. Не нужно бояться переименовывать переменные, если вы придумали имя получше. Современные редакторы позволяют делать это очень удобно. Это в конечном счете сэкономит вам время. Храните в переменной то, что следует Бывают ленивые программисты, которые, вместо того чтобы объявить новую переменную, используют существующую. В результате получается, что такая переменная — как коробка, в которую кидают то одно, то другое, то третье, при этом не меняя название. Что в ней лежит сейчас? А кто его знает.. Нужно подойти, проверить. Сэкономит такой программист время на объявлении переменной — потеряет в два раза больше на отладке кода. «Лишняя» переменная — добро, а не зло. Важность: 3
Решение [Открыть задачу в новом окне] Введение в типы данных
В JavaScript существует несколько основных типов данных. Типы данных
Как правило, такой тип используется для хранения значения типа да/нет, например:
О нём мы поговорим более подробно, когда будем обсуждать логические вычисления и условные операторы.null — специальное значение. Оно имеет смысл «ничего». Значение null не относится ни к одному из типов выше, а образует свой отдельный тип, состоящий из единственного значения null:
Если переменная объявлена, но в неё ничего не записано, то ее значение как раз и есть undefined:
Можно присвоить undefined и в явном виде, хотя это делается редко:
В явном виде undefined обычно не присваивают, так как это противоречит его смыслу. Для записи в переменную «пустого значения» используется null.
Первые 5 типов называют «примитивными». Особняком стоит шестой тип: «объекты». К нему относятся, например, даты, он используется для коллекций данных и для многого другого. Позже мы вернёмся к этому типу и рассмотрим его принципиальные отличия от примитивов. Итого Есть 5 «примитивных» типов: number, string, boolean, null, undefined и 6-й тип — объекты object. 9> |