• А как вы сжимаете картинки для googleSpeed?

    @Fixid
    В подвале googleSpeed можно выкачать все ресурсы сайта в одном архиве уже оптимизированные гуглом
    Ответ написан
    1 комментарий
  • Как загрузить готовый проект в пустой репозиторий?

    @tagplus5
    git commit -m 'initial commit'
    git push -u origin master

    Ответ написан
    Комментировать
  • Почему после переноса появилась ошибка синтаксиса?

    ThunderCat
    @ThunderCat Куратор тега PHP
    {PHP, MySql, HTML, JS, CSS} developer
    Код файла с ошибкой в студию, экстрасенсы все уехали на битву.
    При обфускации кода в любом случае нужно сделать перенос строки по ";", поменять ; на ; + \n\r , и тогда посмотреть в какой строке ошибка. А так - гадание на говнокоде.
    Ответ написан
    2 комментария
  • Как быстрее освоить Ajax?

    leshikgo
    @leshikgo
    Скорее хорошо владеть JS. Так как при отправке вы должны упаковать правильно эти данные и отправить на сервер. На сервере вы просто принимаете эти данные и работаете с этими данными как вам уже угодно. Собственно там ничего сложного нету.
    Ответ написан
    3 комментария
  • Apache vs Ngnix+FastCGI vs Ngnix+Apache - что производительней для php?

    nginx+phpFPM - однозначно
    Ответ написан
    Комментировать
  • Как лучше подключать стили и скрипты?

    SnaIP
    @SnaIP
    Front-end разработчик
    Используйте сборщики webpack, gulp и настраиваете под себя их, скину вам простенький пример gulpfile.js можете переделать под свой вариант

    'use strict';
    
    var gulp = require('gulp');
    var sass = require('gulp-sass');
    var jade = require('gulp-jade');
    var concat = require('gulp-concat');
    var extender = require('gulp-html-extend');
    var browserSync = require('browser-sync');
    var autoprefixer = require('gulp-autoprefixer');
    
    var pub = './dist/';
    var src = './src/';
    
    gulp.task('js', function () {
        gulp.src(src + 'js/**/*.*')
            .pipe(gulp.dest(pub + 'js/'))
            .pipe(browserSync.stream());
    });
    
    gulp.task('sass', function () {
        gulp.src(src + 'sass/index.scss')
            .pipe(sass({outputStyle: 'compressed'}).on('error', sass.logError))
            .pipe(autoprefixer({
                browsers: ['last 3 versions'],
                cascade: false
            }))
            .pipe(concat('app.css'))
            .pipe(gulp.dest(pub + 'css'))
            .pipe(browserSync.stream());
    });
    
    gulp.task('directory', function () {
        gulp.src(src + 'fonts/**/*.*')
            .pipe(gulp.dest(pub + 'fonts/'));
        gulp.src(src + 'svg/**/*.*')
            .pipe(gulp.dest(pub + 'svg/'));
    });
    
    // gulp.task('jade', function () {
    //     return gulp.src(src + 'templates/jade/*.jade')
    //         .pipe(jade())
    //         .pipe(gulp.dest(pub))
    //         .pipe(browserSync.stream());
    // });
    
    gulp.task('extend', function () {
        gulp.src(src + 'templates/*.html')
            .pipe(extender({annotations:true,verbose:false})) // default options
            .pipe(gulp.dest(pub))
    
    });
    
    gulp.task('sync', function () {
        browserSync.init({
            server: {
                baseDir: pub
            },
            port: '3000',
            ghostMode: false,
            open: false,
            serveStatic: [src]
        });
    
        gulp.watch(
            [ '*.html' ],
            { cwd: pub },
            browserSync.reload
        );
    });
    
    gulp.task('watchers', function() {
        gulp.watch(src + 'sass/**/*.scss', ['sass']);
        gulp.watch(src + 'templates/**/*.html', ['extend']);
        gulp.watch(src + 'js/**/*.*', ['js']);
    });
    
    gulp.task(
        'default',
        [
            'watchers',
            'sass',
            'directory',
            'extend',
            'js',
            'sync'
        ]
    );


    + --------- dist
    /fonts
    /svg
    app.css
    index.html
    + --------- src
    + ---- sass
    + ---- templates
    + -------- partials (layout.html header.html footer.html и тд)
    index.html
    + ---- fonts (просто переносятся в папку dist)
    + ---- svg (просто переносятся в папку dist)
    Ответ написан
  • Где изучить фотошоп для верстальщика?

    @freeman0204
    Не чудите:) скачайте уже https://avocode.com/ и меняйте имейл каждые 14 дней, там намного удобней работать.
    Ответ написан
    1 комментарий
  • Попросили проверить код, на что смотреть нужно?

    index0h
    @index0h
    PHP, Golang. https://github.com/index0h
    Смотря зачем)). Я когда делаю Code Review критерии следующие:

    * Безопасность:
    - Каждый аргумент метода простого типа должен проверяться на тип в случае его проксирования и на граничные значения в случае обработки. Чуть что не так - бросается исключение. Если метод с кучкой аргументов на 80% состоит из поверки из аргументов - это вполне норм))
    - Никаких trigger_error, только исключения.
    - Исключения ДОЛЖНЫ быть человеко-понятны, всякие "Something went wrong" можно отдавать пользователю, но в лог должно попасть исключение со стектрейсом и человеко-понятным описанием, что же там пошло не так.
    - Каждый аргумент (объект) метода должен быть с тайпхинтингом на этот его класс, или интерфейс.
    - За eval как правило шлю на **й.
    - @ допускается только в безвыходных ситуациях, например проверка json_last_error.
    - Перед работой с БД - обязательная проверка данных.
    - Никаких == и !=. Со swtich - единственное исключение, по ситуации.
    - Если метод возвращает не только bool, а еще что-то - жесткая проверка с ===, или !== обязательна.
    - Никаких условий с присваиваниями внутри. while($row = ...) - тоже идет лесом.
    - Магические геттеры/сеттеры разрешаются только в безвыходных ситуациях, в остальном - запрещены.
    - Конкатенации в sql - только в безвыходных ситуациях.
    - Параметры в sql - ТОЛЬКО через плейсхолдеры.
    - Никаких глобальных переменных.
    - Даты в виде строки разрешаются только в шаблонах и в БД, в пхп коде сразу преобразуется в \DateTimeImmutable (в безвыходных ситуациях разрешено \DateTime)
    - Конечно зависит от проекта, но как приавло должно быть всего две точки входа: index.php для web и console(или как-то по другому назваться) - для консоли.

    * Кодстайл PSR-2 + PSR-5 как минимум, + еще куча более жестких требований (для начала все то что в PSR помечено как SHOULD - становится MUST)
    - В PhpStorm ни одна строчка не должна подсвечиваться (исключением является typo ошибки, например словарик не знает какой-то из аббревиатур, принятых в вашем проекте). При этом разрешается использовать /** @noinspection *** */ для безвыходных ситуаций.
    - Если кто-то говорит, что пишет в другом редакторе и у него не подсвечивается, на эти отговорки кладется ВОТ ТАКЕЕЕНЫЙ мужской половой **й и отправляется на доработку)).

    * Организация кода:
    - Никаких глобальных функций.
    - Классы без неймспейса разрешаются только в исключительно безвыходных ситуациях.

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

    * Принципы MVC:
    - Никаких обработок пользовательского ввода в моделях, от слова совсем.
    - Никаких ***ть запросов в БД из шаблонов.
    - Никаких верстки/js/css/sql-ин в контроллерах.
    - В моделях НИКАКОЙ МАГИИ, только приватные свойства + геттеры с сеттерами.
    - В моделях разрешено использовать метод save(при наличии такого разумеется) только в исключительных ситуациях. Во всех остальных - либо insert, либо update.

    * Принципы SOLD:
    - Никаких божественных объектов умеющих во все.
    - Если метод для внутреннего пользования - private, никаких public.
    - Статические методы разрешаются только в случае безвыходности.

    * Принцип DRY разрешено нарушать в случаях:
    - Явного разделения обязанностей
    - В тестах (каждый тест должен быть независимым, на сколько это возможно)

    * Работа с БД:
    - Запрос в цикле должен быть РЕАЛЬНО обоснован.
    - За ORDER BY RAND() - шлю на***й.
    - Поиск не по ключам (конечно если таблица НЕ на 5 строк) запрещен.
    - Поиск без LIMIT (опять же если таблица НЕ на 5 строк) запрещен.
    - SELECT * - запрещен.
    - Денормализация БД должна быть обоснована.
    - MyISAM не используется (так уж)) )
    - Множественные операции обязательно в транзакции, с откатом если чо пошло не так.
    - БД не должна содержать бизнес логики, только данные в целостном виде.
    - Не должно быть нецелесообразного дерганья БД там, где без этого можно обойтись.

    * Кэш должен очищаться по двум условиям (не по одному из, а именно по двум):
    - Время.
    - Протухание по бизнес логике.
    Разрешается по только времени в безвыходных ситуациях, но тогда время - короткий период.
    - При расчете ключей кэша должна использоваться переменная из конфигурации приложения (на случай обновлений кэш сбрасывается кодом, а не флашем кэш-сервера). В случае использования множества серверов - это очень удобный и гибкий инструмент при диплое.

    * О людях:
    - "Я привык писать так и буду дальше" - не вопрос, ревью пройдешь только когда поменяешь свое мнение.
    - "Я пишу в vim-е и мне так удобно" - здорово, код консолью я тоже в нем пишу)) но есть требования к коду, если в них не сможешь - не пройдешь ревью.
    - "Я скопировал этот страшный метод и поменял 2 строчки" - это конечно замечательно, но по блейму автор всего этого метода ты, так что давай без говняшек, хорошо?
    - "Оно же работает!" - вот эта фраза переводится примерно так: "да, я понимаю, что пишу полную хрень, но не могу писать нормально потому, что руки из жо", я правильно тебя понял?))
    - "У меня все работает!" - рад за тебя, а как на счет продакшна?
    - "Там все просто" - не используй слово "просто", от слова "совсем". Вот тебе кусок кода (первого попавшегося с сложной бизнес логикой), где там ошибка (не важно есть она, или нет)? Ты смотришь его уже 2 минуты, в чем проблема, там же все "просто"))

    * Всякое:
    ActiveRecord (это я вам как в прошлом фанат Yii говорю) - полное говно, примите за исходную. По факту у вас бесконтрольно по проекту гуляют модельки с подключением к БД. Не раз натыкался на то, что в тех же шаблонах вызывают save, или update (за такое надо сжигать).
    То, что используется Laravel - это печально((. Что бы выполнить требования приведенные выше, приходится "воевать" с фреймворком.

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

    UPD

    Формализировал данные критерии по ссылочке: https://github.com/index0h/php-conventions
    Ответ написан
    55 комментариев
  • Кэширование nginx на стороне клиента?

    gbg
    @gbg Куратор тега Системное администрирование
    Любые ответы на любые вопросы
    Браузер - не дурак, кэширует по собственной инициативе. Первый раз он скачал, второй раз спросил - "не поменялось ли?", сервер ответил "неа", браузер порадовался и не стал скачивать.

    Если же вы поменяете контент, браузер в ответ на запрос получит снова 200 и будет вынужден закачивать.
    Ответ написан
    Комментировать
  • Yii2 или Laravel?

    SamDark
    @SamDark
    Yii2 core team
    Пробуйте оба и выбирайте самостоятельно. Я могу аргументированно уговорить выбрать любой из этих двух фреймворков, но вы так и будете мучаться «а не ошибся ли я» пока не попробуете оба.
    Ответ написан
    2 комментария
  • Как получить email через API ВКонтакте?

    Jeket
    @Jeket Автор вопроса
    Краткий алгоритм действий:
    1) Регистрируешь приложение в ВКонтакте
    2) Формируешь ссылку как в документации API https://vk.com/dev/auth_sites (если нужен email, то указываешь &scope=email )
    3) После получения кода делаешь запрос на получение access_token, в ответе приходит id и email пользователя
    Ответ написан
    Комментировать
  • Как оценить реальную стоимость проекта?

    Fesor
    @Fesor
    Full-stack developer (Symfony, Angular)
    Ну для начала вам стоит определиться со стеком технологий. То бишь как по мне каждый раз писась велосипед это тоже признак дурного тона. Надеюсь все же вы подразумевали разработку на каком-либо популярном фреймворке. Если так, то подберите расширения для него исходя из опыта (где что встречалось часто). Проект состоит из отдельных задачь, модулей, или частей. Называйте как хотите, оцениваются все же они а не весь проект целиком. По началу вы можете просто прикидывать, но думаю один два проекта у вас не выйдет вменяемой оценки. Это все же с опытом приходит. Запоминайте сколько у вас ушло времени на разработку отдельной части проекта.

    И еще один момент — добавляйте риски. Мол оцененное время умножайте на некий коэффициент. По началу можете взять этот коэффициент равный двойке и постепенно его меняйте исходя из статистики.

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