Задать вопрос
  • Анимация без jquery?

    movasyl
    @movasyl
    semper tiro
    когда только изучал JS игрался с чем-то подобным. Рабочим конечно его не назовешь, но в качестве примера полностью сойдет.
    https://codepen.io/kovbassa/pen/ZpJYYQ
    Ответ написан
    Комментировать
  • Как можно в html указать, чтобы редактор понимал буквы кирилицы в коде также как и латиницу, чтобы не было сбоев?

    movasyl
    @movasyl
    semper tiro
    Идея конечно еще та .. Не стоит себя к такому приучать, но чисто ради интереса и развития, посмотри в posthtml и postcss. Эти npm плагины позволяют написать свой собственный язык разметки хоть китайскими иероглифами а на выходе получить всьо тот же валидный html и css. Также посмотри в расширениях к своему редактору на предмет линтеров, ко всем популярным редакторам их на любой вкус и цвет. Или замени свой редактор на более современный, если не найдешь нужных расширений. Рекомендую vs code, как говорится сам пью и всех приглашаю.
    Ответ написан
    Комментировать
  • Я скачал шрифт, а там целый пак шрифтов - Regular, Bold, Light, Italic... И не получается управлять через font-weight, font-style. Как исправить?

    movasyl
    @movasyl
    semper tiro
    Вот, нашел в загашнике, если используешь sass. Я тут что-то такое, когда-то намутил, сам уже не пойму как оно работает, но помню, что работало на ура.
    @mixin font-face($font-name, $path, $weight: null, $style: null, $exts: eot woff2 woff ttf svg) {
      $src: null;
    
      $extmods: (
        eot: "?#iefix",
        svg: "#" + str-replace($font-name, " ", "_") //- сама функция под миксином
      );
    
      $formats: (
        eot: "embedded-opentype",
        otf: "opentype",
        ttf: "truetype"
      );
    
      @each $ext in $exts {
        $extmod: if(map-has-key($extmods, $ext), $ext + map-get($extmods, $ext), $ext);
        $format: if(map-has-key($formats, $ext), map-get($formats, $ext), $ext);
        $src: append($src, url(quote($path + "." + $extmod)) format(quote($format)), comma);
      }
    
      @font-face {
        font-family: quote($font-name);
        font-style: $style;
        font-weight: $weight;
        @if(map-has-key($extmods, eot)){ src: url("#{$path}.eot")}
        src: $src;
      }
    
        // Chrome for Windows rendering fix: http://www.adtrak.co.uk/blog/font-face-chrome-rendering//
    
       @media screen and (-webkit-min-device-pixel-ratio: 0) {
        @font-face {
          font-family: $font-family;
            src: url('#{$path}.svg##{$font-family}') format('svg');
        }
      }
    }
    //функция str-replace для поддержки svg формата
    
    @function str-replace($string, $search, $replace: "") {
      $index: str-index($string, $search);
    
      @if $index {
        @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace);
      }
    
      @return $string;
    }
    Ответ написан
    Комментировать
  • Как повторно использовать компоненты верстки в разных проектах?

    movasyl
    @movasyl
    semper tiro
    Чуваки, вы о git слышали? Если нет, то самый раз услышать.
    ПС: хотя TARS и осиротел в последнее время, но доки там шикарные, не ленитесь за Вас обо всем позаботились ... https://github.com/tars/tars/blob/master/docs/ru/faq.md пункт #3
    Ответ написан
    Комментировать
  • Gulp 4: модули для html файлов?

    movasyl
    @movasyl
    semper tiro
    Однажды попробовав pug, ты больше никогда не будешь писать на html.
    Ответ написан
  • Как заставить метод vuejs дождаться данных с сервера?

    movasyl
    @movasyl
    semper tiro
    Я не совсем понял вопрос, но думаю, что копать нужно в сторону коллбеков или промисов.
    Ответ написан
    Комментировать
  • Современный динамический сайт. Что изучить?

    movasyl
    @movasyl
    semper tiro
    Клиент - JS / VueJS или ReactJS /
    Сервер NodeJS(expressjs)/mongoDB
    Ответ написан
    Комментировать
  • Как правильно структурировать сайт с точки зрения BEM?

    movasyl
    @movasyl
    semper tiro
    Блок - логически завершенный элемент интерфейста. Которому предоставляются наиболее общие стили а также ресет браузерных стилей.
    Блок_модификатор - селектор отвечает за внутренний вид блока. Все от бордера и внутрь. Шрифты, размеры, цвета ...

    Блок__элемент - селектор отвечает за позиционирование элемента внутри родительского блока. От своего бордера наружу до бордера родителя.

    На одном узле могут присутствовать все три сущности одновременно. Любой блок будучи блоком может быть элементом своего родительского блока.
    Но при этом элемент не может иметь дочерних элементов, а только блок.
    Тоесть както так:
    https://codepen.io/kovbassa/pen/ObrqZv?editors=1100
    Ответ написан
    3 комментария
  • Как правильно инвертировать event?

    movasyl
    @movasyl
    semper tiro
    reactjs, а особенно vuejs + pug сделают тебе такую ​​магию, что и не снилось.
    П.С: Если ужо используешь pug, то используй миксы, объекты данных и циклы, а не копипаст тегов.
    Ответ написан
    Комментировать
  • Как можно перехватить функцию javascript?

    movasyl
    @movasyl
    semper tiro
    User agent и без того каждый раз приходит на сервер вместе с объектом request-a.
    Тыкаю: Node.js.
    получаешь запрос с клиента > сверяешь что тебя интересует в ua > рендеринг соответствующей страницы и отправка страницы на клиент.
    Ответ написан
  • Как правильно построить логику загрузки модульного сайта?

    movasyl
    @movasyl
    semper tiro
    Посмотри в сторону фреймворков.
    Ответ написан
    Комментировать
  • Передача js кода или рендер на сервере?

    movasyl
    @movasyl
    semper tiro
    С Angular не знаком, но думаю ниче нового там не придумали.
    По JSON и компилить на клиенте.
    Ответ написан
  • Как из фреймворка onsen ui взять только необходимые компоненты?

    movasyl
    @movasyl
    semper tiro
    Если возникают такие вопросы тебе нужен bootstrap.
    Ответ написан
    Комментировать
  • Какой язык для написания сайта выбрать начинающему?

    movasyl
    @movasyl
    semper tiro
    JS is awesome.
    https://learn.javascript.ru
    Но что бы ты ни выбрал. Начинать нужно с html / css. + bem metodology + SASS / Stylus + pugjs
    По JS стеку:
    0. забыть о C# и не пытаться проводить аналогии. На первый взгляд все С-подобные языка похожи. Но JS уникальный в этом роде.
    1. сам js. + OOP в JS + функциональный стиль написания JS
    2. ReactJS / VueJS
    3. NodeJS + ElectronJS
    4. MongoDB / MySql (или анолог)
    5. Webpack
    Ответ написан
    3 комментария
  • Есть программа, которая из двух файлов делает один и убирает пробелы?

    movasyl
    @movasyl
    semper tiro
    Если никогда не юзал сборщики, то проще посредствам самой ноды. Гуглишь любой мануал по Node.js, ищешь что-то вроде модуля 'fs' или 'работа с файловой системой' 15 мин и готово.
    Ответ написан
    Комментировать
  • Есть ли пакет npm, который подставляет в урлы в html для css и js версию из packages.json?

    movasyl
    @movasyl
    semper tiro
    Та да, bower посмотри.
    Ответ написан
    Комментировать
  • Усовершенствование BEM или "ненужно"?

    movasyl
    @movasyl
    semper tiro
    может, я что-то не так понял, потому что от твоих дефисов, глаза разбегаются ... Семантика есть еще такое понятие, между прочим. Но, чем твое предложение отличается от концепции bem примиси?
    И кто это в 2017 году руками пишет? Пойди лучше загугли о pug да sass и как эту всю историю собрать с gulp или webpack.
    Ответ написан
    Комментировать
  • Какие свойства нужно прописывать для каждого из типов БЭМ?

    movasyl
    @movasyl
    semper tiro
    Ну во-первых немного лирики: не существует никакого единственно правильного варианта использования БЭМ в том или ином случае. Так как БЕМ это не набор аксиом и алгоритмов, а идея (чит. Идеология, философия, взгляд под другим углом и тп ...). Кроме того БЕМ не единственная в своем роде концепция, из первого что приходит на ум - SMACSS, OOCSS, Atomic CSS. Если посмотреть обобщенно, одно и то же разными словами с незначительными расхождениями (краткий обзор). Важно не название, а суть. Ты сейчас (да и вообще каждый, кто делает первые шаги на пути джедая :)) наверное думаешь - "Блин, ну нафига они придумали этот вынос мозгов?", или - "За что они так со мной?". Можешь не отвечать, я все равно знаю что так :). А суть, как раз таки, кроется в противоположной плоскости. Для того чтобы понять сложные вещи написаны зачастую непонятными словами (исключительно для пафоса) нужно:
    1. Из всего потока информации четко, по пунктам выделить для чего оно создано и какие трудности собственно должно решить.
    2. Методом научного тыка, на практике, найти эти проблемы, увидеть своими глазами и понять что данный инструмент, это не наказание с неба, а молоток для гвоздей которые ты раньше забивал ручкой отвертки.
    Чуть ближе к телу:
    Программисты вообще не любят верстку. Потому что они привыкли работать с продвинутыми языками программирования где все поддается логике, а все шишки уже набиты предшественниками. А связка html / css очень трудно вписывается в эту картину. Отсюда и постоянное стремление придумать велосипед. Следующее, существует 1000 и один способ сверстать даже простейший элемент. Что уж говорить о современных интерактивних веб-приложениях... В результате на выходе ты получаешь тысячи строчек кода, которые не понятно как работают, еще и непонятным образом взаимодействуют между собой, да так что сам их создатель через день не может разобраться.
    Ху из BEM:
    Собственно БЕМ ни что иное, как попытка бородатых кодеров из Яедекса применить парадигму ООП (объектно-ориентированного программирования) на процесс верстки. А если более точно то подвид ООП - КОП (не мент, компонентно-ориентированное программирование). И должен признаться, полностью даже удачная попытка.

    Что мы имеем:
    БЭМ-сущность, она же блок, а он же объект, который также известен как компонент или модуль, отвечающий принципу абстракции ООП - А простыми словами, это часть нашей веб-страницы на которую мы разок глазом бросили и особо не задумываясь можем ее выделить как нечто самодостаточное. То, что можно описать одним словом. И слово это будет одновременно и названием, и не глядя на картинку сделает понятным как блок может выглядеть, да еще и ко всему этому опишет его функции и принцип его работы. Вместе с тем его можно переиспользовать в разных местах этой страницы, или на других страницах сайта.
    Пример:
    - Алло, Алекс, я зарегистрировался на тостере, как здесь задать вопрос?
    - Да, проще простого, жмешь на кнопку 'Задать вопрос' спрашиваешь и жмешь кнопку "отправить".

    Таким образом ты не глядя в монитор, а я только что увидев этот сайт впервые, прекрасно друг друга поняли. Потому что на сайте есть ярко выраженный, самодостаточный, элемент пользователь интерфейса - блок кнопка.

    - Эй, Алекс, а помнишь тот сайт который мы сдали на прошлой неделе?
    - Ну да, еще даже исходники на рабочем столе валяются.
    - Супер, заказчик просил кнопки в формах поменять из брендового-зеленого на более яркий зеленый, а то что-то ему в глаза не бросается. :) И ту кнопку, которая в шапке "Узнать больше" надо бы отцентрировать.
    - Ок, три минуты, у нас же там все по less-bem, чики-пики.

    В данном случае ни ты ни я не помним ни точной реализации кнопок ни реализации таблиц, нас вообще не интересует что там внутри, какие теги использовались, сколько там инпутов и тп. Мы абстрагируемся от более примитивного к более осмысленному. Соответственно, когда будешь редактировать, будешь делать это не методом - пальцем в небо. А попросту читая по названиям классов. Сначала найдешь клас header дальше в нем класс button.
    Блок button - это кнопка в общем, он задает общий скелет, шаблон по принципу которого выглядят другие. В идеале туда попадают стили для ресета стилей браузера, ну и еще что-то, если оно присутствует во всех кнопок на макете.
    (схема пример)
    /* HTML types */
    
    <a class='button' href='#'>Кнопа</a>
    <button class='button' href='#'>Кнопа</button>
    <input class='button' type="submit" value="Кнопа">
    /* bem entity */
    
    .button{
                                     // reset
      user-select: none;
      display: inline-block;
      text-decoration: none;
      touch-action: manipulation;
      
                                     // common
      padding: 0.5em 1em;
      border-radius: 2em;
      text-align: center;
    }
    
    /*        _MODS_       */
    // SIZE (SCSS)
    .button{
       &_size_s{
         font-size: 1rem;
         }
       &_size_l{
         font-size: 2rem;
         }
    }
    
    // COLOR
    .button{
      &_primary{
        background: #607D8B;
        color: #ffffff;
        }
      &_secondary{
        background: #8BC34A;
        color: #ffffff;
        }
    }
    
    // PARENT__BLOCK
    .header{
        &__button{
          display: block;
          width: 200px;
          margin: 0 auto;
         }
    }

    codepen.io/kovbassa/pen/ObrqZv?editors=1100

    Дале нас просят изменить что-то в виде кнопок.
    Какие - брендового цвета, какие нужно - ярко зеленые. Все что какой, какая, какие итп .. - это модификатор .button__mod-name, здесь и прямоугольные и колор и закругленные и большие и маленькие. Пример, сделаем книпкы в формах заметнее.
    <button class="button button_accented button_xl">text</button>
                 // common, color,            size

    А теперь отцентрируйте кнопку в хедере.
    .button - скелет всех кнопок, где его конкретный случай будет в шапке, ему все равно.
    button_mod - одьожки кнопок, одна зеленая, другая красная, а там большая итд ..
    Всповним как стоит задача: отцентрировать кнопку в шапке.
    То есть шапка .header а у нее есть элемент .button, который должен быть по середине.
    Отсюда:
    <header>
    <button class="button button_brand header__button" >text</button>
                 //common, color,        local position
    </header>

    На конец - блоки могут состоять, как из меньших блоков так и из элементов. Элементы не могут иметь своих блоков, или элементов. Один DOM узел (html тег) может быть одновременно и блоком и элементом родительского блока.
    Относительно размеров, лучше, когда размеры задает скелет страницы, тобиш сетка. Поэтому старайся делать блоки по максимуму резиновыми в ширину. Старайся оперировать относительными величинами (%, em, rem) а не абсолютными - px.
    А вообще не так важно правильно ты используешь BEM или нет, важнее стабильность стиля. Если начал верстку в определенном стиле, старайся придерживаться его до конца. Например хорошей практикой вертикального позицонування элементов на странице будет использование только margin-bottom, или только margin-top. А не все в кучу и margin's collaps повсюду в итоге.
    Ответ написан
    2 комментария
  • Как вывести сообщение о благодарности после того как человек сделает шаринг в соцсети?

    movasyl
    @movasyl
    semper tiro
    ИМХО, пережиток вчерашнего дня все эти ваши шаринги в соцсети, всплывающие просьбы куда-то там подписаться и что-то лайкнуть...
    Ответ написан
  • Какие инструменты помимо препроцессоров позволяют повысить скорость и качество вёрстки?

    movasyl
    @movasyl
    semper tiro
    1. bem подход (структура + нейминг)
    2. webpack
    Ответ написан
    Комментировать