[Ответить в тред] Ответить в тред

02/12/16 - Конкурс визуальных новелл доски /ruvn/
15/11/16 - **НОВЫЙ ФУНКЦИОНАЛ** - Стикеры
09/10/16 - Открыта доска /int/ - International, давайте расскажем о ней!



Новые доски: /2d/ - Аниме/Беседка • /wwe/ - WorldWide Wrestling Universe • /ch/ - Чатики и конфочки • /int/ - International • /ruvn/ - Российские визуальные новеллы • /math/ - Математика • Создай свою

[Назад][Обновить тред][Вниз][Каталог] [ Автообновление ] 508 | 59 | 138
Назад Вниз Каталог Обновить

JavaScript #70 Аноним 29/11/16 Втр 19:43:34  884383  
14609873131220.jpg (37Кб, 1052x1052)
Ссылка на прошлый тред: >>877341 (OP)

Этот тред посвящён главному языку будущего - JavaScript. Благодаря своей гибкости используется в браузере, на серверах, в мобильных приложениях, на десктопе и практически во всех видах программирования. Удобный синтаксис позволяет легко писать на нём, а высокая производительность делает его отличным выбором для решения любых задач - от небольших магазинов до огромных highload проектов. JavaScript по праву является самым популярным в мире языком. На каждом сайте есть браузерный JavaScript, а JavaScript на сервере используется такими крупными корпорациями, как Amazon, Yahoo, HP, NASA, Walmart и многие другие.

Часто задаваемые вопросы:
https://github.com/xxxwww/js-thread/blob/master/Wiki/faq.md

Список материалов для изучения:
https://github.com/xxxwww/js-thread/blob/master/Wiki/learn.md

Список инструментов и направления JS-разработки:
https://github.com/xxxwww/js-thread/blob/master/Wiki/tools.md

JS-конфа в телеграме:
https://telegram.me/jsthread

Конфа /pr/ в Slack:
https://invite-me-to-2chpr.herokuapp.com/

НЕ КОПИРУЙ КОД ПРЯМО В ТРЕД!
Воспользуйтесь https://jsfiddle.net/ для браузерного кода и https://ideone.com/ для серверного кода.
Аноним 29/11/16 Втр 19:49:48  884390
Сап, аномач. Вопрос к анонам, которые работают с ангуляром. Как там логин/регистрацию/доамшняя/404 правильно сделать? Есть ли какие-нибудь super simple example авторизации для ui-router? А то пиздец какой-то. Что ни найду - на 150+ строк в каждом файле с методами и контроллерами - один охуительней другого.
Хочу на что-то очень простое посмотреть, а потом зарисовать схемку, чтобы окончательно разобраться уже - что куда и откуда идёт.
Аноним 29/11/16 Втр 20:04:35  884399
Скриптач, вот такой пет проект для портфолио сделал, норм?
http://anoblog.herokuapp.com/
Аноним 29/11/16 Втр 20:05:46  884400
>>884399
Нет. Я бы тебя зассал, чмошник. Пришёл бы ко мне на собес - а я бы зассал.
Аноним 29/11/16 Втр 20:07:16  884403
>>884399
А теперь, собственно, открываю ссылку.
Прикольно, кстати. Норм. Можно ещё версию в материал-дизайне сделать
Аноним 29/11/16 Втр 20:08:38  884404
>>884400
>материал-дизайне
Это как?
Аноним 29/11/16 Втр 20:11:49  884407
>>884404
>материал-дизайне
Загуглил, слишкам сложна, я же не дизайнер
Аноним 29/11/16 Втр 20:13:20  884408
>>884407
Да лол, какой сложно. В бутстрап тоже не можешь? А там та же херь. Гугли ангуляр материал. Дописал md-input и радуйся
Аноним 29/11/16 Втр 20:15:23  884409
>>884399
ты чо, охуел?

>Пожалуйста, ввойдите в свой профиль
>Пожалуйста, ввиедите пароль
Аноним 29/11/16 Втр 20:16:12  884410
>>884409
Ну пожалуйста
Аноним 29/11/16 Втр 20:17:19  884411
>>884410
Ладно, Арсен, только русский подучи
Аноним 29/11/16 Втр 20:18:09  884413
>>884411
Из - за гринтекста не видел опечатки, лол
Спасибо
Аноним 29/11/16 Втр 20:20:21  884416
>>884399

Как попап на логине сделал? Хочу такой же сделать, пока не получается.
Аноним 29/11/16 Втр 20:21:44  884418
>>884416
>Как
Что именно тебе не понятно?

Аноним 29/11/16 Втр 20:23:57  884420
Как правильно в nodejs сделать туеву хучу insert-ов или update-ов в postgresql базу асинхронно? Дохуя - то есть база на несколько ГБ и ее нужно заполнить или обновить всю.
Если делать через pg-promise - можно сделать, допустим, 10 одновременных запросов по 10к строк за раз (типа пул). Когда один из запросов завершится, посылать следующие 10к строк. Это хорощая идея?
Аноним 29/11/16 Втр 20:26:41  884424
>>884418

Ну ты его делал типа кликаешь на "войти" и вызывается компонент с формой? А что бы была анимация все это оборачивал в транзишионгруп или не так?
Видел, там есть готовый пакет реакт-попап, но хочется вручную сделать.
Аноним 29/11/16 Втр 20:28:45  884425
>>884424
onClick => changeState({showLoginForm: true})
> оборачивал в транзишионгруп
Да
Аноним 29/11/16 Втр 20:29:27  884428
>>884425

О, спасибо.
Аноним 29/11/16 Втр 20:31:45  884430
>>884399
а ничего, что файлик js весит ~3мб?
Аноним 29/11/16 Втр 20:35:26  884432
>>884430
Там кроме реакта ничего большого, вроде, нет.
При этом бандл еще и минимизированный
Аноним 29/11/16 Втр 20:40:18  884438
Как быстро можно выучить реакт, если знаю js и другие языки, но фронтом мало занимался и делал все на чистом js + jquery?
Алсо, если фронт - это не основное мое занятие, достаточно знать реакт, или еще ангуляр желательно?
Аноним 29/11/16 Втр 22:13:52  884523
5.jpg (401Кб, 596x658)
>>884399
Но подожди, у тебя же inline source map, они же больше самого бандла занимают, не делай так пожалуйста
Аноним 29/11/16 Втр 22:47:43  884552
Screenshot1.jpg (3Кб, 213x34)
>>884523
Спасибо
Аноним 29/11/16 Втр 23:35:11  884599
Аноны, есть ли шансы устроиться джуном со знаниями ванильного жс и jquery (html/css само собой)?
Аноним 29/11/16 Втр 23:44:21  884607
>>884399
Дизайн уж слишком простецкий и это портит первое впечатление. Норм для пустого портфолио, но в будущем заменить.
Аноним 29/11/16 Втр 23:45:24  884608
>>884599
Нет. Я сейчас джуню - нужны реально хорошие знания 3х жс - 3, 5 и 6.
Также html, css и иметь представление о scss/less.
Ещё - знать сборку gulp или webpack.
Ещё - какие-то знания ангуляра/реакта. Чтобы быстро включиться в проект.
Гит, джира, всё такое - по-умолчанию.

Я с этими знаниями сейчас месяц на испытательном, обещают $100. Ещё через месяц - 200, потом 300, как окончательный вариант.
А потом уже - типа учиться и прокачиваться.
Аноним 29/11/16 Втр 23:46:08  884609
>>884608
Ну и ООП забыл. Хотя бы фабрики и сервисы
Аноним 29/11/16 Втр 23:49:25  884618
>>884390
Ты для обучения? Зареализуй тогда свой велосипед, как раз и разберешься. Авторизация - самый обычный http запрос.
Сделай там себе роут на страничку авторизации, контроллер с полями логин, пароль и функцией для логина с помошью $http. Куда уж проще?
Аноним 29/11/16 Втр 23:57:05  884632
>>884618
Честно? В том числе. Но больше - потушить свой пердак, т.к. это было моё тестовое задание, которое я провалил с успехом.
И это не совсем запрос. Я пытаюсь понять, как вот такое https://github.com/cornflourblue/angular-registration-login-example
Перевести сейчас на новомодный ES6 с этими вашими import и export default.

Нашёл, блин, самый простой пример. Херотень на 1к+ строк кода.
Аноним 29/11/16 Втр 23:58:22  884634
>>884618
Я мудак, анон. У него ж там ссылка на 2й ангуляр. Спасибо тебе.
С утра эту херь ковыряю, глаза в точку уже.
Аноним 30/11/16 Срд 00:16:10  884658
>>884634
Я нихуя не понял, но ладно. На том гитхабе вроде 1 ангуляр и вполне себе читабельный кстати. Если хочешь 1 ангуляр с чисто es6, то посмотри вот этот вот тутор:
https://github.com/angular/material-start/tree/es6-tutorial
заодно material design обмажешься.
Не знаю, я лично es6 плюшки использую, но сборку в одно единое приложение как-то всегда доверял gulp.
Аноним 30/11/16 Срд 00:21:57  884661
>>884658
Спасибо, анон. Посмотрю. По сборке - мне тоже галп больше нравится.
Аноним 30/11/16 Срд 03:29:30  884704
14802711475350.png (284Кб, 650x581)
>>884608
От конкурентов избавляешься?
Аноним 30/11/16 Срд 03:34:17  884706
>>884704
Какие тут конкуренты. Думаю уже каким-нибудь пехотинцем пойти работать на судно.
Серьёзно, заебало. Нужно знание гильотины, 10 лет на плантации, из них - 5 на китайской.
Ну... можем вам еды предложить
Аноним 30/11/16 Срд 04:42:25  884723
14801060102750.jpg (53Кб, 300x274)
>>884706
Как же ты себя не ценишь, анон. Нельзя так.
Аноним 30/11/16 Срд 06:03:34  884727
>>884723
Жизнь заставит - и не на такое согласишься. В веб идут не от хорошей жизни, а чисто чтоб пожрать было что.
Алсо, в ебенях на 100 баксов можно даже жить. Хуево, но лучше так, чем никак.
Аноним 30/11/16 Срд 06:58:30  884735
>>884632
Обмазывайся TypeScript. Когда-нибудь придётся перекатываться на ng2
https://github.com/Dimous/crt-ts-recoding/blob/master/module/controllers/IndexController.ts
Аноним 30/11/16 Срд 08:54:49  884753
>>884735
Если это ты делал crt.ru, то СЕОшники тебя наверное просто обожают.
Аноним 30/11/16 Срд 09:03:43  884756
>>884753
Нит. Там команда профессионалов. Меня не взяли.
Аноним 30/11/16 Срд 09:11:38  884761
>>884756
Ну значит ту команду профессионалов любят. Хотя... в будущем уже будет не актуально.
Аноним 30/11/16 Срд 09:20:19  884765
>>884761
Как минимум для гугла
https://medium.freecodecamp.com/using-fetch-as-google-for-seo-experiments-with-react-driven-websites-914e0fc3ab1#.vdap51500
Аноним 30/11/16 Срд 09:30:59  884770
>>884765
То, что поисковики научились нормально работать с SPA - это по-моему относительно новая тенденция. Где-то проебал ссылку на новость.
Даже в статье по ссылке пишется, что бот читает страницу, но с траблами.
Аноним 30/11/16 Срд 11:18:08  884829
>>884727

А от хорошей куда идут?
Аноним 30/11/16 Срд 11:19:07  884832
>>884727

Работать, вообще, идут не от хорошей жизни.
Аноним 30/11/16 Срд 11:22:58  884833
>>884608
> 3х жс - 3, 5 и 6
Проиграл. Был один язык, а теперь 3?
Аноним 30/11/16 Срд 11:43:21  884843
>>884727
> В веб идут не от хорошей жизни, а чисто чтоб пожрать было что.
Кекнул
мимо-$2.5к-мидл
Аноним 30/11/16 Срд 13:40:40  884906
Подскажите как мне сделать примерно следующий функционал, вот у меня сейчас вылезает модальник, в котором можно вбить сумму и нажать кнопочку, и тогда эта сумма полетит в указанный в action пхп скрипт.

Собственно что мне нужно: нужно что бы помимо поля был еще селект с 3 опциями, и если выбрана первая, то появляется еще 1 обязательное поле.
Если выбрана другая опция, то например 2 дополнительных поля. И наконец если третья опция, то под ней появляется скажем 5 дополнительных обязательны полей.

Далее при нажатии кнопки мне нужно склеить всё что там вбито в дополнительные поля в осмысленную красивую строчку и послать вместе с суммой на обработку скрипту.

Есть идеи с чего начать? Собственно меня мучает только js-вопрос, о том как всё это сделать, отправка на скрипт и обработка потом на сервере - это для меня легко.
Аноним 30/11/16 Срд 13:42:26  884910
>>884906
Забыл уточнить, что в action в итоге должно полететь 2 значения - изначальная сумма, и отдельно склеенная из дополнительных полей строчка, под двумя разными именами соответственно.

Заранее спасибо.

Аноним 30/11/16 Срд 14:46:07  884963
>>884608
толсто
Аноним 30/11/16 Срд 15:27:14  885017
>>884963
Для выпускника универа для какой-нибудь мухосранской конторы - вполне реальные требования и зп. Другое дело, что не требуется все знать на уровне мидла. Да и вообще - там учить-то нечего.
Аноним 30/11/16 Срд 15:38:09  885031
Как сделать что бы инпут был рекваеред, только если он видимый?
А когда стоит display:none то похуй было на него вообще?
Аноним 30/11/16 Срд 15:40:21  885035
14802775909320.jpg (115Кб, 1134x757)
>>884829
В гей шлюхи.
Аноним 30/11/16 Срд 16:24:14  885059
Всем привет! Начинаю пилить новый проект и хотелось бы попробовать Angular, что мне стоит почитать, чтобы понять сам концепт и философию этого фреймворка?
Аноним 30/11/16 Срд 16:59:47  885091
>>885059
http://metanit.com/web/angular/
Аноним 30/11/16 Срд 17:02:29  885096
>>885091
Неплохо. Нет такого по реакту?
Аноним 30/11/16 Срд 17:04:15  885098
>>885091
Разве есть смысл сейчас учить первый angular? Второй же перспективней.
Аноним 30/11/16 Срд 17:04:40  885100
>>885096
Реакт же прост как палка, зачем по нему гайды?
Аноним 30/11/16 Срд 17:15:15  885114
>>885100
ReactNative интересен, ищу гайды, в свете вопроса описанного тут
https://2ch.hk/pr/res/884999.html
Статьи на хабре в основном говорят что такие инструменты годны только для создания прототипа, и все равно что-то серьезное придется писать на native.
Аноним 30/11/16 Срд 17:27:25  885121
>>884833
Был ES3. Затем ES5. Потом ES6. А сейчас можно писать и на babel-preset-nigga-what-you-doing-stage-0-ES7.
Изредка бывает полезно знать различия между редакциями.
Аноним 30/11/16 Срд 19:14:44  885180
>>885091
Спасибо большое! Есть ли смысл изучать Angular 1 или лучше сразу начать со 2ой версии?
Аноним 30/11/16 Срд 19:17:48  885182
>>885180
Если нет вакансии для первого, на которой уже завтра можешь работать, лучше начать со второго
Аноним 30/11/16 Срд 19:18:57  885183
>>885114
А что там гайды, учишь рекат, идешь на
https://facebook.github.io/react-native/, изучаешь туториал, все, можешь пилить приложухи на реакт-нейтив.
На js.coach можешь искать компоненты под RN, добрые люди уже запилили довольно много всякого.
Аноним 30/11/16 Срд 20:36:35  885221
>>885183
>js.coach
прочитал js.cocach

Скажи, на сколько реакт нейтив в плане кроссплатформенности отличается от кордовы.
Я так понимаю что "Learn once, write anywhere" и "Write once, run anywhere" в корне разные вещи. Можно запилить один и тот же код на реакте под андроид и айос с небольшими переделками, или же это будут две разных обертки?
Аноним 01/12/16 Чтв 00:04:23  885322
Ачобусы, есть проблема.
Есть 2 файла: app.js и pass.js. Так вот, из второго я беру переменную, он выглядит примерно так:
const PASS = 'some data here';
export {PASS};
Импортирую я ее в app.js
import PASS from './components/pass';
дальше пытаюсь с ней что-то сделать, хотя бы вывести, но не выводится. Хотя если напрямую создать ее в app.js то все ок работает, но так нельзя. Где я ошибся, почему переменная не экспортируется нормально?
Аноним 01/12/16 Чтв 00:08:20  885324
>>884963
Не толсто. Минск лол
Аноним 01/12/16 Чтв 00:11:01  885326
>>885098
Второй перспективнее, но продакшн на нём пилить бОльшая часть контор начнёт не скоро. Банально нет той кучи инструментов и модулей, которые есть для 1.
Вообще хз, в свете тенденции, что теперь новую версию чуть не каждый год хотят релизить, думаю на реакт перекатываться.
Как-то не фанат я каждый год учить новый синтаксис и концепцию.
Аноним 01/12/16 Чтв 00:13:34  885328
>>885326
> Как-то не фанат я каждый год учить новый синтаксис и концепцию.
Откуда вы лезете? Почему вы маняфантазируете вместо того, чтобы прочитать про переход ангулара на семвер?
Аноним 01/12/16 Чтв 00:32:53  885333
Есть идеи у кого по >>884390 ?
Аноним 01/12/16 Чтв 00:36:17  885334
>>885322
export default pass
Аноним 01/12/16 Чтв 00:55:36  885338
>>885334
Спасибо за ответ!
Аноним 01/12/16 Чтв 00:57:23  885340
Как такое http://plnkr.co/edit/UkHDqFD8P7tTEqSaCOcc?p=preview на ES2015 переписать? С этими module и component
Аноним 01/12/16 Чтв 01:06:37  885349
>>885340
В смысле как? Читаешь спеки, смотришь что чем можно заменить и заменяешь. Или пишешь с нуля, подсматривая в архитектуру этого приложения, что значительно проще
Алсо, это первый ангулар. Я б его сейчас уже не трогал.
Аноним 01/12/16 Чтв 01:31:31  885375
>>885349
В смысле за сколько я это смог бы переписать, если вообще ничего не знаю про новую модель, а делал раньше на контроллёрах и фабриках? Думаю вечерком завтра заняться. Прикидываю, что занятие на пару часов, я прав?
Аноним 01/12/16 Чтв 03:41:25  885463
>>885221
Можно, в текущем проекте, в котором около 7 экранов, у меня всего один компонент написан отдельно на ведро и ыфон, все остальные общие.
С кордовой не работал, но типы говорили что RN после кородовы, как манна небесная
Аноним 01/12/16 Чтв 04:08:38  885476
Що нужно знать js нубу, чтобы претендовать на работу ирл?
Аноним 01/12/16 Чтв 04:45:12  885489
Гайз, есть смысл учить первый ангуляр? Или копать сразу второй? Слышал что у первого ангуляра проблем вагон, а во втором все исправили
Аноним 01/12/16 Чтв 07:37:09  885515
>>885476
ООП, ДОМ, замыкание, кроссбраузерность, ajax
jquery/фреймворк из требований вакансии
шаблонизатор
реакт / ангуляр
писать в каком-нибудь AirBnB, например
Аноним 01/12/16 Чтв 07:41:21  885516
>>885515
Звучит сложно.
Аноним 01/12/16 Чтв 07:41:27  885517
>>885515
>2к16
>кроссбраузерность
Аноним 01/12/16 Чтв 07:49:29  885519
>>885517
ну удачи
до этого доёбываются и не слабо, на собеседовании ты не скажешь "какая ещё кроссбраузерность в 2К16?"
Аноним 01/12/16 Чтв 09:02:52  885528
Вопрос по Npm (или nmp?). Скажем поставил я его user/sosaka. Затем накатил фреймворк и перешёл в c/sin/sobaki. Теперь снова накатил фреймворк, (через тот же nmp - g huyeviiframe, пусть второй зависит от первого). Они установится в разные папки? (один в юзер, другой в собаку?) Они будут друг друга видеть?
Аноним 01/12/16 Чтв 09:04:16  885529
>>885519
Лол, меня не доебывали про кроссбраузерность.
Зато спрашивали про недостатки сокетов, преимущества NoSQL и продвинутое использование гита. На фронт энд собеседовании. У меня конечно был специфический случай, но все же иметь какое-то представление о серверной части - большой плюс.
Аноним 01/12/16 Чтв 09:09:30  885530
>>885528
Не понял, ты в сын собаки поставил с -g ?
Аноним 01/12/16 Чтв 09:12:14  885531
>>885530
Да. А как надо? Хотелось бы что бы все было в одном месте, а то по невнимательности наплодил папок, и теперь все через жопу работает
Аноним 01/12/16 Чтв 09:28:56  885533
>>885531
Ключ -g - ставит пакет глобально. Он будет поставлен в общую папку, которую вроде как должно быть видно из любой другой папки.
Ставя без -g - пакет будет поставлен в текущей папке в node_modules.
При require подключении пакет ищется в текущей папке, если его нет, папкой выше, если нет, папкой выше... и так, пока не дойдет до глобального node_modules.
Если поставил пакеты в папки сын собаки и юзер сосака без -g и папки не находятся в отношении родитель-потомок, пакет найден не будет. Но ты можешь вручную укзать откуда дергать пакет (с помощью относительного адреса).
Например, папки сын собаки и сосака находятся в одной родительской папке. Тогда ты из папки юзер/сосака обратиться к модую в сын собаки примерно так (точно как писать не помню):
package = require('.../syn/sobaki')

Вроде как-то так
Аноним 01/12/16 Чтв 09:59:46  885548
>>885533
Спасибо анон
Аноним 01/12/16 Чтв 12:28:15  885600
Нубский вопрос по js-модулям.

Дано: есть бандл, собранный вебпаком (да хоть RequireJs.. неважно). Есть движок (Laravel, Yii etc). В бандле есть модуль, которому для работы нужны какие-то пользовательские данные из БД.

В шаблоне написано что-то вроде
<script src="i-am-idiot.js"></script>
<script>
var user = <?php echo $user; ?> (просто пример, забей на синтаксис и ошибки).
var idiot = new Idiot(user);
</script>

При олдскульном подходе всё работает. Но после упаковки модуля "i-am-idiot.js" с другими модулями и библиотеками, браузер говорит "Idiot is not defined". Само собой, как бы. Я понимаю, почему это происходит. Но я не понимаю, что делать?

Вариант перенести запрос данных аяксом внутрь "i-am-idiot.js" - не вариант.
Аноним 01/12/16 Чтв 12:34:22  885607
>>885600
Зделой отдельный тег script с типом "application/json" и пиши в него данные для инициализации своего скрипта. Или я не совсем уловил суть твоей проблемы?
Аноним 01/12/16 Чтв 12:39:20  885611
>>885607
Не совсем. Для каждого юзера данные разные конечно. Для разных экземпляров чего-либо тоже. Например, страницы /user/123 и /user/456

На первой надо юзать данные о юзере 123, на второй соответственно о юзере 456.
Аноним 01/12/16 Чтв 12:43:54  885613
>>885607
Ну и сопутствующая проблема. На сайте 100500 страниц. При олдскульном подходе я просто на каждой странице делаю initSomething(options). или initSomething(), когда опций нет.

Если не делать этот вызов со страницы, а запихнуть в бандл, то он будет вызываться на каждой странице, потому что бандл включён в каждую страницу. Но это не то, чего хочется.
Аноним 01/12/16 Чтв 12:51:05  885617
>>885611
>>885613
Так я не понял, чем не подходит тебе озвученный вариант?
Из своего пхп скрипта пишешь в страницу тег script с данными для инициализации, хоть для каждой отдельной страницы:

<script id="init" type="application/json"><?php echo "{'user': $user}"; ?></script>

Потом в своем бандле, как ты его называешь, подтягиваешь эти данные со страницы:

var user = JSON.parse(document.getElementById('init').innerHTML);
var idiot = new Idiot(user);

Аноним 01/12/16 Чтв 12:58:36  885618
>>885617
Я неправильно тебя понял изначально. Я думал, ты предлагаешь на серваке создавать json-файлы. Так то конечно можно хоть в data-атрибуты инфу запихнуть. Но твой способ лучше, спасибо, возьму на заметку.

Но один минус есть. initIdiot будет вызвана на каждой странице, куда подключён бандл. А нужно, чтоб вызывалась только на конкретной странице.

Буквально минуту назад осенило. Может неидеальный способ, но тем не менее проблему решает. Надо просто в "i-am-idiot.js" дописать "window.Idiot = Idiot". Тогда можно спокойно юзать этот модуль только там, где мне нужно.
Аноним 01/12/16 Чтв 13:25:05  885626
>>885529
у меня был хуже случай, даже не заставляй вспоминать
Аноним 01/12/16 Чтв 20:39:19  885891
>>884383 (OP)
Что лучше учить angular или react? За каким фреймворком будущее?
Аноним 01/12/16 Чтв 20:39:57  885892
>>885891
Охуеть, как ты вовремя. Зашел за тем же вопросом.
Аноним 01/12/16 Чтв 20:43:58  885895
>>885891
>>885892
Очень странный вопрос. На уровне Java или Javascript
Аноним 01/12/16 Чтв 20:48:34  885897
>>885895
Но выбор-то все равно нужно сделать. Это нормальный вопрос.
Аноним 01/12/16 Чтв 20:48:41  885898
>>885895
C чего бы? Тут сравниваются абсолютно эквивалентные вещи.
Аноним 01/12/16 Чтв 21:03:42  885907
>>885897
По каким критериям ты хочешь сделать выбор? За обоими фреймворками стоят крупные корпорации, в ближайшие несколько лет с ними точно ничего не случится, они будут развиваться и обростать коммьюнити. Можешь тупо выбирать то, что больше нравится

>>885898
Абсолютно для разных потребностей и разных проектов, как мне кажется. Реакт больше для хуяк-хуяк и маленьких проектов, ангулар же с его развитым DI, в сравнении с реактом, больше для энтерпрайза
Аноним 01/12/16 Чтв 21:33:30  885922
>>885907
Собственно вот такого ответа я и ожидал, начну вкатываться в ангуляр.
>>885898 анон
Аноним 01/12/16 Чтв 22:25:59  885947
>>885891
vue.js
Аноним 01/12/16 Чтв 23:13:21  885992
>>885891
Таки реакт - не фреймворк, а библиотека. Так что ключевая разница в том, нужна ли тебе структура приложения, предлагаемая ангуляром, или ты спроектируешь сам. В остальном дело вкуса. Что бы ни говорили, нормально клепать можно и с тем, и с другим.
Аноним 01/12/16 Чтв 23:55:54  886015
>>885992
Какую структуру приложения предлагает ангуляр?
Аноним 02/12/16 Птн 00:06:18  886019
>>886015
https://github.com/johnpapa/angular-styleguide
Аноним 02/12/16 Птн 00:30:19  886026
1480628644171.gif (59Кб, 221x326)

Хочу стать гуру жса. Посоветуйте литературы. В программировании не новичек, могу в инглиш.
Аноним 02/12/16 Птн 00:32:48  886027
>>886026
А в шапку можешь?
Аноним 02/12/16 Птн 00:45:04  886036
>>886027
Шапку уже читал, и книжек примерно на гигабайт собрал. Поэтому и спросил с чего лучше начинать.
Аноним 02/12/16 Птн 01:59:45  886047
Все, я сам разобрался. Надо выбирать React:

>React JavaScript центричен

>Вот оно. В этом заключается ключевое различие React и Angular. К сожалению, Angular остается HTML ориентированным. Angular 2 не удалось решить наиболее принципиальную проблему архитектуры:

>Angular 2 продолжает помещать JS в HTML. React же помещает HTML в JS

>Я не достаточно выделил этот раскол. Это принципиально влияет на опыт разработки. В Angular HTML ориентированный дизайн остается его слабым местом. Как я и подчеркнул в JSX: The Other Side of the Coin, JavaScript более мощный чем HTML. Гораздо логичнее усиливать возможности JavaScript для поддержки разметки, чем HTML расширять логикой. HTML и JavaScript все равно должны быть как-то склеены и JavaScript ориентированный подход React является несомненным превосходством над Angular, Ember и Knockout c их HTML ориентированным подходом.

>Когда вы учите Angular, вы инвестируете своё время в приобретение знания о внутреннем языке (DSL) Angular. Полученное вам пригодится дальше, если вы будете использовать Angular. Если нет (вспоминаем, как закончилось время первого ангуляра ) — большая часть времени окажется потраченным впустую.

>Когда вы учите React, вы инвестируете свое время в приобретение знания о Javascript — DSL в React практически нет. Полученное знание 100% пригодится вам на дальнейшем пути, даже если React вы использовать не будете.

https://habrahabr.ru/post/274523/

Ну и напоследок:

>Едва выпустив Angular 2, Google анонсировала скорый релиз Angular 3

https://tproger.ru/news/angular-3-is-around-the-corner/

Ебал в рот такие расклады.
Аноним 02/12/16 Птн 03:20:34  886066
>>886047
>Ебал в рот такие расклады.
Они просто сменили версионирование. Как огнелис.
Аноним 02/12/16 Птн 03:22:41  886067
>>886036
Один хуй после половины первой книги забьешь
Аноним 02/12/16 Птн 04:06:26  886076
vue-component.png (118Кб, 829x1009)
>>886047
> Angular 2 продолжает помещать JS в HTML
Не JS в HTML, хотя его, конечно, можно туда помещать, а синтаксические конструкции, которые что-то делают. И это не путает тебя, если ты всё делаешь правильно.
Более явно преимущества такого подхода видно в vuejs. Реакт, в сравнении с ним, во всех смыслах сосёт. Но ебучий маркетинг заставляет людей жрать componentWillReceiveProps
Аноним 02/12/16 Птн 04:45:04  886089
>>886076
> когда вы изучаете реакт, вы инвестируете свое время в js
А что по этому пункту скажешь?
Аноним 02/12/16 Птн 04:47:18  886090
>>886089
Этого я даже не понял. В других фреймворках не на жс пишешь, что ли?
Аноним 02/12/16 Птн 08:35:38  886129
18f9e382.jpg (127Кб, 745x993)
Нужно сделать небольшое приложение, которое парсит содержимое некой страницы в интернете и предоставляет REST-интерфейс, который возвращает это спарсенные данные (в виде JSON).

Вопрос: как реализовать кэширование / сохранение данных, чтобы при каждом запросе к приложению, оно не ходило заново в сеть, не парсило данные, а возвращало имееющиеся? Но, скажем, раз в час оно обновляло данные. Как это проще всего сделать?

Аноним 02/12/16 Птн 09:28:23  886138
>>886129
Листал нулевую, увидел даунский запрос, потом увидел, что это JS-тред, и всё понял.

Как реализовать кэширование? Как обычно его реализовывают. Можешь взять реляционную СУБД и складывать данные в неё. Делаешь колонку с таймшпампом последнего обновления страницы, а каждый раз при запросе проверяешь, как давно твои данные обновлялись, ну а там дальше либо просто отдаешь данные, либо обновляешь и отдаешь.

Также можешь взять Redis. В твоём случае этот вариант, скорее всего, более предпочтителен, потому что ты наверняка полный кретин, а значит, получив в руки реляционную вундервафлю, сделаешь всё через жопу, но если тебе вдруг очень большой объем данных в свой кэш складывать надо и в оперативку это не влезет, то лучше не надо.

И это не говоря уже о том, что можно кэш просто в переменной держать.

мимо-парсер-интернетов
Аноним 02/12/16 Птн 09:41:12  886142
c47f1eb7.jpg (213Кб, 814x894)
>>886138
Там довольно сложная структура данных, поэтому варианта с бд хотелось бы избежать, чтобы не городить кучу таблиц и связей для относительно небольшого приложения.

Поэтому и спросил про кэширование на уровне запроса. Типа, если я запросил данные с param1=aaa, param2=bbb, param3=ccc однажды, то при следующем таком вопросе не было нужды парсить страницу заново (некоторое время). Вот и думаю, как это кэшировать в памяти.
Аноним 02/12/16 Птн 09:46:08  886147
>>886129
object.json.cash
Аноним 02/12/16 Птн 09:55:19  886154
70530da6.png (1372Кб, 1053x1000)
>>886129
>>886142
Возникла такая идея: сохранять всё в файлы .json.
Для запроса с param1=aaa, param2=bbb, param3=ccc создавать файл aaa_bbb_ccc.json и сохранять туда ответ. Работать это будет явно быстрее, чем каждый раз ходить в сеть. Однако наплодит куча файлов... И нужно будет еще придумать, где хранить timestamp. В памяти сделать что-то типа HashMap<String, TIme>?

Как вам вообще идея с файлами? Имеет право на жизнь или хуйня лютая?
Аноним 02/12/16 Птн 09:57:50  886156
>>886142
Я потому и упомянул Redis. Сериализуешь всё и пихаешь в key-value хранилище с таймаутом.
Аноним 02/12/16 Птн 09:59:19  886157
>>886154
> хуйня лютая
Аноним 02/12/16 Птн 10:06:13  886161
>>886076
А как насчет такой хуйни?
>ngIf and ngFor
Аноним 02/12/16 Птн 10:25:02  886170
>>884383 (OP)
сап, где можно бесплатно скачать курс Кантора по node за 2016 или хотя бы за 2015 год? Куча раздач 2013 года, но там скринкаст у него просто на ютубе лежит...
Аноним 02/12/16 Птн 10:31:37  886172
>>886142
кури nginx что ли
Аноним 02/12/16 Птн 11:41:43  886210
>>886142
>Там довольно сложная структура данных, поэтому варианта с бд хотелось бы избежать
kek
Аноним 02/12/16 Птн 13:21:36  886262
скриншнот1.jpg (25Кб, 1247x820)
Не знаю, куда еще обратиться. Сомневаюсь, что тут есть знающие аноны, но всё же буду благодарен, если кто поможет. Начал настраивать API карту для одной штуки и столкнулся вот с такой хренью.
То есть вроде она работает, но этот серый фон не могу понять, какого хуя он появился. Сам апи беру отсюда:
http://leafletjs.com/
То есть всё прописал везде, а серый фон не исчезает. Вот кароче.
Аноним 02/12/16 Птн 14:56:26  886313
>>886142
> сложная структура данных, поэтому варианта с бд хотелось бы избежать
Лол, может тебе про nosql рассказать?
Аноним 02/12/16 Птн 14:58:17  886315
>>886154
> И нужно будет еще придумать, где хранить timestamp.
За щекой
Аноним 02/12/16 Птн 15:02:39  886320
>>886138
попробуй релейт https://github.com/felixge/node-dirty

как вариант, из запроса делай хеш, и юзай его как ключ

если вообще лень что то делать и пофиг на сохранность данных, складывай всё в объект типа map

создай просто перед рутером переменную, она будет хранить все что ты в неё запишешь в колбеках рутера

примерное решение:

var cache = new Map();

app.get('*', (req, res, next) => {

var hash = md5(req.baseUrl)

if (!cache[hash]) {
cache[hash] = {wathever}
}

res.send('ok');

})
Аноним 02/12/16 Птн 15:08:24  886326
>>886320

>как вариант, из запроса делай хеш, и юзай его как ключ
Вот нахуя? Чем урл не подходит в роли ключа?
Или у него что, тот самый случай, типа приватности ради нельзя хранить исходные урлы?
Аноним 02/12/16 Птн 15:09:23  886328
>>886262
Это же фон самой карты, нет?
Аноним 02/12/16 Птн 15:13:01  886332
>>886326

мд5 хеш 32х значный, урл может быть макс 2000 значная и я хз, что там с разными утф8 знаками будет еще, нахуй твои экперементы.
Аноним 02/12/16 Птн 15:22:04  886339
>>886332
>урл может быть макс 2000 значная и я хз, что там с разными утф8 знаками будет еще
Дабы не смущать нубов, которые примут твои слова за языковые ограничения:

>урл может быть макс 2000 значная
Q: Is there a limit on length of the key (string) in JS object?
A: No, there is no limit for the string length (as long as it fits into memory)
http://stackoverflow.com/questions/13367391/is-there-a-limit-on-length-of-the-key-string-in-js-object

>я хз, что там с разными утф8 знаками будет
Q: Are there any forbidden characters in key names, for JavaScript objects or JSON strings? Or characters that need to be escaped?
A: No. Any valid string is a valid key. It can even have " as long as you escape it
http://stackoverflow.com/questions/8676011/illegal-characters-in-object-or-json-key

А так похуй, конечно, пусть хоть в Вирпул хеширует урлы.
Аноним 02/12/16 Птн 15:47:40  886354
Опять нашествие даунов в жс треде. Ничего тут не меняется.
Аноним 02/12/16 Птн 15:48:02  886355
Стикер (0Кб, 512x512)
>>886354
стикер отклеился
Аноним 02/12/16 Птн 15:56:10  886363
>>886354
Это ты так представился? А почему во множественном числе?
Аноним 02/12/16 Птн 16:03:12  886367
3124213123.jpg (57Кб, 625x344)
>>886355
Аноним 02/12/16 Птн 16:05:34  886371
>>886328
Там по гайду должна быть полная карта загрузится. бы дальше настраивать стал, но у меня почему-то серый фон. Хотя, может, я тупой такой.
Аноним 02/12/16 Птн 16:10:23  886378
>>886371
http://stackoverflow.com/a/13852053
Аноним 02/12/16 Птн 20:52:03  886516
>>884735
Вот кстати тайпскрипт и нг2 всем хороши, кроме того, что минимизированные сорцы ангуляра2 весят ~3 мб.
пиздец блять.
А вот в плане концепции ng2+typecript - заебись. Не уверен, что ангуляр2 приживется в вебе. Кстати сайт с доками по ангуляру2 сделан на ангуляр1, то есть даже разрабы ссут использовать своё творение.
Аноним 02/12/16 Птн 21:10:21  886532
>>886516
> Кстати сайт с доками по ангуляру2 сделан на ангуляр1, то есть даже разрабы ссут использовать своё творение.
Очень странный вывод, учитывая, что сайт появился одновременно с началом разработки ангулара2
Аноним 02/12/16 Птн 21:22:28  886542
>>886532
Окей, этого я не знал. Однако учитывая сколько ангуляр2 уже пилится, можно было бы и перенести на новую версию.
Аноним 02/12/16 Птн 21:33:03  886550
Стикер (0Кб, 512x512)
>>886363
>>886367
что еще спезданешь?
Аноним 02/12/16 Птн 22:44:54  886595
Не могу понять главную идею js, изучаю ноду около недели.

Есть Express. Есть таблица в Постгрес. Хочу написать отдельный модуль для общения с таблицей. Получилась следующая заготовка https://ideone.com/nTErcl , она же на пикче.

Как в данном случае совладать с асинхронностью: дождаться события end и вернуть из функции таблицу?


Аноним 02/12/16 Птн 22:45:59  886597
Безымянный.png (14Кб, 579x393)
>>886595
пик отвалился
Аноним 02/12/16 Птн 23:39:35  886628
Посоветуйте фреймворк для работы с cookie. Хочу, чтобы система запоминала данные, которые пользователь вводил в инпут несколько дней назад и когда он вновь зайдет на страницу, чтобы введённые им данные уже были введены в инпут.
Аноним 02/12/16 Птн 23:40:39  886629
>>886597
Promises, motherfucker, do you know it??
Аноним 02/12/16 Птн 23:46:03  886635
>>886595

тебе нужно:

1 в контексте рутера, вызвать метод из модели
2 и в его контексте (через колбэк) рендерить твои хтмл-шаблоны

думай "контекстами"
Аноним 02/12/16 Птн 23:53:01  886636
>>886635
>>886597

добавь lib.all(options, cb);

*

var model = require('model');

app.get('/', (req, res, next) => {

model.all(null, (err, result) => {

if (err) throw (err);

res.send(result.whatever);

});

});
Аноним 03/12/16 Суб 00:03:48  886639
>>886339

я тащемто думал про это:

>Microsoft Internet Explorer: Начиная с четвертой версии браузера, максимальная длина воспринимаемого URL составляет 2,083 символов. При этом длина GET-запроса лимитирована 2,048 символа. На POST никаких ограничений, понятное дело, не накладывается.
Аноним 03/12/16 Суб 00:20:04  886643
Всем доброго времени суток! Недавно начал изучать ангуляр, и сегодня столкнулся с проблемой: не могу обновить $scope:

http://pastebin.com/1pA0Ma28

UserSessionService.SaveData это $http
Аноним 03/12/16 Суб 00:21:30  886644
>>886636
>>886635
Понял в каком направлении двигаться. Тоже думал о подобном решении, но структура показалась слишком непривычной, противоестественной. Вас тут есть за что уважать. Для js после остальных языков нужно все мышление перевернуть. Спасибо!

>>886629
До ES6 пока не добрался. Это действительно способ, которым принято пользоваться в js? Пока не разобрался, но решение должно получиться вполне рабочим. В чем тогда разница между этим вариантом и вариантом описанным выше? кроме ES6 Буду признателен за любые рекомендации.
Аноним 03/12/16 Суб 00:44:06  886655
>>886643
Попробуй добавить $scope.$apply();
после $scope.user.userfio = "Trololo";

Аноним 03/12/16 Суб 00:44:52  886656
>>886655
А еще лучше кинь побольше кода.
Аноним 03/12/16 Суб 01:00:50  886665
>>886655
чо эта блять за доллары?) ангуляр это похапе внутри джеес?
Аноним 03/12/16 Суб 01:01:15  886666
>>886655
В общем, практика показала, что проблема в том, что обновляется только $scope в пределах ng-view, как можно обновить переменную вне ng-view?
Аноним 03/12/16 Суб 01:09:21  886671
>>886665
jQuery тоже "похапе внутри JS"? Perl - похапе внутри чего?
Аноним 03/12/16 Суб 01:11:09  886674
>>886656
Прикрутил Scope напрямую к сервису с данными пользователя. Первый день изучаю ангуляр, и если честно, полный восторг!
Аноним 03/12/16 Суб 01:13:59  886677
>>886674
Круто, но в будущем не забудь открутить, когда освоишься. Скопе в сервисе - не очень хорошая практика.
Аноним 03/12/16 Суб 01:16:42  886681
>>886677
не скоп в сервисе, а сервис в скопе, неправильно сформулировал:

http://pastebin.com/H1pPMwYK
Аноним 03/12/16 Суб 01:17:09  886682
>>886677
Или так тоже фигово делать?
Аноним 03/12/16 Суб 01:24:13  886685
>>886682
Да, фигово. Пока не заморачивайся, но в будущем надо будет.
Рекомендую пройти
https://www.codeschool.com/courses/shaping-up-with-angular-js

Что у тебя промисы в сервисе возвращает? $http, $q, Promise, что-то еще?
Аноним 03/12/16 Суб 01:25:50  886687
>>886685
$http
Аноним 03/12/16 Суб 01:35:27  886690
>>886687
Со scope apply я обосрался.
В твоем случае наверное сейчас самым простым и не ломающим мозг вариантом будет почитать про $rootScope.

Я лично с таким не сталкивался, так как подозреваю ты не совсем красиво пока решаешь свои задачи, но если бы пришлось разбираться, то я бы загуглил
scope outside ng view
Аноним 03/12/16 Суб 01:37:28  886693
>>886665
Внутриангулярные хуитки )))))xDxD
Аноним 03/12/16 Суб 01:56:26  886702
>>886690
да, я сразу попытался $scope.$apply, но он падает с ошибкой, и stackoverflow толсто намекает, что $scope.$apply нужен в том случае, если переменные меняются вне angular, например в jQuery.post. У меня рвет шаблон то, что весь шаблон рендерится со $scope'ом от текущего контроллера, но вот поменять его, ска, можно только в ng-view. А, например, в ng-include уже ни-ни.
Аноним 03/12/16 Суб 02:06:09  886703
>>886702
Скопы могут быть вложенными. А еще можно из скопа ребенка обращаться к скопу родителя (не всегда), по-моему это $scope.$parent.
Пройди какой-нибудь пошаговый туториал и читай доку какую тебе удобно. Не будешь наступать на все возможные грабли.
Аноним 03/12/16 Суб 05:18:44  886750
14741099293470.jpg (134Кб, 1280x803)
>>884383 (OP)
Утречка, форумчане. Собираюсь делать первый свой серьёзный проект на Node.js. Твёрдо настроен сделать не халтурное говно (как обычно), а конфетку, которую я буду использовать в будущем. Но проблема заключается в том, что я не знаю, как правильно начать, как заложить хороший фундамент ? Наслышан о готовых решениях, сборщиках проектов, паттернах проектирования и тд, но не могу понять, что мне действительно нужно и нужно ли вообще ? Что посоветуешь мне ты, анон ?
Проэкт - веб-приложуха на веб-сокетах.
Аноним 03/12/16 Суб 05:21:02  886751
>>886750
Гугли pandas
Аноним 03/12/16 Суб 05:32:48  886754
>>886751
Загуглил. Это скорее относится именно к разработке самой приложухи. А мне же ещё систему авторизации, базу данных и много всего нужно прикрутить. Нужно что-то, что поможет создать нужные файлы, облегчит рутину ...
Аноним 03/12/16 Суб 05:52:11  886757
>>886754
Рутина?
Ну тебе наверное это:
https://www.npmjs.com/package/generator-socketio

С термином скаффолдинг вообще знаком?
Аноним 03/12/16 Суб 09:21:02  886779
>>886754
поищи инфу по разработке энетерпрайз приложения
Аноним 03/12/16 Суб 09:32:51  886785
>>886644
> Для js после остальных языков нужно все мышление перевернуть.
Это раньше так было, сейчас, с приходом async/await, всё очень просто стало
Аноним 03/12/16 Суб 09:52:54  886789
Есть ли какая нибудь очень лёгкая в настройке и работе база данных?
Есть не более 500 маленьких джейсонин, с которыми идёт работа и которые надо сохранять (иначе хватило бы и массива).
Аноним 03/12/16 Суб 10:54:16  886806
>>886789
sqlite
Аноним 03/12/16 Суб 11:13:58  886809
>>886806
Только если хочешь работать с sql,
поищи для себя что-то вроде https://www.npmjs.com/package/node-dbi
.
Вообще любая распространенная бд ставится без проблем по гуглу.
Еще если у тебя готовые json файлики, ты можешь читать (и перезаписывать) напрямую их.

Mongodb будет очень дружественна к твоим json. Можешь вообще их сохранять полностью как таблицы, только в документоориентированных бд это называется другими терминами.
Аноним 03/12/16 Суб 11:55:48  886817
Изучаю JS, прошёл по learnjs до событий. Сейчас наткнулся на хабре на данный пост habrahabr.ru/post/312022/, и как-то приуныл. Действительно ли все это нужно изучать, и это везде требуется? Сложно ли это изучить? А то я и так JS уже месяца 3 учу, а если ещё все эти технологии так же объемны, то я до конца жизни всем этим не овладею, учитывая что они появляются постоянно.
Аноним 03/12/16 Суб 12:07:22  886825
>>886817
Забей, не все так страшно. Всё выучится со временем.
А вообще, в кодинге пиздец везде, в любом языке, любом направлении.
Будешь разгребать моря говна, разбираться почему не работает то что должно и т.д...
Добро пожаловать в реальный мир, сынок.
Аноним 03/12/16 Суб 13:29:58  886858
>>886817
ты 3 месяца над learnjs сидишь? Если да - рекомендую поплотнее заняться. Там все прорешивается вдоль и поперек за 2 спокойно. (но если опыта совсем не было с другими языками, тогда может и норм побольше потратить) После него еще надо будет всякие нюансики почитать и приступать к сборщикам, фреймворкам, библиотекам, ноде и т.д.

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

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

Решать конечно тебе, так что хорошо подумай.
Если решился - значит делай, превозмагай если потребуется.
Если нет - значит лучше найди чем другим заняться, может в тебе талантливый музыкант спит или врач или сантехник или владелец уютного кафетерия с вкусными булочками.
Аноним 03/12/16 Суб 13:53:23  886881
Стикер (0Кб, 512x512)
>>884383 (OP)
Допишите в ОП посте, что всем кто боится новых версий ангуляра, огромного количества технологий - лучше выбрать другой язык и другую отрасль информатики. Есть питон, java, haskell - там все гораздо проще и нет частых обновлений.
хотя эти дауны все равно шапку не читают, таких просто игнорировать
Аноним 03/12/16 Суб 13:55:38  886882
Или как советуют анон выше>>886858 заняться чем-то другим.
Аноним 03/12/16 Суб 14:29:30  886907
Стикер (0Кб, 512x512)
Как использовать PassportJS БЕЗ форм? Надо просто передать туда данные как аргументы.

logIn(data) {
let username = data.username, password = data.password;

passport.authenticate('local', { successRedirect: '/', failureRedirect: '/login' })

passport.authenticate(// ???)

},
Аноним 03/12/16 Суб 15:09:32  886942
>>886907
Читай доки, педор
http://passportjs.org/docs#log-in
Аноним 03/12/16 Суб 15:24:16  886954
>>886089
typescript - это зык-надстройка Javascript. Как следствие, он [bold]КОМПИЛИРУЕТСЯ[/bold] в javascript. Изучая angular, соответственно, ты изучаешь тотже жс, только с измененным синтаксисом. Это как CoffeeScript , если ты знаком с этим
Аноним 03/12/16 Суб 15:26:24  886957
>>886161
> синтаксические конструкции
Это ведь они и есть
Аноним 03/12/16 Суб 15:27:32  886958
>>886825
>>886858
Спасибо аноны. Работаю просто сейчас по 5 дней, после работы остается по 2-3 часа. Да и прям плотно трачу эти часы на программирование только в последний месяц. Планирую в будущем, когда появится возможность, перейти на незапарную работу дня по 3 в неделю и целиком окунуться в программирование.

Алсо, читаю параллельно SICP, с виду язык scheme кажется более красивым и "стройным". Но, не уверен в актуальности лиспа, да и предвижу, что это красота есть только в учебных задачах, а в реальности куча подводных камней. Поэтому продолжаю изучать JS из-за популярности и больших возможностей этого языка.
Аноним 03/12/16 Суб 15:30:51  886960
>>886942
и что с этим говном делать? как туда передать логин и паруль?
Аноним 03/12/16 Суб 15:32:55  886961
>>886960
let user = { username: data.username, password: data.password }
Аноним 03/12/16 Суб 15:47:48  886981
>>886961
А как получить обратно из БД юзер-дата? Там помимо юзера ещё данные которые нушны.

app.post('/login', (req, res) => {
const { user } = req.body;

req.login(user, err => {
if (err) { return err; }

db.logIn().then(() => {
res.redirect('/loginsucsess')
});
});
});

logIn() {
passport.authenticate('local', { successRedirect: '/', failureRedirect: '/login' })
},
Аноним 03/12/16 Суб 15:49:19  886983
>>886981
там в слове success ошибка, не пинайте
Аноним 03/12/16 Суб 15:52:41  886985
>>886981
>>886983
Ты вообще понимаешь зачем ты пасспорт юзнаешь? Он сам эти данные достаёт при каждом запросе и кладет их в req.user
Аноним 03/12/16 Суб 15:55:41  886987
>>886985
Юзаю passport чтобы сохранить сессию и соответственно постить контент от лица юзера. Зачем же его ещё юзать?
Аноним 03/12/16 Суб 15:57:54  886990
>>886987
За сессию отвечает express-session, а passport нужен для аутентификации
Аноним 03/12/16 Суб 15:59:48  886991
>>886990
Зачем express-session если можно сделать app.use(passport.session());
Аноним 03/12/16 Суб 16:08:00  886995
>>886991
> если можно сделать app.use(passport.session());
Который использует express-session, да. И служит для аутентификации, а не для сессий.
Аноним 03/12/16 Суб 16:18:00  887004
>>886995
Passport exposes a login() function on req (also aliased as logIn()) that can be used to establish a login session.

А это что? Написано же - сессия.
Аноним 03/12/16 Суб 16:19:59  887006
>>887004
И что же происходит при этом establish, не расскажешь?
Аноним 03/12/16 Суб 16:26:10  887011
>>887006
Понятия не имею. Если копаться в каждом из 40 модулей, можно и ёбнуться. Но думаю что судя по описанию, устанавливается сессия.
Аноним 03/12/16 Суб 16:30:05  887013
>>887011
> Если копаться в каждом из 40 модулей, можно и ёбнуться
А если не копаться, то можно использовать какой-то модуль, потому что все его использовать и не знать вообще зачем он тебе нужен, и нужен ли вообще. Как это делаешь ты
Аноним 03/12/16 Суб 16:57:04  887032
>>887013
Я просто хотел получить данные юзера.
Аноним 03/12/16 Суб 19:40:01  887138
>>884383 (OP)
Анон, а как именно ты используешь Ангуляр ?
А то я вот почитал описание в интернете и так и не понял, нахуя он вообще нужен ?
Аноним 03/12/16 Суб 19:48:32  887145
>>887138
https://gist.github.com/kentcdodds/6789009
Аноним 03/12/16 Суб 19:53:07  887146
>>887138
Задай себе этот вопрос, когда будешь прикручивать на свой сайтик поверх jquery шаблонизатор, чтобы облегчить биндинг данных и вообще работу с html. А еще когда ты возьмешься пилить сайтик с достаточно сложной логикой и будешь охуевать от той лапши, которую ты напилил и которую надо поддерживать. Это в принципе не конкретно об ангуляре, а в целом о фреймворках.

Для простых веб задач ангуляр не нужен. Для сложных - может помочь упростить разработку сейчас, и поддержку в будущем.
Аноним 03/12/16 Суб 20:05:32  887152
Привет, анон.
Расскажи, в чём отличие по работе front-end у джуна и мида?
Вот приходит джун и приходит мид на работу - какие задачи они будут делать? Что - привелегия джуна, а что - для джуна уже перебор?

Ваять роуты на ангуляре с таблицами по ui-grids и стилизовывать это всё sass'ом - это кто?
Аноним 03/12/16 Суб 20:32:57  887176
14656636932050.png (4734Кб, 3264x1840)
>>887146
А как именно ? Что вообще он делает, если вкратце ?
Вот например JQuery:
- Подключаешь через ссылку прямо в документе.
- Помогает удобно искать и изменять элементы на странице
- Удобно работает с событиями
- Можно днлать анимации
А вот можно ли в подобном роде датя описание Ангуляру ?
А то опять таки, на Википедии тоже написано что облегчает разработку одностраничных веб-приложений, но не совсем понятно каким образом ...
Аноним 03/12/16 Суб 21:10:48  887204
>>887176
Если в кратце, всякую работу с dom может и ангуляр. Про дата биндинг тебе антоша сверху кинул ссылку. Ты не будешь по селектору искать элемент, брать его значения, вешать обработчики для событий, чтобы менять элемент - в ангуляре это делается значительно проще.
В ангуляре события есть, но они немного другие.
По-хорошему ангуляр приложения нужно писать, придерживаясь определенных правил, тогда у тебя код будет аккуратно структурирован и с ним удобно будет работать - то есть работа с бизнес-логикой в одном месте, работа с DOM - в другом месте и т.д.. Если будешь писать приложуху на jQuery, то возможно ты тоже захочешь структурировать свой код и в итоге все равно напишешь свое подобие ангуляра, но только скорее всего не без боли.
Вот я тебе маленькую простыню текста написал, но смотри:
если ты предложишь писать сложное веб приложение на jQuery, то на тебя посмотрят как на поехавшего. Даже если ты не хочешь, какой-то из фреймворков тебе все равно придется изучить, чтобы расти как веб деву.
Кстати на некоторых проектах Angular и jQuery используются вместе.
Аноним 03/12/16 Суб 21:17:44  887210
14522928856440.jpg (107Кб, 750x1000)
>>887204
О. от это отличньо рассписано. Спасибо Антош. теперь я окончательно сё понял.
Аноним 03/12/16 Суб 21:20:59  887216
>>887210
Пожалуйста. скажи имя няши с первого пика.
Аноним 03/12/16 Суб 22:14:23  887262
>>887152
Но ведь обилием "кульных терминов роуты юи юи)))" не заполнишь пустоту в голове.
Когда ты будешь миддлом, тебе сами предложат эту позицию.
Аноним 04/12/16 Вск 00:03:20  887321
whatschoolsteach.jpg (163Кб, 462x451)
>>887176
>>884383 (OP)

тоже хочу обновить свой технолоджи стек, сейчас смотрю релейт

1. Bootstrap components written in pure AngularJS https://angular-ui.github.io/bootstrap/

1.1. Bootstrap 4 components, powered by Angular 2 https://ng-bootstrap.github.io/#/home

2. The most popular front-end framework, rebuilt for React http://react-bootstrap.github.io/

пока не могу сделать выбор

в идеале хотелось бы рендерить DOM бутстрапа на node.js и на клиентах

может кто знает такие проекты, поделитесь с Анонам
Аноним 04/12/16 Вск 03:22:20  887403
Помоги разобраться, Анон. Я знаю для тебя это не составит труда. Код должен выводит натуральные числа, но при таком варианте работает не корректно http://plnkr.co/edit/YE2bsBCTGtdTHaOkHkpe?p=info, а вот при таком все норм http://plnkr.co/edit/jolZ2RF7nbe7TTa4OGNe?p=catalogue . Мне кажется что и первый вариант должен адекватно работать, но почему это не так не могу разобраться?
Аноним 04/12/16 Вск 06:59:21  887420
>>887403
у тебя у первой проверке цикла 2<2
Аноним 04/12/16 Вск 09:49:49  887435
>>887403
У тебя вывод числа в консоль для каждого i происходит по несколько раз. Например при i = 5 выводится в консоль при j = 2, j = 3, j = 4.
Аноним 04/12/16 Вск 12:43:08  887494
>>887321
Что ты подразумеваешь под " рендерить DOM бутстрапа на node.js"
Впервые с такой формулировкой сталкиваюсь.
Аноним 04/12/16 Вск 13:05:36  887502
>>887494

что бы на сервере HTML (например бутсрап) имел свой виртуальный DOM

типо:

var bsWgts = require('bootstrap-templates');

app.get('/', () => {

res.send(bsWgts.panel({

title : 'Demo',
body : 'Ахуенный текст '
}));


});
Аноним 04/12/16 Вск 13:19:33  887512
>>887494

в ЖС есть по умолчанию релейт http://www.w3schools.com/js/js_htmldom_nodes.asp

было бы архи норм, найти HTML бутстрапа написанный в таком формате
Аноним 04/12/16 Вск 13:23:48  887518
>>887502
Но ведь... Шаблонизаторы, контекст...
Аноним 04/12/16 Вск 13:32:43  887531
>>887512
>>887502
>>887494

вроде оно https://www.npmjs.com/package/node-bootstrap-html
Аноним 04/12/16 Вск 13:39:54  887543
>>887518

да, но тебе нужно писать шаблоны на HTML самому, имхо это лишнее
Аноним 04/12/16 Вск 13:46:26  887548
>>887531
>>887512

похоже вот оно https://github.com/yuche/vue-strap
Аноним 04/12/16 Вск 13:48:20  887550
>>887543
Ну допустим. А если тебе надо кастомизировавать бутстрпавый аккордеон? Все равно же в итоге перепишешь на рендеринг шаблона.

Подскажи мне use case, когда можно использовать рендеринг html непосредственно в скрипте. Может быть тоже буду использовать.
Аноним 04/12/16 Вск 14:13:09  887587
mvc.png (37Кб, 727x536)
>>887550

у меня сейчас такая структура

и я понял, что там templates лишнее звено, так как в pages/my-pages есть videochat.page.view.js

в котором из шаблонов собирается страница

шаблоны туда поставляются в виде объектов из views/templates/templates.api.js
Аноним 04/12/16 Вск 14:16:14  887590
>>887587

*ветка /page старая, она не используется и будет удалена. вместо неё будут /pages
Аноним 04/12/16 Вск 14:25:50  887607
>>887587
>templates лишнее звено

лишнее в плане, что мне нужно будет там делать шаблоны для компонентов бутсрапа. так то полюбому эта ветка нужна, так как в ней будут шаблоны того же <html> документа и другие стандартные вещи. проблема в бутстрапе, не охота велосипедить для него АПИ
Аноним 04/12/16 Вск 14:39:26  887641
BracketsIDE.jpg (35Кб, 800x350)
>>884383 (OP)
Перестал работать автокомплит в js, да и вообще. Куда копать? Переустанавливать пробовал, пересобирать пробовал, без толку. Сижу на archlinux, если что.
Аноним 04/12/16 Вск 14:40:03  887642
>>887587
У тебя во вьюхах и бизнес-логика, и логика рендеринга?
Аноним 04/12/16 Вск 14:44:00  887646
>>887642
>логика рендеринга

only this.

в них только "оборачиваются" данные с /model

логика представлена в модели. и частично в рутере
Аноним 04/12/16 Вск 14:45:54  887652
ахуеть, правильно ли я понимаю, что гит не пушит пустые папки? Какие у него еще подводные камни?
Аноним 04/12/16 Вск 14:47:21  887658
>>887652
Правильно
Аноним 04/12/16 Вск 14:48:00  887661
>>887652
Делай пустой файл в папке.
обычно делают .gitkeep
Аноним 04/12/16 Вск 14:49:58  887664
>>887652

да, делай в такой папке файл .gitkeep
Аноним 04/12/16 Вск 14:52:39  887667
>>887641
> Куда копать

stackoverflow?
Аноним 04/12/16 Вск 14:53:59  887670
>>887667
Я хуйло и не умею в инглиш((
Аноним 04/12/16 Вск 14:57:14  887677
>>887646
>>887587

>pages/my-pages есть videochat.page.view.js
>в котором из шаблонов собирается страница

Обычно такое переносят в шаблонизатор.

Мне твоя архитектура не внушает доверия. Не выглядит такой, чтобы легко было работать.

Это коммерческий проект или твой учебный? Кто-то код смотрел, что говорили?
Аноним 04/12/16 Вск 14:58:54  887680
>>887670

пипец проблема https://translate.google.de/
Аноним 04/12/16 Вск 15:09:08  887695
>>887677

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

в данном виде паттерн приложения работает как часы. меня просто смутило, что для компонентов бутстрапа нужно будет что-то велосипедить

>Обычно такое переносят в шаблонизатор.

"шаблонизатор" как раз и представлен модулем /templates, не?

есть еще такой момент, приложение работает на sockets, тут я пока тру не решил куда поместить их логику, думаю в /router
Аноним 04/12/16 Вск 15:11:34  887700
LzVoyaO.png (59Кб, 2560x1440)
>>887641
Проиграл. Вангую, что автокомплит пропал после очередного "пакман суй".
Аноним 04/12/16 Вск 15:11:42  887701
>>887695
>модулем /views/templates
>fix
Аноним 04/12/16 Вск 15:18:27  887715
>>887695
Я имел в виду, что сборка шаблона из партиалов, наследование шаблонов пишется непосредственно в шаблонах.
Аноним 04/12/16 Вск 15:18:55  887716
>>887715
*И разруливается шаблонизатором
Аноним 04/12/16 Вск 15:26:59  887725
sub-js-thread-0[...].gif (76Кб, 202x102)
лол, вся суть ЖС одним логотипом
Аноним 04/12/16 Вск 15:41:36  887739
>>887695
На серверном js вроде же работает правило one feature - one file ?
В роутах у тебя для сокетов событие и хендлер, но сама реализация хендлера лежит отдельно. Ну да, наверное я бы и сам так делал, если бы кодил под ноду, только еще бы в имени файла обязательно обозначил, что это роуты под сокеты.
Аноним 04/12/16 Вск 15:43:36  887741
build.png (79Кб, 1076x653)
>>887715
>>887716

ок, в моём паттерне шаблонизатор представленный модулем /views/templates/templates.api.js предоставляет шаблоны партиалов в виде объектов (например каркас ХТМЛ дока и прочие элементы) из которых в модуле /pages/my-pages/<whatever>/<whatever>.page.view.js собирается всё что угодно и как угодно.

сборка страниц происходит как на пике.

инб4: это одно из 100 возможных решений, я не на что не претендую.
Аноним 04/12/16 Вск 15:58:26  887747
>>887741
Я понял тебя. Я бы конечно так не делал, так как попахивает велосепидизмом с легкой формой мазохизма, но если работает и устраивает как заказчика, так и программиста лол, то почему бы и нет. Если вдруг надо будет, перепишешь.
Аноним 04/12/16 Вск 16:01:08  887750
>>887747
* актуально для сложных вьюх.
для простых, вроде пика скрин выглядит цивильно
Аноним 04/12/16 Вск 16:15:25  887754
>>885891
angular 2
Аноним 04/12/16 Вск 16:29:58  887760
>>887739

ок, получилась такая структура

/router/router.http.js

/router/router.sockets.js

>реализация хендлера

я думаю в router.sockets.js поместить события и в них же логику, типо:

whatever.events.on('event one', (socket) => {
socket.emit('test1', { hello: '1' });
});

whatever.events.on('event two', (socket) => {
socket.emit('test2', { hello: '2' });
});

анонимные функции в примере, это же вроде и есть хендлеры?

>one feature - one file

хм, я думаю в отдельные файлы пилить логику для router.http или router.sockets, вроде и так уже норм разделение?

Аноним 04/12/16 Вск 16:41:57  887770
>>887760
Да, верно. Анонимные функции - хендлеры.

Когда-нибудь твой router.sockets может стать 2к+ строчек кода. Если вдруг ты наймешь фрилансера помогать тебе писать проект, он будет тебя материть, уверен.

Вообще, почему ты не захотел следовать MVC? Есть даже уже готовые структуры node express проектов - пользуйся не хочу.
Аноним 04/12/16 Вск 16:48:35  887772
>>887747
>велосепидизм

да тут сложно, меня этот паттерн устраивает 10/10.

меня смущает всего один момент, что для бутсрапа нет готового абстрактного класса, и мне его придётся возможно велосипедить.

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

предложи другой вариант для клиентского UI уровня бутсрапа, как насчет ангуляра и реакта, у них есть готовые компоненты и сетка, которая еще и мобайл фирст?
Аноним 04/12/16 Вск 16:51:01  887774
>>887770
>Если вдруг ты наймешь фрилансера помогать тебе писать проект, он будет тебя материть, уверен

готов поспорить с тобой тут. если использовать инструмент IDE с инструментом outline, то весь код у тебя как на ладони, будь он хоть 100к строчек
Аноним 04/12/16 Вск 16:51:30  887776
>>887774
>использовать IDE с инструментом outline
>fix
Аноним 04/12/16 Вск 17:00:54  887784
>>887770
>Вообще, почему ты не захотел следовать MVC

лол так это MVC же и есть, просто дополненный, типо MVC-Х

Аноним 04/12/16 Вск 17:03:20  887785
>>887772

>меня смущает всего один момент, что для бутсрапа нет готового абстрактного класса, и мне его придётся возможно велосипедить.

Вот и говорю - мазохизм и велосипеды. Усложняешь вещи, которые можно было бы делать проще.


IDE - шка может начать страдать от слишком больших файлов, но больше - программист. Даже с outline. Еще на репозитории в онлайн режиме сложнее будет с такими сорцами взаимодействовать.

>>887784
Зачем тогда роуты контроллерами сделал?
Аноним 04/12/16 Вск 17:07:02  887788
Сеточка - ну... skeleton, foundation,
sass+susy...

На ангуляр уже куча всякого дерьма накопилась на любой вкус, про реакт не знаю.
Аноним 04/12/16 Вск 17:25:59  887797
router.png (114Кб, 876x883)
>>887785
>Усложняешь вещи, которые можно было бы делать проще

ок, я заинтригован, решение в студию

>IDE - шка может начать страдать от слишком больших файлов, но больше - программист

хм х/з что там у тебя за IDE такая в 2016, я пишу в eclipse neon с этим плагином https://marketplace.eclipse.org/content/tern-eclipse-ide

всё летает.

насчет страданий программиста х/з, возможно дерево файлов с четкими именами наглядней. ок возможно ты тут прав, я подумаю над этим

>Зачем тогда роуты контроллерами сделал?

всё немного иначе чем ты думаешь

в app.js всего 2ве строки

// Other routes

const $router = require('./router/router.http')

httpApp.all('*', $router.api)

в рутере происходит что на пике

как таковой контроллер находится в /views/views.controller.js

он как раз на основе path выбирает какую подгрузить страницу из /views/pages/

Аноним 04/12/16 Вск 17:36:45  887802
Почему запрос ничего не шлёт обратно? res.send не работает, на клиенте пусто. Ошибки не выскакивают.

app.post('/login', (req, res, next) => {

console.log(JSON.stringify(data)) // Обьект с данными
db.logIn(req, res, next).then(data => res.send(JSON.stringify(data)) );

});


logIn(req, res, next) {

return User
.findOne({ username: req.body.username })
.then((user) => {
if (user.password == req.body.password) {
console.log('Password is OK');
req.session.user = {
id: user._id,
username: user.username,
color: user.color
}
return Promise.resolve(req.session.user)
} else {
return Promise.reject('Password is wrong')
}
})
.catch((err) => {
return next(err)
})

},
Аноним 04/12/16 Вск 17:43:45  887807
>>887802
p.s. console.log(JSON.stringify(data)) на самом деле внутри .then перед res.send
Аноним 04/12/16 Вск 17:50:24  887812
>>887802

http://stackoverflow.com/a/35034963
Аноним 04/12/16 Вск 17:57:01  887819
>>887797
Честно, не знаю зачем тебе нужен абстрактный бутстрап класс, но сам факт того, что тебе понадобился подобный класс уже вызывает вопросы.

Я предлагаю не рулить бутстрапом нигде, кроме непосредственно шаблона. В контексте твоего сервера, если я правильно его понимаю, ты не используешь объекты на базе твоего абстрактного бутстрап класса, но можешь подключать бутстрап партиал компоненты вида acordeon.partial.htm там где нужно.

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

Еще те же самые бутстрап компоненты требуют не только хтмл, но и скрипты. Компоненты может потребоваться конфигурировать на клиентских скриптах. Как ты будешь это разруливать?

Для использования ангуляров, реактов и прочего тебе нужно будет пересмотреть свою архитектуру в пользу переделки сервера в апишку.
Аноним 04/12/16 Вск 18:21:12  887833
Стикер (0Кб, 512x512)
>>887812
Пиздец, я ебал мозги этим три дня, и в итоге оказалось что промис выбрасывает данные только в переменную с тем же именем что и входная. Поистине надо обладать баттхертоустойчивым пердаком чтобы с этим совладать.
Аноним 04/12/16 Вск 18:41:42  887857
>>887819

>зачем тебе нужен абстрактный бутстрап класс

всё просто

1. на строне сервера для доставки определенных шаблонов в /views/pages/
2. для доставки всех элементов бутстрапа на сторону клиента в скрытый элемент на странице <div class="hide js-bs-templates"></div>

2й пунк, для того, что бы я потом селектором jquery мог брать оттуда готовые, отрендеренные клиентом виджеты, и вставлять их в рандомные места странницы

например:

var _bs = $('div.js-html-templates');

var button = _bs.find('div.button').clone();

$('body').append(button.html('Кнопка #1'));

$('body').append(button.html('Кнопка #2'));

таки это всё работает без всяких реактов и ангуляров. клиент рендерит тебе готовые виджеты с CSS и прочими фичами, ты их лишь клонируешь и меняешь их html
Аноним 04/12/16 Вск 18:55:02  887876
freyd38227511or[...].jpeg (62Кб, 450x638)
>>887857

*и внезапно, мы опять же приходим в итоге к MVC паттерну, но уже на строне клиента

<div class="hide js-bs-templates"></div> - представляет Views

var _bs = $('div.js-html-templates'); представляет Controller

моделью в этом концепте будут либо данные с сервера, либо твои данные, которые ты обернёшь в туже кнопку например в виде её innerHTML.
Аноним 04/12/16 Вск 19:03:53  887882
>>887876
>var _bs = $('div.js-bs-templates')
>fix
Аноним 04/12/16 Вск 19:08:28  887887
>>887857
Зачем доставлять на сторону клиента все элементы бутстрапа, даже не нужные на текущей странице? Каких целей ты хочешь этим добиться?
Аноним 04/12/16 Вск 19:16:07  887896
>>887887

ООП же
Аноним 04/12/16 Вск 19:21:58  887899
>>887896
Ладно, чувак. Удачи тебе с проектом, желаю чтоб выстрелил. Подумаю над твоей реализацией всего, может что-то для себя найду полезное.
Аноним 04/12/16 Вск 19:30:30  887909
>>887887
>>887896

You wanted a banana but you got a gorilla holding the banana

>>887899

пасибо Анон, добра тебе

если интересно/нужно, технология проекта https://en.wikipedia.org/wiki/WebRTC

фреймворк с кучей примеров и ахуенной документацией https://github.com/priologic/easyrtc

Аноним 04/12/16 Вск 19:36:38  887916
>>887909
>WebRTC

да, кста, учите новый термин Антохи: "servent" https://en.wiktionary.org/wiki/servent

ну и на засыпку, подумайте на досуге, как эта технология через пару лет изменит Мир
Аноним 04/12/16 Вск 19:51:29  887924
>>887916
> пару лет
Ты как будто первый день родился.
Через пару лет уже этот новый, модный, молодежный термин устареет пару раз, будут совершенно новые концепции (которые, разумеется, потребуют все переписать с нуля).
Аноним 04/12/16 Вск 19:59:47  887929
>>887916
Скорее всего понятие "браузер" довольно узко отражает всё что можно делать с помощью такого клиента. Может быть будет какой то универсальный "клиент" - все ММО игры будут работать через него, вся информация будет течь peer-to-peer как электрические импульсы между нейронами. Только здесь встаёт вопрос о том что такое говноподелие как JS в нынешнем виде при этом использовать просто идиотская идея. Нужен WebAssembly в который будет копилироваться какой то новый JS2.0 возможно с похожим синтаксисом но без всех этих багов вроде typeof null и без пяти вариантов "как сделать одно и тоже действие". Но одно можно сказать почти с уверенностью - если и будут разрабатываться интерфейсы для дополненной реальности, скорее всего они будут на языке который будет иметь похожий синтаксис и логику.
Аноним 04/12/16 Вск 20:01:08  887930
Почему в тестах querySelector и querySelectorAll работают значительно медленнее, чем getElementsByTagName, getElementById и getElementsByClassName?
https://jsperf.com/element-id
https://jsperf.com/taganame
https://jsperf.com/classnamespeed-test
https://jsperf.com/idtagname-speed
https://jsperf.com/queryselectorall-radio-checkbox-test
Аноним 04/12/16 Вск 20:38:33  887950
>>887924

имхо ВР на подходе, технология webRtc норм подходит для неё. думаю что всё будет штабильно

>>887929

>Только здесь встаёт вопрос о том что такое говноподелие как JS в нынешнем виде при этом использовать просто идиотская идея

х/з, после пыха конечно первое время было непривычно работать с ЖС, но теперь у меня нооборот чувство, что ЖС как раз работает так и нужно тру языку.

>без пяти вариантов "как сделать одно и тоже действие"

имхо в целом если ты можешь различать {} и [] тебе должно быть похуй на синтакс и язык как таковой.

кста значек для срелочных функций тоже имхо в ЖС удачно выбрали: () => {} красота имхо 10/10 просто

>WebAssembly

вроде ключевые модули ноды написанны на си. имхо даже если внедрят этот твой WebAssembly, ты всёравно будешь работать сним в лексической среде через обёртку языка ЖС

>typeof null

старо как мир, вроде это не критично

>If null is a primitive, why does typeof(null) return "object"?
>Because the spec says so.
>http://stackoverflow.com/a/18808252
Аноним 04/12/16 Вск 20:39:47  887952
>>887950
>наоборот
>fix
Аноним 04/12/16 Вск 21:00:44  887960
>>887929
>синтакс жс хрень

меня другое кста смущает в ЖС, конкретно в ноде.

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

и что тогда получается, если моё приложение юзает вебсокеты, то как я скалирую его в облаке, на скажем 12 ядер и 24 гб памяти?

кластер создать как я понял не проблема, проблема, что у каждого процесса ноды будет своё пространство имён, и в каждом таком пространстве будет свой объект с активными сокетами, если это так, как тогда сможет рандомный зокет из процесса #1 связаться с рандомным зокетом, к примеру из процесса #8 или #10? втф.
Аноним 04/12/16 Вск 21:15:32  887971
>>887950
> Вроде ключевые модули ноды написанны на си
Перепишут хули. А инвесторы найдутся если это дело под дополненную реальность перепрофилировывать. Ещё Головайчук как то ныл в одном посте мол нода defected by design. К тому же три модульных системы это не найс.
Аноним 04/12/16 Вск 21:18:20  887972
>>887960

ок, загуглил, как я и думал, нужна будет in memory DB, которая будет типо мостом между нодами http://socket.io/docs/using-multiple-nodes/#passing-events-between-nodes

всё просто вроде
Аноним 04/12/16 Вск 21:46:53  887986
>>887971
>три модульных системы

что за системы?

Аноним 04/12/16 Вск 22:01:50  888001
Бамп вопросу >>887152
Аноним 04/12/16 Вск 22:02:00  888003
switch в get-роутах не слишком bad practice?
Аноним 04/12/16 Вск 22:04:57  888006
>>888001
Взять роуты, положить роуты, это всё любой должен уметь. Характеристика довольно размытая, думаю миддл - это способность сделать сложный проект одному, а сеньор уже может комбинировать языки, писать какой нибудь бэкенд на питоне.
Аноним 04/12/16 Вск 22:32:24  888037
>>888006
> комбинировать языки, писать какой нибудь бэкенд
То есть я, ныне мид-фрондендер, пришедший из JavaEE-бэкэнда (и пилил раньше фуллстек на дофига килострок в одиночку) - по твоему, синьор-помидор?
Аноним 04/12/16 Вск 22:38:42  888043
>>888037
я мимокрокодил, если что
Аноним 04/12/16 Вск 22:42:06  888045
>>888037
Лол, так я не один такой бекендер-перекатывальщик?
Тебе не говорили что-то вроде переходить на фронт - плохая идея, 90% процентов работы - пофиксить кнопочку и т.д. ?
Как вообще, о решении не жалеешь?
Аноним 04/12/16 Вск 22:46:37  888048
>>888006
Одному? Ничего не путаешь?
Сейчас, например, вдвоём с сеньором пилю проект: срок 25 дней (5 общались с заказчиком, делали акки у них в системе, определялись с технологиями, поднимали вебпак и т.п.), на фронте angular, sass, bootstrap.
Система управления хостингом с админкой и отображением статуса серверов. Это рили работа на двоих на 20 дней?
При том, что меня вообще pre-джуном взяли на $100 на этот месяц без какого-то оформления - тип стажировка, ещё и свой ноут взять пришлось, т.к. у них компа для меня не было. При этом компания нормальная, реально много филиалов в разных городах и странах, на кидалово не тянет. Странно.
Аноним 04/12/16 Вск 22:49:57  888050
>>888045
Ну, как сказать, фронтенд более "интерактивный" что ли. Поэтому меня он больше цеплял, когда я фуллстеком занимался. Джава-тырпрайз наскучил, захотелось перемен, тем более зарплату больше предложили. Пока не жалею. Сейчас на фронтенде бурный рост (новые плюхи как грибы появляются), не заскучаешь.
Аноним 04/12/16 Вск 23:16:48  888062
>>888048
Нет, не путаю. Речь идёт о том что миддл может гипотетически сделать проект, не бегая каждый день и не спрашивая советы у сеньора-помидора.
Аноним 04/12/16 Вск 23:20:42  888066
>>888048
100$ за месяц? Совсем долбоёб? Помоему тебя просто наебали как лоха. Я бы даже интернет магазин не стал делать дешевле чем за 500$. Ну а то что ты описал, наверное, вполне можно поднять иза 20 дней, за соответствующую объёму работы сумму.
Аноним 04/12/16 Вск 23:21:39  888069
>>888006
Ты так говоришь, будто я сеньор, ведь я все это умею. Но только хуй, я не сеньор.
Аноним 04/12/16 Вск 23:22:54  888070
>>888037
Если ты будешь использовать этот стек в работе, то тебя можно назвать синьором. Но основным критерием всё же остаётся уровень зарплаты, как минимум она должна быть у тебя не меньше 3000$.
Аноним 04/12/16 Вск 23:24:26  888072
>>888069
Опиши свои навыки.
Аноним 04/12/16 Вск 23:27:55  888077
>>888066
Я хер знает, до этого в одной компашке работал, там $350 платили, но не сработался со старшим, который хер клал на линты, стиль кода и мозг трахал, что я пишу не как он (при том, что там eslint весь красный был).
Так в том и дело, что я из-за отсутствия особого опыта пока не понимаю, что происходит. Меня предупредили, что я для заказчика - мид, а напарник - сеньор (я так понял, его с мида "подняли"). Не особо понял смысла этой махинации, правда, если меня берут типо на джуна-если-хорошо-себя-покажешь и вообще я в любой момент могу тупо не прийти на работу, меня ж ничего не связывает.
Алсо ещё тестировщица нас подбодрить решила - типо проект хорошие инвестиции собрал. Поправьте, но мне не похер? Я же доли в нём не получу, а какая мне разница, что я пилю, если мой результат - 100 баксов в карман?
Аноним 04/12/16 Вск 23:28:35  888080
>>888070
Толсто. Работаю за $1200
Аноним 04/12/16 Вск 23:36:07  888085
>>888080
Что толстого то? Поэтому то ты и не синьор.
Аноним 04/12/16 Вск 23:38:36  888088
>>888070
Сэр, у вас жир потек.
ЗП никак не критерий "синьерности", а одно из следствий. Не знаю, как в других, но в моей галере одним из важнейших критериев для вердикта о результате ассесмента на сеньора - навыки общения, умение вести команду, принимать решения и т.п.
Аноним 04/12/16 Вск 23:44:56  888092
>>887950
> ключевые модули ноды написанны на си
++
Аноним 05/12/16 Пнд 00:36:28  888121
b4782966.png (51Кб, 266x200)
>>888092
>>887929

сейчас гуглил за WebAssembly

вроде как скоро нода будет работать в этой среде по умолчанию https://github.com/nodejs/node/issues/7925



пик рандом
Аноним 05/12/16 Пнд 06:15:48  888213
9ceddef7fb3d346[...].jpg (67Кб, 645x603)
Подскажите пожалуйста, что я делаю не так?
http://pastebin.com/Ky9AG4D2

Функция должна выполнить сетевой запрос, извлечь из него данные и возвратить массив элементов.

Я всегда получаю пустой массив, но в консоли элементы логгируются нормально.
Подозреваю, что что-то не так с точки зрения асинхронного кода. Как исправить?
Аноним 05/12/16 Пнд 07:13:33  888229
>>888213
>Подозреваю, что что-то не так с точки зрения асинхронного кода.
Все правильно подозреваешь.
>Как исправить?
Использовать коллбеки (плохо) или резовлить промисы (лучше).
Аноним 05/12/16 Пнд 11:55:10  888292
Снимок.PNG (14Кб, 990x170)
Очень говнокод или норм?
Аноним 05/12/16 Пнд 12:37:36  888316
>>888292
Да.
Аноним 05/12/16 Пнд 14:16:38  888404
>>888316
Что значит твоё "Да"? Что говнокод это норма?
Аноним 05/12/16 Пнд 14:22:17  888412
Кто-нибудь пробовал к Backbone реакт прикручивать? Какие успехи, результат того стоит?
Аноним 05/12/16 Пнд 15:54:49  888464
>>888412
Троллейбус_из_хлеба.жпг
Аноним 05/12/16 Пнд 16:16:21  888482
У меня такой вопрос, анонасы.
Функция всегда должна что-то возвращать? Кажется я прихожу к тому, что это является best practice и т.п. Ведь, если я напишу что-то такое

let a = 5;
const aba = () => {
a = 5+5;
}

то , если с переменной а ЧТО_ТО случится!!! - функция сделает бяку. А если бы она что-то возвращала, то сразу бы ошибку вышибла
Аноним 05/12/16 Пнд 16:28:09  888489
>>888482
>Функция всегда должна что-то возвращать?
Любая функция в JS что-то, да возвращает.
Неявно это undefined.
>Кажется я прихожу к тому, что это является best practice
В первую очередь такие функции удобно тестировать.
Аноним 05/12/16 Пнд 16:30:54  888494
>>888489
В смысле, очевидное применение для новичка в программировании - это использовать функции как скобки, разрезая длинный кусок кода на маленькие и короткие.
Но если не думать при этом об архитектуре и взаимодействии ф-й между собой, то это то же нагромождение, только упиханное в функции. А поменяешь порядок - поставишь одну над другой - и всё сломается.
Аноним 05/12/16 Пнд 16:33:44  888497
>>888292

для удобства чтения начинай первую строкус с "" +

var a = '' +
'строка 1' +
'строка 2' +
'строка 3';
Аноним 05/12/16 Пнд 16:35:31  888499
>>888412
Какая у этого цель? Потешить твой синдром утёнка?
Аноним 05/12/16 Пнд 16:36:45  888500
>>888497
Ну а может лучше Настя использовать шаблонные строки из ES6 вместо конкатенации строк?
Аноним 05/12/16 Пнд 16:38:01  888502
>>888499
>Какая у этого цель?
Облагородить реакт моделью, очевидно же.
Аноним 05/12/16 Пнд 16:44:00  888512
>>888500

норм технология, но зачем они в конкретном случае с моим примером и в примере того анона, которому я ответил?
Аноним 05/12/16 Пнд 16:48:10  888516
>>888500
>>888512


почитал манул, ок каюсь https://developer.mozilla.org/ru/docs/Web/JavaScript/Reference/template_strings

там кста пометка "экспериментальная технология"
Аноним 05/12/16 Пнд 17:50:59  888551
14646245328750.gif (499Кб, 360x246)
блээээт а почему в for лупе нет разницы между ++i и i++?
Аноним 05/12/16 Пнд 17:57:08  888557
>>888551
Хотел ответить "съеби в js-тред с такими глупыми вопросами", но мы уже здесь
Аноним 05/12/16 Пнд 17:58:26  888558
>>888557
ну так тогда отвечай, свинья ебаная
Аноним 05/12/16 Пнд 18:02:44  888561
>>888558
> почему в for лупе...
потому что мать твоя - шлюха сравнение и инкремент происходят в отдельных стейтментах
Аноним 05/12/16 Пнд 18:08:26  888564
>>888561
при чем тут сравнение, свинья?
Аноним 05/12/16 Пнд 18:11:06  888565
>>888564
>>888561
>>888551

>++i means i+=1; return i
>i++ means oldI=i; i+=1; return oldI

Аноним 05/12/16 Пнд 18:11:34  888568
>>888564
При том, что от сравнения индекса с длиной обычно зависит количество итераций, тупой ты пхп-шника сын.
Аноним 05/12/16 Пнд 18:13:17  888571
povarl.webm (483Кб, 320x240, 00:00:13)
>>888565
>>888568
>эти свиньи
Аноним 05/12/16 Пнд 18:18:35  888574
>>888571

var i=0;
var r = [i++, i, ++i, i, i--, i, --i, i];
alert(r);
Аноним 05/12/16 Пнд 18:20:24  888575
14586775661280c[...].webm (648Кб, 640x360, 00:00:10)
>>888574
>alert(r);
Аноним 05/12/16 Пнд 18:23:31  888577
>>888575

https://jsfiddle.net/#&togetherjs=2utVUnTKqb
Аноним 05/12/16 Пнд 18:25:25  888580
ну вы и свиньи конеш... даже я уже понял
Аноним 05/12/16 Пнд 18:59:36  888613
>>887930
Аноним 05/12/16 Пнд 19:33:09  888653
Когда в JS появится некоторая понятность и упорядоченность из коробочки? Чтобы оно все само соединялось и оптимизировалось, а ты лишь писал код?
Аноним 05/12/16 Пнд 19:42:22  888663
>>888653
Никогда
Аноним 05/12/16 Пнд 19:53:16  888673
Что скажут ангуляро-боги?
https://meebleforp.com/blog/36/angular-2-is-terrible?utm_source=forwebdev&utm_medium=announcement&utm_campaign=pochemu-angular-2-uzhasen-nestabilnye-za
Аноним 05/12/16 Пнд 20:02:24  888679
>>888663
Тогда по другому вопрос. Чего в принципе необходимо и достаточно для покрытия 80% задач? Эдакий принцип Паррето применительно к JS? Стабильность-простота-минимум
Аноним 05/12/16 Пнд 20:05:31  888680
Ребятки, уже отписывал в фронтенд треде, спрошу и тут. Я запилил простой калькулятор и игру(найди пару) на js. В планах был засраный туду лист на jquery (типа чтоб показать, что знаю jq) и какое-то простенькое SPA на Ангуляре. Выходит, что это все нахуй не надо и не интересно работодателю? Тогда подскажите, что должно лежать на гитхабе такого, какой проект, чтоб меня хотя бы пригласили на собеседование front/js junior?
Аноним 05/12/16 Пнд 20:14:29  888687
>>888680
Ну епты на джуна это говно и пили.. это для миддла тебе нужны средние - крупные готовые проекты по конкретной технологии.
Аноним 05/12/16 Пнд 20:15:20  888689
>>888679
Ты про фреймворки сейчас?
Аноним 05/12/16 Пнд 20:21:02  888698
>>888653
>Когда в JS появится некоторая понятность и упорядоченность из коробочки?

как только ты откроешь для себя, как console.log() смотреть что в объектах
Аноним 05/12/16 Пнд 20:23:59  888703
>>888698
>что лежит в объектах
>fix
Аноним 05/12/16 Пнд 20:27:10  888706
Итак, вопрос века, browserify или webpack?
Аноним 05/12/16 Пнд 20:33:41  888714
>>888698
> как только ты откроешь для себя, как console.log() смотреть что в объектах
Но ведь для объектов лучше подойдет console.dir()
Аноним 05/12/16 Пнд 20:39:30  888717
>>888689
Да. Ну то есть я учу Яву. Стало интересно поковыряться что из себя представляет js а там какие то ебеня из кучи слов. Когда весь мир движется в сторону "make it easy!®". Js сообщество движется в сторону феодальной раздробленности.
Аноним 05/12/16 Пнд 21:00:07  888726
>>888717

эти "кучи слов" АПИ языка, просто не лезь в дебри сразу, юзай минимум. всё придёт само.
Аноним 05/12/16 Пнд 21:01:21  888727
>>888726
>всё придёт само

ЛЕТ ЧЕРЕЗ 7-8
Аноним 05/12/16 Пнд 21:02:51  888728
>>888726
>>888717
А если придет, то ты либо отрастишь бороду и будешь попивать смузи, заедая панкейками, либо убежишь из этого ада для инженеров куда-нибудь в IBM/Апач/Оракл/етц хайлоад/лоу левел связанные технологии.
Аноним 05/12/16 Пнд 22:36:50  888793
>>888728
Врядли в 2024 ты будешь задаваться этим вопросом. Скорее будешь сидеть в какой нибудь московской республике и думать где бы поймать прохожего на ужин.
Аноним 05/12/16 Пнд 22:48:02  888801
Скриптаны, нужно в строке заменить множественные пробелы не заключенные в одинарные или двойные кавычки на одинарные пробелы. Помогите регулярку для replace запилить.
Аноним 06/12/16 Втр 00:55:53  888857
>>888801

google -> build regex online
Аноним 06/12/16 Втр 10:53:17  889020
8f98772c1818f9b[...].jpg (4Кб, 220x220)
111.PNG (37Кб, 666x253)
Почему tmp = undefined ?
Аноним 06/12/16 Втр 11:02:10  889027
блокнот.png (5Кб, 585x115)
Я в веб разработке не шарю совсем, помогите пожалуйста. Почему в гугле аппендчайлд работает, а на дваче - нет?

>>889020
Если tablerow1 не определен и tablerow1 не определен, то…
Аноним 06/12/16 Втр 11:05:03  889030
>>889027
>div
Не исправил текст после попытки запихнуть див класс. Сейчас там img, и все равно не работает.
Аноним 06/12/16 Втр 11:05:42  889031
>>889027
>Если tablerow1 не определен и tablerow1 не определен, то…
Но они определены. Первый равен 0, второй равен 5. Дебагер это показывает.
Аноним 06/12/16 Втр 11:12:41  889035
>>889027
Полагаю, может неработать из-за строки 2 или из-за строки 5.
Аноним 06/12/16 Втр 11:16:22  889036
>>889031
> if (row1 > row2)
Условие не выполняется, tmp определяется в блоке по условию, которое не выполняется. Поэтому tmp = undefined.
Аноним 06/12/16 Втр 11:17:39  889037
С фленегана или кантора лучше начать?
Аноним 06/12/16 Втр 11:21:43  889039
google.PNG (14Кб, 1095x430)
>>889035
Но ведь с главной страницей гугла этот скрипт работает. Может есть какие-то системы защиты? Их можно обойти?
Аноним 06/12/16 Втр 11:30:58  889046
append.PNG (91Кб, 1357x661)
Элемент оказывается добавился, просто его не видно. Но почему?
Аноним 06/12/16 Втр 12:18:13  889065
>>889046
Разобрался. Спасибо.
Аноним 06/12/16 Втр 12:50:05  889100
image.png (7Кб, 125x25)
Это норма?
Аноним 06/12/16 Втр 12:55:35  889104
>>889100
хуйня
Аноним 06/12/16 Втр 13:16:51  889115
>>889100
Этот >>889104 имел ввиду, что это ещё хуйня, атм и веселее штуки есть.
Аноним 06/12/16 Втр 13:28:27  889124
>>889100
Это еще ерунда:
constructor(){
this.Bar = this.Bar.bind(this);
this.Baz = this.Baz.bind(this);
...
this.Zaebalo = this.Zaebalo.bind(this);
}
Аноним 06/12/16 Втр 13:34:11  889133
>>889100
Раньше - да. Сейчас частично стрелочными функциями эту хуйню решили.
Аноним 06/12/16 Втр 13:35:58  889135
>>889027
Ты уверен, что getElemByClass работает как надо?
Аноним 06/12/16 Втр 13:36:29  889136
>>889135
а, надо сразу весь тред читать
Аноним 06/12/16 Втр 14:24:13  889151
ctr.png (90Кб, 851x687)
решил писать всё в таком стиле, будут ли в конце проекта проблемы?
Аноним 06/12/16 Втр 14:41:54  889171
>>889151

*case 'call-id-anchor' это в смысле якорь для того что бы позвонить юзеру с заданным айди, а не в смысле что я там дублирую название якоря приложение для коммуникации
Аноним 06/12/16 Втр 16:31:16  889234
>>889151

var a = function(){ console.log('123') }();

в хроме это пашет, что с другими бровзерами?

по идее нужны еще одни скобки:

var a = (function(){ console.log('123') })();

почему нет ошибки?
Аноним 06/12/16 Втр 17:24:22  889259
Как это сократить?

.replace(/<[^>]+>/g,'').replace(/\[b\]/,'<b>').replace(/\[\/b\]/,'</b>').replace(/\[i\]/,'<i>').replace(/\[\/i\]/,'</i>').replace(/\[s\]/,'<s>').replace(/\[\/s\]/,'</s>')
Аноним 06/12/16 Втр 17:25:12  889261
>>889259
без первого replace
Аноним 06/12/16 Втр 17:35:36  889265
>>889234
>>889151

>In contexts where an expression is expected, wrapping in parentheses is not necessary
>https://en.wikipedia.org/wiki/Immediately-invoked_function_expression

ок, хуя я мастер гугла.

короче этот код будет пахать везде. ок, я спокоен.

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


Аноним 06/12/16 Втр 19:55:32  889370
>>889151
> будут ли проблемы?
Определенно. Потому что тебе руки переломают за такое. Это нечитабельно.
Когда видишь var hui = function... сразу думаешь, что это просто объявление какого-нибудь коллбека. В крайнем случае можешь сделать
(function huitka() {
console.log("ряяя");
})();
если так хочешь "именованные неймспейсы". Но даже так это тупо. Лучше юзай ES6 модули, компиль бабелем и не страдай костылями.
Аноним 06/12/16 Втр 19:56:52  889372
>>889265
> именованные замыкания
Нахуя?
Аноним 06/12/16 Втр 19:57:22  889373
>>889370
фикс:
"именованные замыкания"
сажа случайно приклеилась
Аноним 06/12/16 Втр 19:59:06  889376
>>889373
да блеать, опять сажу забыл убрать
Аноним 06/12/16 Втр 20:12:06  889386
Sup, /pr/, пришёл я в надежде получить советов мудров (и хуйцов не соснуть при этом).
Есть один хуй (я), желающий вкатиться в JS разработку за несколько месяцев и делать деньги на этом фриланся.
Сам JS уже практически изучен по Кантору + JS: The good parts, про DOM читал в DOM Enlightment, HTML/CSS знаю, но не особо.
Доп. условия:
1) Есть всякий разный опыт: написания приложений на C++ (вот-вот выложу прогу C++/Qt на 700+ строк на гитхаб), установки генту в нестандартной конфигурации (с написанием своих ебилдов) и прочего
2) Сложности с мотивацией. Сейчас я делаю её таблетками и активно задрачиваю JS по 2+ часа каждый день (время дано без учёта отдыха/проверки ВК/etc), но я могу это делать только несколько месяцев, дальше уже стоит получать хоть какую-то денежную отдачу чтобы был стимул работать.
3) Английский знаю недурно, спокойно могу читать какую-угодно документацию, возможно полезу на Upwork.
Вопрос: какие библиотеки/фреймоворки/API изучить за эти несколько месяцев?
Аноним 06/12/16 Втр 20:18:51  889389
>>889386
> вкатиться в JS разработку за несколько месяцев
> фриланся
))
Аноним 06/12/16 Втр 20:21:37  889392
>>889386
> 700+ строк
"Hello, world"?
Аноним 06/12/16 Втр 20:32:39  889398
>>889386
Jquery, подтяни верстку (как бог знать не обязательно, но с гуглом должен поставленные задачи решать за адекватное время), бутстрап, какой-нибудь препроцессор, сасс, например.
и фреймворк для построения крупных приложух на клиенте на твое усмотрение. Вроде ничего не забыл.
По идее сможешь конкурировать с индусами или пойти в говнофирмочку. Как ни странно, можешь писать про опыт в плюсах, некоторые заказчики ценят, что перед ними не просто js макака-верстайло. Еще знание серверных языков котируется, но на мой взгляд фулл стек - это зло для старта.
Аноним 06/12/16 Втр 20:35:14  889400
>>889398
> зло для старта
чому?
мимокрокодил
Аноним 06/12/16 Втр 20:35:18  889401
>>888653
Ангуляр2/тайпскрипт. Через жопу, но что-то похожее.
АУ!! Аноним 06/12/16 Втр 21:08:10  889430
Может кто-то по быстрому подсказать?

Есть див с id="hyi". Внутри него лежат разные элементы в том числе и UL. Как обратиться к этому юэлу?
Аноним 06/12/16 Втр 21:10:05  889433
>>889430
$("div#hui ul")
Аноним 06/12/16 Втр 21:19:05  889444
>>889433
без жквери надо. но я уже разобрался, спс
Аноним 06/12/16 Втр 21:28:22  889453
>>889386
Не лезь в это говно, серьёзно. Джунам только офис
Аноним 06/12/16 Втр 21:30:25  889455
>>889444
> без жквери надо
ты хуй
Аноним 06/12/16 Втр 21:45:56  889468
Поясните за elm, годнота в целом?
А то я тут issues кофейни почитал, не в том направлении они что-то движутся, что очень печалит.
Аноним 06/12/16 Втр 22:49:08  889519
>>889386
Что за таблетки? тоже так хочу.
Аноним 06/12/16 Втр 23:15:37  889530
>>889398
Благодарю.
Только вот стоит ли хоть как-то интересоваться NodeJS?
И вдогонку: стоит ли использовать Gulp и Babel в паре с NodeJS сервером, в собственных проектах?
Пусть не чтобы потом зарабатывать на том, что я умею с ними работать, а просто чтобы знать?
Примитивнейший NodeJS сервер у меня уже давно есть, с npm и прочим знаком, если что

>>889453
Заказчики неадекватны и конкуренция огромная?

>>889519
Эглонил, 200мг/день
Аноним 06/12/16 Втр 23:25:29  889533
>>889151
перешел на react, забыл такое как страшный сон.
мимо const кун () => {<tag/>}.
Аноним 06/12/16 Втр 23:36:27  889535
Стикер (0Кб, 480x512)
Высрал борду на реакте, чо дальше то делать?
Аноним 06/12/16 Втр 23:41:32  889538
>>889530
Там разобраться с тем галп и бабелом - на день работы.
Знать ноду лучше, чем не знать %%внезапно%. Пиздуй уже учить. Колеса в рот и с песней!
>>889398
Слишком большая для ньюфага зона ответственности. Проще было бы сосредоточиться на одной области и дрочить её, лучше фронт энд, так как в целом проще на мой взгляд и цена твоих косяков будет меньше для всех, включая тебя самого.
Вообще похуй, куда нравится, туда и надо идти. Если интересно, то что угодно осилишь.
Аноним 07/12/16 Срд 00:06:19  889555
анон, помоги, я устал уже.
Есть пустая HTML страница. Есть файл с несколькими функциями. Как сделать, чтоб функция make работала?
Соль в том, что если document.write выполняется внутри загруженного скрипта, страница остается пустой. Если снаружи - конечно, все норм, но только тогда он не берет значение хэша arr[c], и тогда же нельзя вызвать функцию make().

tl:dr
как загрузить и вызвать рандную ФУНКЦИЮ из ДРУГОГО файла-скрипта?
Аноним 07/12/16 Срд 00:12:18  889561
>>889555
А ты уверен, что в arr[c] у тебя что-то есть?
Залей на https://jsfiddle.net/ свой код
Аноним 07/12/16 Срд 00:15:18  889563
>>889561
блин, я уже ноут вырубил.
там точно все есть. Через алерт() все работает отлично.
Суть скрипта в выводе рандомного слова из введенных, как можно догадаться. Алерт(арр[с]) работает. мейк() нет. Просто докврайт тоже нет.
Аноним 07/12/16 Срд 00:19:15  889566
static-js.png (9Кб, 447x130)
>>889372

думал сперва писать всё одной простынкой, но теперь понял, что сила в модулях

>>889370

да, спасибо, понял, простынки с замыканиями не ок, нужны модули. посмотрел бабиль и другие варианты, не обессудь, но я внезапно понял что это всё делается элементарно в jquery. там еть АПИ представленный свойством $.fn, туда можно экпортировать что угодно.

теперь у меня получилась структура как на пике, всё работает как нужно.

цифры нужны для группирования, типо 2 всегда = контроллер и тд.

в 0 самые глобальные переменные, типо: $.fn.route = window.location.href.split('//').slice(1).join().split('/');

в 1 вначале идёт $.fn.uiWgts = {}; потом $.fn.uiWgts.modalForLoginButton = function(options) { ... } и так далее. ХТМЛ для виджетов клонируется с готового DOM страницы.


вроде всё норм теперь. мне тру нравится
Аноним 07/12/16 Срд 00:34:18  889573
>>889563
>+c ; //сделать переменную числом
это так не работает, надо
c = +c
Аноним 07/12/16 Срд 02:58:50  889633
>>889535
Уебищное говнище поди какое-нить.
Аноним 07/12/16 Срд 03:22:41  889640
Ищу скрипт для сортировки по тексту блока. Например, есть код:

<a href="#">Анапа</a>
<a href="#">Астрахань</a>
<a href="#">Багдад</a>
<a href="#">Варшава</a>

Если выбрана буква А, то отображать только те ссылки, у которых первая буква А. Если выбрана буква Б, то отображать только те ссылки, у которых первая буква Б и так далее согласно алфавиту. Например, как здесь https://www.aviasales.ru/airports

Гуглопоиск выбиает хуеву кучу сортировщиков таблиц.
Зачет Зачет 07/12/16 Срд 06:51:22  889655
QlXQr1FkCag.jpg (17Кб, 720x140)
Помогите Антоны
Аноним 07/12/16 Срд 07:14:10  889657
>>889655
>зачёт
>чтение/запись файлов
>JS
Сделал мой день
Аноним 07/12/16 Срд 08:37:50  889672
>>889657
жи есть нодегс
Аноним 07/12/16 Срд 08:51:03  889674
Аноны поясните за принцип работы сайтов типа YouTube to mp3 converter
Каким образом они из видео делают мп3 файл? По типу - "видео сначало заливается к ним на сервер, потом", пошагово.
Аноним 07/12/16 Срд 09:05:51  889677
>>889566
> сила в модулях
require.js
browserify
webpack
Не пиши велосипедов

Ладно бы ты писал шаблонизатор, не привязанный к конкретному фреймворку, с двухсторонним биндингом, циклами, скопами и прочим. Но тут уже сделали неплохие вещи, которыми можно пользоваться, несмотря на уродливость js.
Аноним 07/12/16 Срд 09:24:15  889681
>>889633
Нет, обычный красивый круд без ответов и картинок.
Аноним 07/12/16 Срд 09:35:47  889685
>>889573
работает, если не use strict
Аноним 07/12/16 Срд 10:54:08  889727
Стикер (0Кб, 512x512)
Всем друзьям и не только, которые ищут работу или просто пинают хуи советую вкатываться во фронтенд и жс. Советую клитора и этот тред. Я все правильно делаю?
мимо Java-господин
Аноним 07/12/16 Срд 11:38:28  889737
>>889727
Хитро. Всё правильно, пусть плебеи кушают сладкий жс-хлеб.
Аноним 07/12/16 Срд 12:40:00  889762
Стикер (0Кб, 512x512)
Зачем вообще нужна NodeJS? Это же один большой костыль. Люди берут асинхронный язык, и костылят на нём последовательное выполнение (синхронный код) с помощью всякого говна вроде колбеков, промисов. Существование этого уродца это какое то недоразумение. Почему бы не использовать парралелизм нормальных языков и добавить к нему асинхронность, и соответственно роутинг без перезагрузки на клиенте? Райан Дал создал чудовище.
Аноним 07/12/16 Срд 13:07:51  889774
>>889535
Теперь на vue
Аноним 07/12/16 Срд 13:25:03  889780
>>889677

окай Антон, почитал манулы к твоим костылям, идеи то ок, но профитов в них я не увидел.

<внезапно> есть более ультимативное и компромиссное решение. всё приложение для фронтэнда разбивать на модули, но в продакшине конкатить все файлы из каталога /static/js в один файл. на сторону клиента будет приходить один сжатый и кашированный файл например /static/js/app.js.

не забывай Антоха, чем больше в твоём приложении разных чужих велосипедов, тем сложнее тебе придётся в будущем. что например будет, если через 2 года забросят browserify, когда на его место придёт очередной хипсторский костыль, ты будешь опять переписывать всё с нуля, или будешь за спасибо фиксить баги в библиотеке browserify? в этом имхо и проблема. нативному ЖС и jquery такая судьба не грозит, тут я уверен на 146%

вроде я понял всё правильно, пруф ми вронг как гриццо
Аноним 07/12/16 Срд 13:37:50  889791
>>889681
> круд
> красивый
На 0 делишь
Аноним 07/12/16 Срд 13:41:20  889796
>>889780
webpack как раз таки и используется для бандлинга - сборки кусков в цельный проект, минификации и т.п. Жопой ты мануалы читал что ли?
мимо
Аноним 07/12/16 Срд 13:49:59  889802
>>889762
Меня, например, позабавило вот что: js - однопоточный, но для "имитации" многопоточности сделали событийную модель; потом делают async/await, который предназначен для линейного выполнения псевдоасинхронного кода, и все щас ссут кипятком с этого async/await. Вот это шин.
Аноним 07/12/16 Срд 14:08:24  889813
>>889780
> не забывай Антоха, чем больше в твоём приложении разных чужих велосипедов, тем сложнее тебе придётся в будущем.
признайся, ты не писал ничего крупнее хелловорлда для собеседования?
Аноним 07/12/16 Срд 14:16:24  889818
>>889737
Пусть плебеи вкатываются в хаскель, жс, фронтентд, пхп, но благословенную жаву оставят в покое.
Аноним 07/12/16 Срд 14:35:55  889827
>>889802
Событийная модель - не имитация многопоточности, а другая модель конкуррентности. Нода написана на основе libuv, а модель эта существует уже много лет (select, epoll, kqueue).

Async/await, который надо сказать не только в ЖСе сейчас есть, сделан для того, чтобы писать асинхронный код без коллбэк-лапши.

Чтобы ты понимал, я не ЖС/Нода-фан, просто интересуюсь темой. И давай без хейта.
Аноним 07/12/16 Срд 14:39:43  889830
Стикер (0Кб, 512x512)
>>889802
Вот тут интересно написано на эту тему: https://news.ycombinator.com/item?id=12338365

Даже Райан Дал ненавидит Node.js:
http://harmful.cat-v.org/software/node.js
Аноним 07/12/16 Срд 14:56:57  889843
>>889827
Я в том смысле, что в js сделали "ненастоящую" асинхроннлсть, когда реально работает один поток, что вынуждает писать лапшу из коллбеков даже когда реальной необходимости в этом могло бы и не быть. А потом выкатывают асинх/авейт типа "смотрите какую мы вам крутую штуку принесли", хотя это по сути костыль, который покрывает их старый костыль с псевдоасинхронностью.
Никакого хейта, я сам из энтерпрайза в js перекатился.
Аноним 07/12/16 Срд 15:22:43  889866
>>889685
схуяли оно будет работать? при чем тут вообще юз стрикт?
>>889774
с этого начинать надо было
но уже мозги зашкварены реактом и нормальные фреймворки вряд ли их спасут
это как раньше были жквери программисты теперь есть реакт программисты, синоним говнокодера
Аноним 07/12/16 Срд 16:28:42  889928
>>889843
>Я в том смысле, что в js сделали "ненастоящую" асинхроннлсть, когда реально работает один поток
Блядь, тебя уже поправил анон выше, а ты снова путаешь понятия асинхронной модели и многопоточной.
Может быть, пора перестать думать жопой?

>Никакого хейта, я сам из энтерпрайза в js перекатился.
Право дело, из ынтырпрайза приходят исключительно лоботомированные личности.
Аноним 07/12/16 Срд 17:36:12  889982
>>889802
> сделали событийную модель
> для "имитации" многопоточности
нет
Аноним 07/12/16 Срд 17:37:54  889983
>>889866
> нормальные фреймворки
> vue, react
Сорта говна же. Нормальный фреймворк сейчас только Ember и angular2. Они юзают вообще какие-то слабосвязанные библиотеки.
Аноним 07/12/16 Срд 17:47:23  889989
>>889983
angular 2 возможно станет самым годным фреймворком, но пока он сырой
ember годнота, тут согласен
но почему ты считаешь vue говном?
этакий реакт из которого выкинули все говно и оставили хорошее
при том это сейчас самый быстрый фронтэнд фреймворк в мире для большинства кейсов
если учить первый фреймворк то vue оптимальный выбор, потом года через 3 опыта перейти на ember или angular 2
Аноним 07/12/16 Срд 17:54:25  889993
>>889989
В vue что хорошо, что туда еще не успели набежать говнокодеры. И новичок изучая его будет делать это по хорошим мануалам с минимальным шансом наестся говна.
React сам по себе не плох, но даже сами авторы в ахуе от того, сколько говнокодеров набежало в жажде наживы и какой пиздец они вытворяют. При том эти люди еще и имеют наглость кого-то учить.
Аноним 07/12/16 Срд 17:54:37  889994
>>889989
реакт быстрый, пока ты своего гавна над ним не напихаешь, чтобы всетаки доделать приложение.
Аноним 07/12/16 Срд 17:56:04  889995
>>889994
самый быстрый vue, а не реакт
с этим даже разработчики реакта согласились, так как вместе писали бенчмарки
Аноним 07/12/16 Срд 18:04:03  889997
ТАК ЧТО УЧИТЬ-ТО?? ЭМБЕР, РЕАКТ, АНГУЛАР ИЛИ БЕКБОН?
Аноним 07/12/16 Срд 18:56:17  890045
>>889674
ffmpeg
Аноним 07/12/16 Срд 18:58:37  890047
>>889989
> фреймворк
Это либа блядь потому что
Аноним 07/12/16 Срд 19:00:17  890049
>>889997
Лучше уж книжку по паттернам проектирования наверни, а понимание как все работает потом придет.
Аноним 07/12/16 Срд 19:02:25  890052
Screenshot20161[...].png (38Кб, 976x315)
>>890047
М?
Аноним 07/12/16 Срд 19:09:11  890056
>>890052
Охуеть, либу для рендеринга теперь фреймворком называют.
Хотя да, заглянул в репу, грустно стало пиздец от такой хуйни. JS проходит в сжатые сроки все то, что прошел php за 12 с хуем лет.
Аноним 07/12/16 Срд 19:18:56  890061
>>890049

Посоветуй какую?
Аноним 07/12/16 Срд 19:19:33  890062
>>890056
Ну там есть официальные роутер и стейт менеджмент. Так же официальная интеграция с RxJS. Почему бы и не называть фреймворком, даже если эти вещи опциональны.
Аноним 07/12/16 Срд 19:21:02  890063
Про JS чувак пишет:
http://keinkeinkein.livejournal.com/141332.html

Профессии "дальнобойщик" и "таксист" уйдут в прошлое. Данные люди будут уволены, а те из них, кто захочет переобучиться, сделают это. Они изучат дома что-нибудь наподобие Rust, C, Golang или C++, затем выучат в общих чертах какую-нибудь узкую предметную область и пойдут работать на какой-нибудь проект. Будут работать, как все. Software development и смежные области работы, кстати, вообще не требуют ни особой генетики, ни особой структуры мозга. Все смогут работать, абсолютно все.

Я думаю, что хотя бы язык Си и standard library может освоить каждый. Каждый гражданин России в возрасте от 15 до 50, не являющийся умственно отсталым, не состоящий на учете у психиатра. Не требуется там вообще (!) никакая особая структура мозга. Дальнобойщик сможет научиться использовать Vim и отладчик в том числе, если будет нормальное образование, если будут грамотно составленные курсы.

Ну и JavaScript тоже каждый может освоить. События, API браузера, DOM, замыкания, области видимости, контекст вызова, итераторы. Опять же, там вообще никакая особая генетически обусловленная структура мозга не требуется. Да все могут.
Аноним 07/12/16 Срд 19:22:11  890065
>>889866

но у меня же работает.
Аноним 07/12/16 Срд 19:38:43  890073
>>890065
если ты автор скрина то работает потому что оно уже и так число
эта строка ничего не делает и не изменяет
Аноним 07/12/16 Срд 20:26:52  890089
Посоны, что лучше всего подходит для фронта простенького SPA-интернет магазина? Пилить буду один, чисто для себя.
Аноним 07/12/16 Срд 20:44:25  890094
>>890089
SPA же хуже гуглятся, не? Для интернет-магазина это неоч.
Аноним 07/12/16 Срд 21:15:12  890113
>>890094
нет, от того что приложение спа хуже оно гуглится не будет
Аноним 07/12/16 Срд 21:19:08  890116
>>890089
Backbone + vue.js
Аноним 07/12/16 Срд 23:26:09  890181
>>890116
React или Vue.
Аноним 08/12/16 Чтв 01:12:35  890234
etq5lPYe5P0.jpg (7Кб, 300x314)
Вечер в радость, чефир в сладость!
В общем есть пару вопросов за ваш этот js
Учусь в вузе на 3ьем курсе, курсач по web технологиям написать игру на js.
Есть ли варик слизать где-то готовую или годные туториалы?
просто времени в js разбираться нет, тк долги по другим предметам есть
сам имею небольшой опыт работы с c++, java, asm
Аноним 08/12/16 Чтв 01:14:51  890236
>>890234
Хуясе.
Аноним 08/12/16 Чтв 01:17:11  890238
>>890236
???
Аноним 08/12/16 Чтв 01:18:11  890239
>>890238
1. Ты охуел, чмо ленивое?
2. Что это за шарага такая?
Аноним 08/12/16 Чтв 01:19:57  890241
>>890239
спбгэту
Я не ленивый, помимо этого дохуя дел
Это называется путь наименьшего сопротивления или расстановка приоритетов
Аноним 08/12/16 Чтв 01:23:36  890242
>>890241
Какой же ты пидр, пошел отсюда нахуй в гугл.
Аноним 08/12/16 Чтв 01:38:25  890250
стоит ли перекатываться с пхп на эту вашу ноду?
Аноним 08/12/16 Чтв 01:44:48  890255
>>890242
Какой же ты грубый
Остуди свой гнев, петух
Аноним 08/12/16 Чтв 01:52:22  890258
1480609839398.png (99Кб, 352x345)
>>890250
> с говна на мочу
Аноним 08/12/16 Чтв 02:00:09  890260
>>890250
Зачем? Laravel один из лучших бекенд фреймворков сейчас. Гораздо лучше нодовского express для львиной доли кейсов.
Аноним 08/12/16 Чтв 02:05:04  890262
boyan-mihaylov-[...].jpg (24Кб, 638x359)
>>890250

да. гугли за webassembly
Аноним 08/12/16 Чтв 03:09:24  890274
>>889993
знакомый хохол-обосранец, работавший всю жизнь барменом и жонглером учит сейчас реакту за деньги.
нет, это не троллинг и не реклама
Аноним 08/12/16 Чтв 03:23:44  890276
>>890260
Некорректное совершение. У ноды есть
https://adonisjs.com
Аноним 08/12/16 Чтв 03:24:30  890277
>>890276
> совершение
Сравнение, офкос
Аноним 08/12/16 Чтв 04:49:57  890286
Сосоны, я вообще нихуя не программист на js, но у меня возникла задача поменять html страничку полностью как плагин для grease monkey. Есть ли какие-нибудь функции, типа перлового s/// чтобы быстро заменить строку, которую я нашел регэкспами на ту, что нужно мне.
Аноним 08/12/16 Чтв 04:56:35  890288
У кого-то есть на примете скрипт для инфинити скролла с поддержкой grid-системы и без привязки к фреймворкам? С меня как всегда.
Аноним 08/12/16 Чтв 05:40:15  890294
14806299465630.jpg (4Кб, 184x184)
>>890288
С меня тоже как всегда.
Аноним 08/12/16 Чтв 06:01:11  890296
Задача: создать массив длинны N и заполнить каждый его элемент его же индексом, т.е. [0, 1, 2,...]
Решение: Array.apply(null, {length: N}).map(Number.call, Number)
А теперь задайте себе вопрос: додумался ли ты бы сам до такого красивого и компактного решения? Если нет, то даже не считай себя js-программистом. Ты обычная макака, которая без фрамеворка даже штаны себе не застегнет.
Аноним 08/12/16 Чтв 06:22:35  890298
>>890296
Прикольно, в 7.3 раз быстрее чем while > push.
Правда такой массив ограничен 500к элементов.
Аноним 08/12/16 Чтв 06:26:40  890300
>>890298
Array(N).fill().map((e,i)=>i+1);
а это в 45 раз быстрей
Аноним 08/12/16 Чтв 06:30:08  890301
Стикер (0Кб, 320x320)
>>890294
Аноним 08/12/16 Чтв 06:41:33  890302
>>890296
Спецолимпиада же в другом треде, не?

>>890300
>Array(N).fill().map((e,i)=>i+1);

Так тоже пойдет:
[...new Array(n)].map((val, idx) => idx);
Аноним 08/12/16 Чтв 08:57:18  890318
>>890296
> красивого и компактного
С такими красивыми и компактными решениями пусть нахуй идут, олимпиадники. Кому-то потом это говно еще поддерживать
Аноним 08/12/16 Чтв 12:11:54  890373
>>890318
Что, после укладки шпал не остается времени на развитие?
Аноним 08/12/16 Чтв 12:17:41  890375
>>890373
Поддерживаемость и читаемость кода стоят над его краткостью, красотой и выходной эффективностью.
Бузинес работает именно так, кид.
Аноним 08/12/16 Чтв 12:35:09  890388
>>890373
Уж сколько раз твердили миру, что явное лучше неявного. Я могу легко потратить минут 10 чтобы распарсить этот говнокод. Но раскидав такие кусочки говна по всему проекту, любителю-рубисту у нас, например, легко могут оставить без обеда за счет компании, так как за коммитами смотрит не один человек.
Аноним 08/12/16 Чтв 12:43:05  890396
Стикер (0Кб, 512x512)
шкальники вкатывальщики выебываются, а вы ведетесь, лол
Аноним 08/12/16 Чтв 12:46:42  890397
>>890045
Спасибо
Аноним 08/12/16 Чтв 13:26:56  890417
Аноны поясните кто-нибудь (или дайте ссылку, буду благодарен) за более лоу лвл работу обычного нод http сервера? Имеется в виду не только "app.listen()" как в книгах о ноде, а именно как это вообще происходит обмен файлами? Всякие хендшейки там протоколы и тд.

Если сделать сервер на C например, это прояснится для меня или на С тоже все через библиотеки все делают?
Аноним 08/12/16 Чтв 13:29:29  890420
>>890417
Ты как оказался в профессии, не умея в гугл?
Аноним 08/12/16 Чтв 13:29:36  890421
>>890417
> а именно как это вообще происходит обмен файлами? Всякие хендшейки там протоколы и тд.
Возьми да глянь исходники, хули там сложного?
Аноним 08/12/16 Чтв 16:14:02  890519
>>890286
.replace
Обратиться аяксом и вызвать метод Аноним 08/12/16 Чтв 17:00:12  890544
ajax-in-django.jpg (44Кб, 462x430)
Учу этот ваш JS, дошел до аякса - тут урок по RPC-XML запорот немного видос часто стоит на месте. Вообщем хуйово я его усвоил. Но лабу сделать хочу, подскажи анон, что имеется ввиду в этом пункте задания?

-Обратитесь к серверу XML-RPC lab-4-server.php и вызовите метод eshop.getDeliveryMethods (без параметров). Сервер вернет XML-RPC ответ.
-Создайте переменную dom и присвойте ей вернувшийся ответ.

Как обратиться и передать параметры я понял, но как обратиться и вызвать метод?
Аноним 08/12/16 Чтв 19:00:47  890621
>>890544
> вызвать метод
Погугли что такое rpc и как делать post запросы с разными content-type
Аноним 08/12/16 Чтв 19:22:56  890642
>>890621
это я уже вроде понял, но почемуто в консоли возвращается null.

Пишу так: https://jsfiddle.net/kbmnmchr/
Там пару библиотек самописных подключены, но не суть. Написано то все правильно? Я имею ввиду, если написано правильно, то проблема может быть в остальных файлах? Или это норма, что condole.log возвращает нулл? сука, как же мне больно
Аноним 08/12/16 Чтв 19:34:06  890650
>>890642
> Написано то все правильно?
По части логики наверно да. Проблема либо на сервере либо в остальных либах.
Аноним 08/12/16 Чтв 21:22:57  890726
>>884432
>хеллоу ворлд вкатыша
>3мб
>При этом бандл еще и минимизированный
Да ты охуел.
Аноним 08/12/16 Чтв 21:26:05  890729
>>890726
У меня этот бандл всего 400кб весит.
Аноним 08/12/16 Чтв 22:37:28  890789
>>890650
а не имеется какого либо сжатого фака в виде документации по теме xml-rpc?
Аноним 08/12/16 Чтв 23:21:24  890812
>>890789
> сжатого фака
Статья на вики.
Аноним 08/12/16 Чтв 23:53:49  890840
>>884390
>на 150+ строк в каждом файле с методами и контроллерами - один охуительней другого.
Велькам ту аур ворлд, май диар френд.
А еще системы сборки, у которых зависимости и зависимости от зависимостей, и все это стоит на ките, который едет на одноколесном велосипеде и жонглирует YOBAми.
И все ради того, чтобы у тебя на страничке пиздато все отображалось.
Аноним 09/12/16 Птн 00:53:23  890886
>>884390
пиши на jquery
Аноним 09/12/16 Птн 02:10:29  890904
>>890812
Там нихуя нет. Но уже разобрался
Аноним 09/12/16 Птн 07:45:04  890972
Аноны, какие телодвижения надо осуществить, чтобы с состояния абсолютного незнания подняться до уровня "Javascript на уровне чтения кода", и сколько приблизительно времени это займёт? Да-да, всё индивидуально, я понимаю, но хоть приблизительно.
Аноним 09/12/16 Птн 08:54:36  890988
>>890904
Поздравляю, ты тупой. Там даже пример вызова блять есть.
Если нужно еще подробнее, то только спека.
>>890972
> с состояния абсолютного незнания подняться до уровня "Javascript на уровне чтения кода"
пара минут, достаточно лишь исходники открыть какие-нибудь.
Аноним 09/12/16 Птн 16:30:25  891153
>>890988
>>890972

чтение кода !== тупо чтение букв и слов, его нужно уметь выполнять в голове. на это в случае с ЖС уйдёт месяц-два минимум.

>телодвижения

разбирать рабочие примеры и курить гайды
Аноним 09/12/16 Птн 17:17:24  891167
>>890063
Это галерный пропагандон. Не слушайте его.
Аноним 09/12/16 Птн 18:08:08  891199
Изобрел для себя недавно принцип построения например какой-нибудь бизнес логики, модели да хоть целого приложения.Заметьте, что любой объект(product) можно расширить любым поведением(someone). Причем пристутствуют приватные объекты и открытый доступ к ним с помощью методов. Наверняка такое уже где-то есть. Как оно называется? Пример ниже

var someone = {
extend: function(extendable) {
var something = {};
extendable.changeSomething = function(data) {
something = data;
};
extendable.getSomething = function() {
return something;
};
}
};

var factory = {
set1: {},
set2: {},
set3: {},
produce: function() {
var produced = {
set1: {},
set2: {}
};
produced.set1 = this.set1;
produced.set2 = this.set2;
someone.extend(produced);
return produced;
}

};

factory.set1 = something1;
factory.set2 = something2;
var product = factory.produce();
product.changeSomething(something3);

и так далее.
Аноним 09/12/16 Птн 18:32:19  891214
>>891199
Ты сейчас backbone изобрел
Аноним 09/12/16 Птн 19:02:47  891222
с чего начать изучать фреймверки, с backbone или angular
Аноним 09/12/16 Птн 19:15:46  891228
>>891222
С первого, оно простое очень и хорошо позволяет понять паттерны проектирования веб приложений не отвлекаясь на пока что ненужные сложности.
Можно с vue еще если не волнует что мало готовых компонентов. Под нее мануалы очень хорошие сейчас, позволяют новичку учиться делать правильно и сам этот фреймворк в отличии от всяких реактов не поощряет говнокод.
Аноним 09/12/16 Птн 19:24:14  891232
Что можно почитать про функциональное программирование на js для тупого?
Аноним 09/12/16 Птн 19:33:59  891235
>>891232
http://reactivex.io/learnrx/ палю годноту
Аноним 09/12/16 Птн 19:34:57  891237
>>891235
Только там надо самому делать интерактивные примеры, а не просто смотреть ответы. Иначе нихуя толку не будет.
Аноним 09/12/16 Птн 19:40:19  891243
>>891235
Годно. Спасибо.
Аноним 09/12/16 Птн 21:10:42  891314
2016-12-09-2110[...].png (95Кб, 1920x1080)
>>891235
Проиграл с этой годноты
Аноним 09/12/16 Птн 22:14:00  891369
>>891314
> Сломать себе браузер
> Проигрывать с этого
Аноним 10/12/16 Суб 01:26:06  891451
Подскажите что можно посмотреть/почитать по React па русске
Аноним 10/12/16 Суб 02:03:54  891462
>>891369
Зачем ты его так приложил?
Аноним 10/12/16 Суб 03:18:01  891470
в Node.js проблема с открытием видео вконтакте. Ссылки вида https://cs635500.vk.me/6/u225819608/videos/b179a92183.240.mp4?extra=9S....6x
В браузеер, питоне, curl'е — всё нормально, 200 OK, данные приходят. Если же, используя request, попробовать открыть это в ноде — 404.

Никак не пойму, в чём может быть проблема? Никакие куки или хедеры остальным не нужны. Нода 6.4.0, реквест 2.79.
Аноним 10/12/16 Суб 03:26:24  891472
>>891470
А впрочем, вопрос задал, как обычно, прямо перед тем, как наконец решить проблему. Если страницу с, собственно, сылкой на файл сначала скачать в ноде, то выдранная из той страницы ссылка (с другим ключом уже) нормально работает в ноде (и нигде больше). Видимо, та тройка шарит какой-то общий ресурс, который вконтакте считает за одно и то же, а нода — отдельная. Был бы рад объяснению происходящего.
Аноним 10/12/16 Суб 06:00:44  891491
>>891472
Может дело в юзерагенте? Браузер и пистон уж точно не могут быть связаны
Аноним 10/12/16 Суб 11:23:37  891555
>>891472

сравни хиддеры реквестов к тентаклю, что шлют те три клиента и нода
Аноним 10/12/16 Суб 11:46:58  891569
>>891555
>>891491
Хедеры я пытался разные вставлять, но курл лишь три использует и всё норм, в питоне вообще без хедеров отправлял и тоже ок, юзер-агента хоть asdf ставь.
Ссылку он не открывает точно так же, как если бы я её просто на другом компьютере пытался открыть (потому я её и обрезал, собственно, вам бесполезна была бы).
Можете попробовать вот отсюда https://vk.com/video-41485889_456239973 (не требует регистрации, а так любое можно) взять в коде страницы ссылку ( искать по"url240", "url360" и т.д.) и зареквестить её в ноде. Она даже в ругом браузере работает! Но не на другом компьютере (в чём угодно).
Аноним 10/12/16 Суб 11:56:58  891579
14809115242510.webm (9389Кб, 492x360, 00:03:20)
Как переписать это с колбэками?

axios.get(root + '/posts/1')
.then((responseOne) => {

axios.get(root + '/posts/2')
.then((responseTwo) => {

console.log(responseOne.data.id)
console.log(responseTwo.data.id)

})
})
Аноним 10/12/16 Суб 12:16:48  891593
>>891579
вместео get(a).then((){}) делать get(a, function(){})?
Аноним 10/12/16 Суб 12:36:49  891608
>>891593
И как туда response передавать? Как сам callback вызывать?
Аноним 10/12/16 Суб 14:16:11  891641
Почему response в модуле request приходит в JSON формате а в модуле axios в JS формате? В axios встроенный парсер?
PEREKOT Anonimous 10/12/16 Суб 14:18:29  891643
Perekot to >>891642 (OP)
Аноним 10/12/16 Суб 14:27:12  891653
>>891579
нахера?
Аноним 11/12/16 Вск 12:34:30  892322
>>884727
Дурак ты, из-за тебя и таких же как ты, демпингующих макак, скоро совсем джунам зп платить перестанут, а надо будет еще доплачивать первые пару лет за возмонжость поработать.
Подумайте тупо логически - в маке платят 25к, там уметь вообще нихуя не надо, картоху переворачиваешь весь день и все.
А чтобы актуальный стэк фронта изучить нормально надо 6-12 месяцев систематических занятий (если совсем с нуля).
Сам такой же, ксатти, пашу за 20к в большой международной компании уже пол года, еще на испытательной 2 месяца за 15к сидел.
Я считаю хороший джун в милионниках должен получать 30 со старта.
Аноним 11/12/16 Вск 14:00:13  892383
>>892322
Уметь не надо, зато какая это унизительная и тяжелая физически работа - переворачивать картоху целый день и кричать свободная касса.
А ведь от джуна толку мало, так как скорость его работы крайне низкая, он может не справится с задачей, допустит много багов.

[Назад][Обновить тред][Вверх][Каталог] [Реквест разбана] [Подписаться на тред] [ ] 508 | 59 | 138
Назад Вверх Каталог Обновить

Топ тредов
Избранное