Тест на крепкого JS программера
Столкнулись тут мы с валом резюме на вакансию JS программера в нашу новую компанию. Понятно, что обработать огромное количество заявок силами двух человек весьма сложно. Разумным выходом является тест, по результатам которого некоторую часть кандидатов мы приглашаем на собеседование. Тест я написал на этих выходных, результат под катом.
Внимание, вопрос JS программерам, есть ли какие-то вещи, которые не нашли отражения в этом тесте?
1. Кроссбраузерность:
1.1. Расскажите, какие методы межсерверных запросов вы знаете и применяете.
1.2. XSS атаки: как они работают, что вы делаете для защиты от них?
2. протокол HTTP:
2.1. какие методы вы применяете и как?
2.2. Как осуществляется передача файлов с клиента на сервер и с сервера на клиент?
2.3. keep-alive и как он применяется для оптимизации работы скриптов?
2.4. Кэширование: какие есть заголовки, как они применяются, какие методы вы применяете для защиты от кэширования на прокси серверах?
3. scriptHost: какие отличия скриптовых движков браузеров вы знаете (без DOM модели)?
4. ООП:
4.1. Что такое ООП? Основные принципы.
4.2. как JS соотносится с парадигмой OOП? Поясните свой ответ.
5. Шаблоны проектирования (Design Patterns):
5.1. Что такое шаблоны проектирования и для чего они нужны?
5.2. MVC в JS – применяете ли вы этот шаблон? Если применяете, то как (пример кода)? Если не применяете, то почему?
5.3. Синглтон в JS. Что это такое? Зачем он может понадобиться в JS?
6. Быстродействие:
6.1. Как бы вы сложили 20 строк в JS?
6.2. Расскажите про влияние разных стилей вёрстки на скорость загрузки страницы.
6.3. Что ещё влияет на скорость загрузки страницы?
6.4. Как вы оптимизируете скорость загрузки страницы? Любимые приёмы улучшения производительности работы.
6.5. Как влияют отличия в работе с DOM моделью браузеров на скорость загрузки?
7. Браузеры
7.1. С какими браузерами вы работали?
7.2. Расскажите про отличия между ними.
8. Вёрстка:
8.1. Что такое сематическая вёрстка и зачем она нужна?
8.2. Что такое микроформаты?
8.3. Как бы вы сверстали горизонтальное меню сайта? Пример кода. Почему именно так?
8.4. Что вы можете рассказать о таком коде: <table><tr><td>cell</td><td>cell</td></tr></table>?
8.5. Зачем нужна вёрстка на дивах? Какие преимущества она даёт? Какие есть недостатки? В каких случаях её лучше не применять?
8.6. Есть код: <div id="AAA"><div><h1>header</h1><span class="comment">comment</span><span id="buttons">buttons</span>text</div></div>. Напишите CSS селекторы, чтобы раскрасить подчёркнутые слова в разные цвета.
8.7. Есть многострочная таблица. Нужно сделать каждую чётную строку чуть темнее, чем нечётную. Как вы это реализуете? Почему?
8.8. Есть древовидная дискуссия, например, как на habrahabr.ru. Необходимо сохранить отметки о прочтении ответов, чтобы они оставались после перезагрузки страницы и каждый прочитанный ответ был отмечен картинкой-пиктограммой. Как вы это реализуете?
8.9. Нужно сверстать выпадающее меню, не применяя JS. Расскажите о способах и их недостатках.
8.10. Необходимо прижать футер к низу страницы. Расскажите о способах и их недостатках.
8.11. Необходимо сделать круглые края у кнопки. Расскажите о способах и их недостатках.
8.12. Дизайнер нарисовал картинку со множеством кнопочек. Необходимо нарезать кнопки и вставить в дизайн. Как вы будете это делать?
8.13. Сделайте круговую диаграмму с 5 сегментами, размеры которых задаются переменными в JS и пришлите пример кода.
9. Тестирование:
9.1. а как вы тестируете вёрстку? (методы, фреймворки, подходы)
9.2. На какие вещи необходимо обращать внимание при тестировании вёрстки?
9.3. Как вы отлаживаете JS код?
9.4. На что обращаете внимание при тестировании JS?
10. AJAX:
10.1. Мультипоточность/многозадачность в JS, как она реализуется?
10.2. Как сделать синхронизированную секцию на JS в браузере?
10.3. Нужно написать web чат: страничка в которой есть список сообщений от пользователей и форма отправки. Какой подход вы используете для реализации и почему?
10.4. Для вставки нового элемента в DOM модель необходимо сгенерировать уникальный ID. Как как вы это сделаете?
UPD
Предполагается, что этот тест будет высылаться по email людям, которые указали мало своих скилов в резюме, не предоставили примеры своих работ или в скилах которых мы сомневаемся
Источник: http://habrahabr.ru/blogs/javascript/76730/
Столкнулись тут мы с валом резюме на вакансию JS программера в нашу новую компанию. Понятно, что обработать огромное количество заявок силами двух человек весьма сложно. Разумным выходом является тест, по результатам которого некоторую часть кандидатов мы приглашаем на собеседование. Тест я написал на этих выходных, результат под катом.
Внимание, вопрос JS программерам, есть ли какие-то вещи, которые не нашли отражения в этом тесте?
1. Кроссбраузерность:
1.1. Расскажите, какие методы межсерверных запросов вы знаете и применяете.
1.2. XSS атаки: как они работают, что вы делаете для защиты от них?
2. протокол HTTP:
2.1. какие методы вы применяете и как?
2.2. Как осуществляется передача файлов с клиента на сервер и с сервера на клиент?
2.3. keep-alive и как он применяется для оптимизации работы скриптов?
2.4. Кэширование: какие есть заголовки, как они применяются, какие методы вы применяете для защиты от кэширования на прокси серверах?
3. scriptHost: какие отличия скриптовых движков браузеров вы знаете (без DOM модели)?
4. ООП:
4.1. Что такое ООП? Основные принципы.
4.2. как JS соотносится с парадигмой OOП? Поясните свой ответ.
5. Шаблоны проектирования (Design Patterns):
5.1. Что такое шаблоны проектирования и для чего они нужны?
5.2. MVC в JS – применяете ли вы этот шаблон? Если применяете, то как (пример кода)? Если не применяете, то почему?
5.3. Синглтон в JS. Что это такое? Зачем он может понадобиться в JS?
6. Быстродействие:
6.1. Как бы вы сложили 20 строк в JS?
6.2. Расскажите про влияние разных стилей вёрстки на скорость загрузки страницы.
6.3. Что ещё влияет на скорость загрузки страницы?
6.4. Как вы оптимизируете скорость загрузки страницы? Любимые приёмы улучшения производительности работы.
6.5. Как влияют отличия в работе с DOM моделью браузеров на скорость загрузки?
7. Браузеры
7.1. С какими браузерами вы работали?
7.2. Расскажите про отличия между ними.
8. Вёрстка:
8.1. Что такое сематическая вёрстка и зачем она нужна?
8.2. Что такое микроформаты?
8.3. Как бы вы сверстали горизонтальное меню сайта? Пример кода. Почему именно так?
8.4. Что вы можете рассказать о таком коде: <table><tr><td>cell</td><td>cell</td></tr></table>?
8.5. Зачем нужна вёрстка на дивах? Какие преимущества она даёт? Какие есть недостатки? В каких случаях её лучше не применять?
8.6. Есть код: <div id="AAA"><div><h1>header</h1><span class="comment">comment</span><span id="buttons">buttons</span>text</div></div>. Напишите CSS селекторы, чтобы раскрасить подчёркнутые слова в разные цвета.
8.7. Есть многострочная таблица. Нужно сделать каждую чётную строку чуть темнее, чем нечётную. Как вы это реализуете? Почему?
8.8. Есть древовидная дискуссия, например, как на habrahabr.ru. Необходимо сохранить отметки о прочтении ответов, чтобы они оставались после перезагрузки страницы и каждый прочитанный ответ был отмечен картинкой-пиктограммой. Как вы это реализуете?
8.9. Нужно сверстать выпадающее меню, не применяя JS. Расскажите о способах и их недостатках.
8.10. Необходимо прижать футер к низу страницы. Расскажите о способах и их недостатках.
8.11. Необходимо сделать круглые края у кнопки. Расскажите о способах и их недостатках.
8.12. Дизайнер нарисовал картинку со множеством кнопочек. Необходимо нарезать кнопки и вставить в дизайн. Как вы будете это делать?
8.13. Сделайте круговую диаграмму с 5 сегментами, размеры которых задаются переменными в JS и пришлите пример кода.
9. Тестирование:
9.1. а как вы тестируете вёрстку? (методы, фреймворки, подходы)
9.2. На какие вещи необходимо обращать внимание при тестировании вёрстки?
9.3. Как вы отлаживаете JS код?
9.4. На что обращаете внимание при тестировании JS?
10. AJAX:
10.1. Мультипоточность/многозадачность в JS, как она реализуется?
10.2. Как сделать синхронизированную секцию на JS в браузере?
10.3. Нужно написать web чат: страничка в которой есть список сообщений от пользователей и форма отправки. Какой подход вы используете для реализации и почему?
10.4. Для вставки нового элемента в DOM модель необходимо сгенерировать уникальный ID. Как как вы это сделаете?
UPD
Предполагается, что этот тест будет высылаться по email людям, которые указали мало своих скилов в резюме, не предоставили примеры своих работ или в скилах которых мы сомневаемся
Источник: http://habrahabr.ru/blogs/javascript/76730/