Задать вопрос
  • Попросили проверить код, на что смотреть нужно?

    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 комментариев
  • Кавычки по стандартам HTML?

    27cm
    @27cm
    TODO: Написать статус
    Используйте двойные кавычки, это уже стало негласным стандартом. А валидны оба варианта.
    Ответ написан
    3 комментария
  • Выявляли ли вы сезонность заказов на зарубежном фрилансе?

    @Siberian_Bear Автор вопроса
    Искал похожую тему - не нашел.
    Только эту добавил - и сразу в "похожих" выбило похожий вопрос На фрилансе бывают просадки?
    Ответ написан
    Комментировать
  • Каким образом формируется раздел "Recommended Jobs" на Upwork?

    @abcyu
    Разработчик
    Random, судя по тому какой бред мне предлагают.
    Ответ написан
    Комментировать
  • Какие ресурсы с новостями по web-разработки вы знаете?

    edward04
    @edward04
    Начинающий ninja frontend
    smashingmagazing.com
    html5rocks.com
    сайт mdn
    блоги типа Пола Айриша и других ниндзя
    code.tutsplus.com/articles/33-developers-you-must-...

    dmitry.baranovskiy.com

    https://www.digitalocean.com/company/blog/20-devel...

    addyosmani.com/blog

    https://github.com/mr-mig/ru-it-chats

    css-live.ru

    www.webmonkey.com
    frontendfront.com

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

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

    берете и гуглите, нет на русском - пишите по английски, не знаете буржуйский- есть гугл транслэйт.

    PS Извиняюсь за ошибки -писал в порыве гнева.
    Ответ написан
    16 комментариев
  • На фрилансе бывают просадки?

    dmitry_pavlov
    @dmitry_pavlov
    World-class .NET freelance contractor (remotely)
    На фрилансе бывает всякое. Надо иметь финансовую подушку безопасности на пару-тройку месяцев хотя бы. Под рождество все действительно замирает на западе. Многие берут дополнительные отпуска и уезжают с семествами куда-то. Всем не до работы. В этот период лучше иметь уже текущий заказ, если сами конечно не хотите отдохнуть.
    Ответ написан
    Комментировать
  • На фрилансе бывают просадки?

    xmoonlight
    @xmoonlight
    https://sitecoder.blogspot.com
    "Просадок" по прямым заказам постоянных и новых клиентов, идущих прямиком на e-mail - не наблюдаю: очередь стоит постоянно, хоть отбавляй.
    1. Возможно, что Вами выбран нецелевой Клиент или продукт/услуга, на которых Вы специализируетесь или у Вас недавно стал завышенный спрос за работу.
    2. Скорее всего, сейчас пошла предпраздничная подготовка к НГ с шопингом и всех "разморозило" от проектов.
    Ответ написан
    Комментировать
  • На фрилансе бывают просадки?

    ManWithBear
    @ManWithBear
    Swift Adept, Prague
    У всех рождество на носу. До вас нет дела.
    Ответ написан
    2 комментария
  • Чистый JavaScript, он жив?

    bootd
    @bootd
    Гугли и ты откроешь врата знаний!
    Знаком с jQuery/AngularJS/JS

    но больше всего привлекает и нравится работа именно на JS

    Эм, все правильно понял? Вы пишите на jQuery/AngularJS/JS, но больше всего любите писать именно на js? Что-то тут не так!

    Терь по делу! Все, что будет дальше - это сугубо мое мнение!
    Вообще очень странный тренд, чистого js. А из вашего списка jQuery/AngularJS - это не чистый js? Возможно меня сейчас все зафейлят, но все же.

    В чем отличие jQuery от js? Вы можете его назвать? Я никакого не вижу. jQuery - это же всего лишь js обертка, которая позволяет использовать одни и те же функции в более удобном виде. Но написан то он на js, а значит это чистый js!!

    Например: напишем простейшую функцию скрытия элемента
    var hide = function(elem){
    	document.getElementById(elem).style.display = 'none';
    };
    
    hide('text');

    на jQuery
    $('#text').hide();

    Эти 2 функции делаю одно и тоже. Просто скрывают указанный элемент. И весь jQuery написан из таких функций, которыми приходится пользоваться постоянно!

    Получается если я напишу мини мини фреймворк на js для своего проекта, что бы не писать постоянно повторяющийся код и буду использовать его методы как при использовании jQuery, то я перестану использовать "чистый" js? Где в вашем понимании грань?
    Ответ написан
    5 комментариев
  • Как сделать ссылку, которая не перезагружает страницу?

    web-verzus-team
    @web-verzus-team
    Full Stack Developer
    <a href="javascript:void(0)"> </a>
    Ответ написан
    Комментировать
  • Функции на php?

    YardalGedal
    @YardalGedal
    yeah boy
    function writtetwoLog($dtime){ 
        $entry_line = "$dtime - Сайт все еще не доступен \n";
        $fp = fopen("logs.txt", "a");
        fputs($fp, $entry_line);
        fclose($fp);
    }
    
    writtetwoLog($dtime);


    либо такой вариант(но крайне не рекомендую)

    // $dtime = ...
    function writtetwoLog(){ 
        global $dtime; 
        $entry_line = "$dtime - Сайт все еще не доступен \n";
        $fp = fopen("logs.txt", "a");
        fputs($fp, $entry_line);
        fclose($fp);
    }
    Ответ написан
    1 комментарий
  • Существуют ли какие нибудь хорошие сервесы для описания CSS с примерами?

    afishr
    @afishr
    make const not var
    Ответ написан
    Комментировать
  • Как узнать номер элемента в цикле?

    dimonchik2013
    @dimonchik2013
    non progredi est regredi
    так и будет
    print ($key.$ky);
    или что там нужно
    Ответ написан
    Комментировать
  • Где проверить знания по php?

    Denormalization
    @Denormalization
    У upwork куча тестов по языкам. Стоит глянуть.
    Ответ написан
    2 комментария
  • Что значит символ & перед селектором?

    nazarpc
    @nazarpc
    Open Source enthusiast
    Значит что название тэга &.
    Но вероятнее всего, что это не CSS, а SCSS, в котором так обозначается родительский селектор.
    Ответ написан
    7 комментариев
  • Можно ли сделать такую сетку?

    nazarpc
    @nazarpc
    Open Source enthusiast
    Да, можно с display: flex; flex-direction: column;, если HTML менять нельзя - то order: x поможет изменить порядок элементов по вашему желанию.
    Ответ написан
  • Кто-нибудь обращался в службу поддержки Freelancer.com?

    Не самые приятные впечатления - много лишнего как по интерфейсу так и по платежам (купи курс, купи тест, купи топ, купи то, купи сё). Только одно это меня остановило там работать.
    Смешно читать, как многие пишут, что там то баги, то деньги не дошли, то кинули и биржа не разрулила. При всём при том, что там куча платных услуг ещё навязывается, о чём я выше написал.
    Ответ написан
    8 комментариев
  • Как новичку найти клиентов на upwork и на что рассчитывать?

    Punkie
    @Punkie
    Почитайте блог: jff.name . В своё время он мне очень помог. И автор у него отзывчивый - всегда подскажет.
    Ответ написан
    1 комментарий
  • Нужно ли складывать много маленьких JS файлов в один большой?

    Stalker_RED
    @Stalker_RED
    Параллельная загрузка может дать выигрышь только в том случае, если вы не упретесь в максимальное число соединений. А с учетом того, что кроме js файлов нужно грузить еще и css, изображения, и другие ресурсы упереться в лимит довольно легко.
    Вот не очень свежий (~два года назад) но список поддерживаемого кол-ва соединений onedev.net/post/231
    Ответ написан
    Комментировать
  • Нужно ли складывать много маленьких JS файлов в один большой?

    IonDen
    @IonDen
    JavaScript developer. IonDen.com
    Не только можно но и нужно:
    1. Собирается через Grunt/Gulp
    2. Минифицируется
    3. Сжимается gzip-ом
    4. Кэшируется браузером
    5. Использует только 1 реквест на сервер.

    При загрузке сайта у разных браузеров есть ограниченное количество одновременно выполняемых запросов (на мобилах вообще мало), кроме того у вас там ведь не только JS файлы, есть еще css, картинки и т.п. Они все встают в очередь на загрузку. Так что, в 99,9% случаев, загрузка одного JS файла будет всегда быстрее чем загрузка нескольких.
    Ответ написан
    Комментировать