Задать вопрос
  • Не работает gulp таск?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Перепешите Ваш serve в соответствии с 4 версией:

    gulp.task('serve', function(){
      browserSync.init({
         server: './src',
         notify: false,
         host: '185.27.134.11'
    });
      gulp.watch('src/sass/**/*.sass', gulp.series('sass'));
      gulp.watch('src/*.html', gulp.series('название таска, который обрабатывает html'));
    })


    parallel task-и в потоке выполняются вместе.
    series тут сперва выполнится первый task, потом второй и т.д.

    Так же, для практики, попробуйте написать сами дефолтный таск.
    Ответ написан
    Комментировать
  • Что такое webpack dev server?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    С этой штукой Ты сможешь разрабатывать приложения с высокой скоростью и комфортом.
    Webpack Dev Server позволяет тебе запускать локальный сервер (на твоем ПК) и следить за изменениями всех, необходимых для разработки файлов, автоматически. То есть, тебе не придется перезапускать проект, чтобы обновить изменения.

    в консоль пишешь:
    npm i webpack-dev-server

    в package.json в поле scripts добавляешь вот такие вот команды:
    "scripts": {
        "commandName": "webpack-dev-server",
      }

    Где commandName название твоей команды.

    Простой конфиг:
    devServer: {
            port: 8888, // определяет порт 
            overlay: { // показывает ошибки или предупреждения при разработке
                warnings: boolean,
                errors: boolean
            },
            open: true, // открывает окно браузера
        }

    и еще куча многих опций, типа http/https/https2/hot/host/filename и т.д.
    Ответ написан
    Комментировать
  • Как открыть выпадающий список при наведении мыши?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    <select class="form-control" @mouseover="метод">
      <option>Default select</option>
    </select>
    Ответ написан
    Комментировать
  • Что такое обратный вызов в программировании?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Все очень просто:
    Вы правильно сказали, что это функция, передающаяся как аргумент в другую функцию:
    пример с js
    function  first(callbak){
    ----здесь пишем код функции----
    ---- здесь можно записать код "функции обратного вызова" 
    и она сработает тогда, когда выполнится функция first()----
    }

    Простым языком - есть одна функция и у нее в параметре другая. Сперва выполнится сама функция, а потом та, которая является аргументом этой функции.
    Ответ написан
    Комментировать
  • Почему gulp-pug не обновляется?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Предлагаю сделать так:
    var browserSync  = require('browser-sync').create()
    var bsConfig = {
    		server: {
    			baseDir: 'app'
    		},
    		notify: false,
    		open: false
    	}; 
    
    gulp.task('watch', function(){
    	browserSync.init(bsConfig);
    	gulp.watch("app/pug/*.pug", gulp.parallel("pug"));
    })

    Watcher предлагаю использовать таким способом)
    Ответ написан
    Комментировать
  • Почему Не работает gulp-autoprefixer?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Опечатка на 37 строке. Gulp и никто еще не знает такую комманду)
    browsers
    Ответ написан
    Комментировать
  • Почему выводится ошибка при выполнение нескольких тасков в одном?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Вы используете 3 версию Gulp.
    Чтобы решить Вашу проблему, нужно:
    • Либо удалить Gulp 4 и установить прошлую версию Gulp 3.9.1
    • Либо остаться на прежней версии и привыкнуть к новому синтаксису.


    Если Вы хотите сделать шаг по первому варианту, Вам придется ввести такую комманду в консоль:
    npm uninstall -g gulp && npm i -g gulp@3.9.1 и код Ваш заработает.
    Иначе оставьте свой Gulp 4 и перейдите по этой ссылке и прочитайте инструкцию.

    Вот Вам код для Вас Gulp 4:
    gulp.task('watch', function(){
    	browserSync.init({
          сюда конфиг вашего сервера
    });
    	gulp.watch("Путь к файлам Html", gulp.series('html'));  // <--- В кавычках название таска
    	gulp.watch("Путь к файлам CSS", gulp.series('prefix'));
    })


    Oбъясню на счет parallel и series. То есть в первом случае Ваши task-и в потоке выполняются вместе. А в другом случае, сперва выполнится первый task, потом второй, третий и до конца.
    Ответ написан
    Комментировать
  • Как переместить картинку в css?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Таакс, смотря, что именно вы хотите:
    • Пододвинуть картинку в блоке, используя свойство margin
    • Позиционировать картинку относительно элемента, используя свойство:
      position: relative
      позже можете писать свойства:
      top: значение в px | em | % | rem | pt и т.д.;
      left, right и bottom так же


    • Позиционировать картинку независимо элемента, используя свойство:
      position: absolute
      позже, так же, можете писать свойства:
      top: значение в px | em | % | rem | pt и т.д.;
      left, right и bottom так же



    Почитайте так же (тут вкратце):
    Позиционирование
    Ответ написан
    Комментировать
  • Почему не появляется зеленый блок?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Что Вы именно хотите сделать?
    Вы сместили этот зеленый блок ниже на320px.
    Уберите в классе .central-menu свойство margin-top: 320px
    А чтобы задавать свойство для дочерних элементов, можно писать либо так:

    parent > child{
      property : value
    }

    или так:
    parent child{
      property : value
    }


    Если хочется задать свойство к одному "ребёнку", то можно сделать так:

    parent::nth-child(child's number){
      property : value
    }


    Например:
    Есть структура

    ul.list
      li.list__item
      li.list__item
      li.list__item
      li.list__item

    Тут вы можете задать свойства толькo для первого li, используя правило ввыше:

    .list::nth-child(1){
      padding: 0 0 0 20px
    }
    Ответ написан
    4 комментария
  • Как делается подобный скролл на js и чистом css?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Посмотри, Я попробовал сделать и без js:
    Вот код
    Ответ написан
    2 комментария
  • Как адаптировать часть сайта под мобильные устройства?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Все это делается в css media queries. Если вы не умеете верстать сайты, а просить это у умеющих не позволяет бюджет, либо для такой "мелочи" и не хочется тратить вообще либо какую-то копеечку, можно поискать в ынтернети инфу о медиа запросах (media queries). В вашем случае, нужно этой же картинке или блоку, содержащему эту картинку при мелких размерах экрана (мобильных) написать свойства css:

    .block_img{
        display: none
    }


    И этот кусок кода засунуть в медиа-запрос:

    @media only screen and (max-width: 768px){
    .block_img{
        display: none
       }
    }
    Ответ написан
    Комментировать
  • Почему не включается компьютер после чистки?

    andreydobrin
    @andreydobrin Автор вопроса
    Сложно , но это пока
    Дело было в бракованном блоке питания.
    Ответ написан
    Комментировать
  • Почему перестал запускаться browsersync после того как добавил gulp-less?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Можете таск server засунуть, наоборот, в watcher:
    Для простоты, создайте переменную с настройками сервера:
    var config = {
    server: {
            baseDir: "src/"
        }
    }

    Watcher будет выглядеть так:
    gulp.task('watch', function(){
      browserSync.init(config);
      gulp.watch("src/less/*.less", gulp.series("less")); 
    --> x
    })


    Где Я поставил крестик, можно пихать еще файлы для просмотра вместе с методом gulp.series или gulp.parallel. Их разница в порядке выполнения тасков. Я рекомендую использовать gulp.series для подобных тасков.
    Ответ написан
    Комментировать
  • Таск для обновления .html/.js на Gulp 4?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Для вашей сборки пойдет такой watcher:

    gulp.task('watch', function(){
    	gulp.watch('файлы html', gulp.series('html'));
    	gulp.watch('файлы css', gulp.series('css'));
    	gulp.watch('файлы js', gulp.series('js'));
    	gulp.watch('файлы img', gulp.series('img'));
    })

    Вместо 'файлы [html, css, js&img]' пишите путь до файлов.
    А builder примерно такой:

    gulp.task('build', 
    	gulp.series(
    		сюда можно таск очитки dist папки засунуть, т.е. его название, типа 'clean',
    		gulp.parallel(
    			'html',
    			'styles',
    			'js',
    			'img'
    )));


    Если же таск для очистки не нужен, то можете удалить строку с gulp.series, при этом не забыть удалить все скобки, связанные с этим методом.
    Ответ написан
    Комментировать
  • Ошибка Gulp, что делать?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Прочитайте короткое объяснение ответа ниже, если нужен синтаксис gulp 4

    gulp.task('watch', function(){
      gulp.watch("src/*.html", gulp.series("html"));
      gulp.watch("src/js/*.js", gulp.series("scripts"));
      gulp.watch("src/sass/*.sass", gulp.series("sass"));
      gulp.watch("src/images/*.+(jpg|jpeg|png|gif)", gulp.series("imgs"));
    })


    Oбъясню на счет parallel и series. То есть в первом случае Ваши task-и в потоке выполняются вместе. А в другом случае, сперва выполнится первый task, потом второй, третий и до конца.
    Ответ написан
    Комментировать
  • Не работает Gulp + sass, что за ошибка?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Gulp 4 версии у Вас. А task watch использует синтаксис 3 версии.
    Замените ваш watcher на такой:
    gulp.task('watch', function(){
    	browserSync.init({
    Сюда Ваш конфиг сервера
    });
    	gulp.watch(путь до стилей, gulp.series('style'));
    })
    Ответ написан
    Комментировать
  • Почему возникает ошибка в gulp 4 The following tasks did not complete?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    gulp.task('removedist', function (done) {
        del.sync('dist');
        done();
    });

    Нужно знать, что фунция завершилась. Если не помогло, то напишите, что вышло после моего кода.
    Если получили 4 версию gulp, то task для вашей сборки должен выглядеть так:

    gulp.task('build', 
    	gulp.series(
    		'removedist',
    		gulp.parallel(
    			'imagemin', 
            'styles', 
            'scripts'
    )));


    Отметье, если помогло. Если появятся вопросы, отпишитесь. Если появится проблема, так же. Вы должны скопировать этот код и, может быть, доработать его под Вашу сборку.
    Ответ написан
    1 комментарий
  • Почему не работает @media?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Вы создали квадрат, который отключается, когда ширина окна будет больше 768px. Проверьте снова, используя резайзер прям в окне либо инспектор во вкладке debug и включите device-toolbar и управляйте шириной окна.
    Ответ написан
    Комментировать
  • Как поправить синтаксис кода gulp3 под gulp 4?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    gulp.task('watch', function(){
    	browserSync.init(config);
    	gulp.watch(path.watch.html, gulp.series('html:build'));
    	gulp.watch(path.watch.scss, gulp.series('scss:build'));
    	gulp.watch(path.watch.css, gulp.series('css:build'));
    	gulp.watch(path.watch.js, gulp.series('js:build'));
    	gulp.watch(path.watch.images, gulp.series('images:build'));
      gulp.watch(path.watch.fonts, gulp.series('fonts:build'));
    })

    Если вы не смотрели выпуск, в ссылке на ответ выше, то объясню на счет parallel и series. То есть в первом случае Вашиtask-и в потоке выполняются вместе. А в другом случае, сперва выполнится первый task, потом второй, третий и до конца.
    В build можно сделать так:

    gulp.task('build', 
    	gulp.series(
    		'clean:build',
    		gulp.parallel(
    			'html:build',
    			'css:build',
    			'js:build',
    			'images:build',
    			'fonts:build'
    )));


    Здесь сперва чистится папка dist, а потом собирается продакшн.
    Попробуйте использовать и отпишитесь и отметьте, если поняли суть)
    Ответ написан
    Комментировать
  • Почему не отображается псевдоэлемент befor?

    andreydobrin
    @andreydobrin
    Сложно , но это пока
    Вместо классаitem-web в третьем элементе напишите item-security в стилях:

    .item-web::before {
      content: "";
      background: url(/img/Icon-Laptop.png) no-repeat 15px;
      display: block;
      margin: auto;
      width: 70px;
      height: 70px;
      border: 4px solid #f2d048;
      border-radius: 50px;
      opacity: .8; }
    
    .item-security::before {  < ----- CЮДА
      content: "";
      background: url(/img/Icon-Locked.png) no-repeat 15px;
      display: block;
      margin: auto;
      width: 70px;
      height: 70px;
      border: 4px solid #f2d048;
      border-radius: 50px;
      opacity: .8; }
    Ответ написан
    1 комментарий