Задать вопрос
  • Как победить увеличение высоты страницы на мобильных устройствах?

    @agaliullin
    CEO & Founder of Futureinapps, LLC
    https://stackoverflow.com/questions/23164503/disab...

    P.S. Возможно кому-то пригодится
    Ответ написан
    Комментировать
  • Возможно ли найти удаленную стажировку в it?

    sfi0zy
    @sfi0zy
    Creative frontend developer
    Но вряд ли кого-то интересует человек без опыта... Нормальной работы тут не было...
    сложно ли устроиться... много что пробовал... вольюсь во что-то новое если понадобится

    Когда-то я тоже таким был. Это очень плохая позиция для переговоров. Если подходить со стороны "я вот чем-то занимался, возьмите меня", то будет очень сложно убедить работодателя (не только удаленно, но и вживую), что вы лучше, чем десять других претендентов на вакансию. Подходите к вопросу с другой стороны - "я специалист и могу решать вот этот круг задач, у вас есть головная боль - я тот, кто может вас от нее избавить". Определитесь с областью, выложите то, что вы делали, на гитхаб или еще куда-нибудь, если веб - ну сделайте сайт себе, своим знакомым, покажите, что вы можете решать задачи. Не так быстро, как человек с 10-летним опытом, но можете. С таким подходом можно смело начинать откликаться на вакансии, ну а там уже как повезет.

    Фриланс тоже имеет смысл попробовать, но это не для всех. Там умение продавать продукт имеет большее значение, чем умение его создавать.
    Ответ написан
    2 комментария
  • Какой редактор кода лучше?

    @ZZahar
    Если решил проблему - нажми "отметить решением"
    VScode - лучшие что я видел из редакторов. Этот редактор будет посильнее некоторых IDE таких как: Netbeans и Eclipse и значительно лучше редакторов Atom и Sublime Text и уж тем более Notepad++.
    в VScode есть:
    • Мульти курсор
    • Функционал из коробки как у IDE
    • Дебагер
    • Туча плагинов которые обновляются если не раз в 3 недели, то уж точно раз в полтора месяца.
    • Обновления самого редактора раз в 1 месяц или 2 месяца, причём не "А мы тут кнопочку переместили.", а с фиксами, улучшением дебагера, производительности и синтаксиса.
    • Куча хоткейных команд
    • Быстрые клавиши из Atom, Sublime Text,IntelliJ IDEA, Vim и ещё пару редакторов.
    • Кросплотформенный т.е. поддерживает macOS,Linux и Windows. Причём macOS и Linux не хуже чем Windows, тут Microsoft хорошо постарались.
    • Там есть обучающий короткий курс прямо в редакторе.

    Ещё как вариант Brakets. У него есть LivePrewiew то есть все изменение(почти все изменения) в CSS и HTML будут показывать в реальном времени без сохранения и без обновления страницы. Только там нужен хром в других браузерах насколько я знаю не работает.
    Ответ написан
    Комментировать
  • Заполнения массива на Javascript?

    0xD34F
    @0xD34F Куратор тега JavaScript
    function createArr(size) {
      const arr = [...Array(size)].map(() => Array(size).fill(0));
    
      const mid = (size / 2) | 0;
      arr.forEach((n, i) => {
        n[i] = n[size - i - 1] = 1;
        // если размер чётный, непонятно, где выставлять единицы, так что выставляем только для нечётных
        if (size & 1) {
          arr[mid][i] = n[mid] = 1;
        }
      });
      // хотя, конечно, есть вариант ставить по два вертикальных и горизонтальных ряда единиц
      /*
      const mid = (size - 1) / 2;
      arr.forEach((n, i) =>
        n[i] =
        arr[mid | 0][i] =
        arr[Math.ceil(mid)][i] =
        n[mid | 0] =
        n[Math.ceil(mid)] =
        n[size - i - 1] =
      1);
      */
    
      return arr;
    }

    Оценить результат работы можно так, например:

    console.log(createArr(21).map(n => n.join('')).join('\n'));

    Выведет такое вот чудище:

    100000000010000000001
    010000000010000000010
    001000000010000000100
    000100000010000001000
    000010000010000010000
    000001000010000100000
    000000100010001000000
    000000010010010000000
    000000001010100000000
    000000000111000000000
    111111111111111111111
    000000000111000000000
    000000001010100000000
    000000010010010000000
    000000100010001000000
    000001000010000100000
    000010000010000010000
    000100000010000001000
    001000000010000000100
    010000000010000000010
    100000000010000000001
    Ответ написан
    Комментировать
  • Как правильнее использовать БЭМ в флекс верстке?

    dpmango
    @dpmango
    Лучше писать на уникальные классы все флекс-свойства.

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

    Например .header__wrapper вместо .flex-wrap.flex-wrap--aic.flex-wrap--jcsb
    Ответ написан
    Комментировать
  • Нужен ли return при ES6 синтаксисе?

    teknik2008
    @teknik2008
    Расскажите про GOLANG. Мне интересно
    А в чем проблема. 1 строка - return не нужен. Много, напишите явно return. Или тяжело 6 клавиш нажать? Вы код для себя пишите или для тех кто потом будет с бубном танцевать?
    Ответ написан
    9 комментариев
  • Wordpress: обработчик сохранения кастомной страницы опций?

    maxxannik
    @maxxannik
    Сайты на WordPress + Интернет магазины WooCommerce
    Вообще не правильно. Даже рядом не пахло кодексом. Это дикий костыль. Позор джунглям.
    Читаем Settings API. Или статьи в рунете есть.
    Либо можно оставить костыли. А потом говорить что ВордПресс тормозит. Хотя реально тормоза не в ВордПрессе, а в коде таких вот гениев. Тяп ляп, шлеп шлеп и в продакшн.
    Ответ написан
    5 комментариев
  • Как вы запоминаете информацию с IT-вебинаров?

    gobananas
    @gobananas
    finishhim.ru
    Просто слушаю, делая параллельно какие ни будь другие дела, подкорка мозга записывает данные фоном, потом когда надо это сделать мозг работает по принципу "я помню там ещё можно так" + легкий гуглёж и находим рецепт.

    P.S. Сейчас столько вебинаров, что если все по серьёзке смотреть, то ничего другого не будешь успевать, только по 10 часов в день вебинары смотреть ))
    Ответ написан
    Комментировать
  • Как правильно организовать структуру SPA + Backend?

    @wearemieta
    BEWARE HIPSTERS
    Но бесит, что там нет единого собранного файла bundle.js

    В шаблоне webpack-simple все скрипты собираются как раз в один файл build.js. Обратите внимание, он подключается в сгенерированный index.html. vuejs-templates/webpack-simple.

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

    так он еще создает кучи других непонятных файлов и при режиме разработки запускает ненужный 'hot-load'.


    Давайте разберемся, для чего нужен сервер в режиме разработки для Vue. При написания SPA приложения вы используете кучу библиотек, файлов в разных форматах и возможно еще обращаетесь к стороннему API(например twitter). Плюсом, вам хотелось бы использовать транспайлер, чтобы в js можно было красиво писать стрелочные функции и использовать другие вкусняшки ES2015. А еще это здорово было бы склеивать файлы одного формата в один большой для разных оптимизаций. Плюс, после того как вы измените что-то в одном файле, не пришлось бы тыкать каждый раз на перезагрузку страницы. Примерно эти вещи делает за вас dev сервер с webpack в режиме разработки.

    — с помощью webpack вы можете собирать ваши файлы каким угодно образом и складывать их в любое удобное место в фс.
    — вы можете их склеивать, минифицировать и использовать транспайлеры, препроцессоры, постпроцессоры и прочее.
    — вы можете обращаться к стороннему API с локалхоста.
    — если вам не нужен hot-load — отключите его в конфиге.

    Оставить в покое django под портом :8000, а VueJS под :8080. И в nginx как-то слушать их обоих, раздельно, таким образом четко разделить фронт от бэка. Не будет ли проблем?


    Проблем с проксированием nginx'ом? Не очень понятно что вы имеете в виду.

    Если вам нужен кастомный шаблон vue-cli то вы можете легко его разработать один раз и в дальнейшем использовать: Vue-cli custom templates

    Как правильно организовать структуру SPA + Backend

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

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

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

    В случае микросервисной парадигмы вы делите ваше приложение на много микро-сервисов. Давайте придумаем кейс, который может возникнуть в реальной жизни.

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

    Ваше приложение схематически выглядит так:

    Клиент: хочу авторизоваться => Сервер приложения: отправлю бизнес-логике => Бизнес-логика: спросим базу (данные для авторизации) => База данных: можно => Клиент: я авторизован

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

    Теперь, в вашем фронтенде на Vue, например, вы можете отображать нужные вам данные (а соотв. делать запросы в основную базу), только если пользователь авторизован.

    Теперь ваше приложение выглядит так:

    Клиент: хочу авторизоваться => Фронтенд-микросервис: отправляю микросервису авторизации => Микросервис авторизации: можно => Фронтенд-микросервис: я авторизован, хочу данные => Сервер приложения: отправлю бизнес-логике => Бизнес-логика: спросим базу (данные отображения авторизованному клиенту) => База данных: данные => Клиент: я получил данные

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

    Авторизация? — микросервис — auth0.com
    SQL База данных? — микросервис — Google CLOUD SQL
    Уменьшаем размер картинок? — микросервис — AWS Lambda

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

    Конечно, это решает определенные проблемы, но и создает новые, поэтому, повторюсь, все зависит от ваших задач.

    Давайте посмотрим на ваш пример с Django. Если я все правильно понимаю, то вы хотите использовать все плюсы Django, типа ORM, API доступа к БД, etc, заменив лишь систему шаблонов на Vue?

    В таком случае, на мой взгляд, вам нужно реализовать на Django классический REST API и из SPA на Vue обращаться к endpoint'ам вашего API.

    Ссылки по теме:
    Архитектура микросервисов
    SPA-архитектура для CRM-систем: часть 1
    SPA-архитектура для CRM-систем: часть 2
    AWS Lambda и никаких серверов
    Ответ написан
    Комментировать
  • Адаптивная верстка. Чем лучше делать отсупы(margin, padding) - rem или %?

    Ankhena
    @Ankhena Куратор тега CSS
    Нежно люблю верстку
    А логику включить?

    Чем лучше делать отсупы(margin, padding) — rem или %?

    А вы как верстаете? Не глядя в макеты дизайнера вообще?

    Сами ответьте на вопрос
    В чем вы будете задавать отступы в CSS, если:
    1. В макете дизайнера все отступы на всех разрешениях равны 23 пикселям.
    2. На десктопе шрифт задан 16px и отступы по 16px, на мобильных шрифт 20px и отступы тоже по 20px.
    3. В стайлгайде написано человеческим языком: делай отступы 3% от ширины блока.
    4. Тоже самое, но делай отступы в 2 символа.
    Ответ написан
    Комментировать
  • Где обычно находят иностранных заказчиков?

    @djay
    Я нахожу спокойно и быстро на специфических ресурсах:

    - Laravel Jobs
    - WordPress/Drupal Jobs

    Напрямую без всяких паразитов-постредников и Upwork'ов.

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

    delphinpro
    @delphinpro Куратор тега CSS
    frontend developer
    Не нормально.
    Не нормально в качестве теста перелопатить реальную страницу или сверстать с нуля лендос.
    Уточнение: не нормально, если такое тестовое задание не оплачивается.

    Нормальное тестовое задание должно занимать на выполнение не более двух-трех часов у соискателя.
    Ответ написан
    Комментировать
  • Стоит ли гнаться за лаконичностью кода?

    k12th
    @k12th
    console.log(`You're pulling my leg, right?`);
    Гнаться надо за читабельностью (обычно это где-то посередине между графоманией и кодогольфом из примера из топа).

    На CodeWars ценится краткость кода, но поскольку вы еще начинающий, главное, чтобы код работал и выглядел вменяемо (у вас ок, за исключением очень уж нестандартного форматирования). А всяким трюкам и сокращениям научитесь потом.
    Ответ написан
    Комментировать
  • SASS: extend or mixin?

    delphinpro
    @delphinpro Куратор тега CSS
    frontend developer
    Не нужно делить мир на черное и белое. В нем гораздо больше оттенков.
    Ответ написан
    4 комментария
  • Javascript уникальные значения свойства объектов?

    SPAHI4
    @SPAHI4
    реактовцы - это не девы, а прокидыватели пропсов
    const uniqueSerials = Array.from(new Set(yourObject.map(item => item.serial)));
    Ответ написан
    Комментировать
  • Javascript уникальные значения свойства объектов?

    Stalker_RED
    @Stalker_RED
    let data = [
     {id: 1, serial: "Blood.Drive", season: 1},
     {id: 2, serial: "Blood.Drive", season: 1},
     {id: 3, serial: "Foo.Bar", season: 1},
     {id: 4, serial: "HelloWorld", season: 1},
    ]
    
    let unique = data.reduce((acc,elem)=>acc.add(elem.serial), new Set())
    
    console.log(unique)
    https://jsfiddle.net/9Lunhds9/
    Ответ написан
    Комментировать
  • Почему в 1-ом случае мы прописываем each, а во втором все и так работает?

    abyrkov
    @abyrkov
    JavaScripter
    Потому, что под капотом click тот же each.
    Ответ написан
    Комментировать