• Как сделать геттер-функцию?

    0xD34F
    @0xD34F
    Зачем функция? Делаем геттер, представляющий посты, сгруппированные по категориям:

    getters: {
      postsByCatId: ({ posts }) =>
        posts.reduce((acc, n) => (
          (acc[n.catId] = acc[n.catId] || []).push(n),
          acc
        ), {}),
    },

    Соответственно, в компоненте добавляем свойство, представляющее id категории, и вычисляемое свойство, представляющее массив постов. Можно оформить миксин, если подобное нужно в разных компонентах:

    const postsMixin = {
      data: () => ({
        catId: null,
      }),
      computed: {
        posts() {
          return this.$store.getters.postsByCatId[this.catId] || [];
        },
      },
    };
    Ответ написан
    2 комментария
  • Обязан ли человек предоставлять пароли от собственного ноутбука следственным органам?

    uvelichitel
    @uvelichitel
    habrahabr.ru/users/uvelichitel
    Кажется в рамках законодательства вы не обязаны помнить пароли. Плохая память вроде не преступление.
    Ответ написан
    Комментировать
  • Этот код сильно ужасен)?

    usdglander
    @usdglander Куратор тега PHP
    Yipee-ki-yay
    После include "bitrix.php"; да. Ужасен. Не глядя.
    Ответ написан
    2 комментария
  • Как при нажатии на кнопку выбирать элемент объекта и выводить его?

    0xD34F
    @0xD34F Куратор тега React
    const [ active, setActive ] = useState(null);
    const item = test.title[active];
    
    const onClick = e => setActive(e.target.dataset.id);

    Кнопки:

    {Object.keys(test.title).map(n =>
      <button key={n} data-id={n} onClick={onClick}>{n}</button>
    )}

    Выбранный элемент:

    {item && <div>{item.title} ---- {item.category}</div>}
    Ответ написан
    5 комментариев
  • Как реализуется подобная механика в VueJS?

    @Wezalal
    Ответ написан
    Комментировать
  • Зачем асинхронность?

    WinPooh32
    @WinPooh32
    Stack Overflow answer searching expert
    но для чего ее можно использовать еще?

    Например, заваривание чая человеком:
    Включаете чайник с водой. Пока вода греется, кладёте пакетик чая, сахар в кружку. Тут можно и посуду начать мыть. Когда чайник выключится, наливаете в кружку и размешиваете. Продолжаете мыть посуду.

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

    Замените человека на поток, чайник с водой на сетевые запросы, кружку с чаем, посуду на обработку данных.
    Ответ написан
    Комментировать
  • Как просто реализовать push-уведомления на сайте?

    sergey-gornostaev
    @sergey-gornostaev
    Седой и строгий
    Использовать websocket'ы.
    Ответ написан
    Комментировать
  • Поговорим о static?

    @l4m3r

    Когда гораздо проще сделать так:
    MyObject::myMethod();


    Если myMethod не влияет на внутреннее состояние объекта (изменяет members) - то так и надо делать (static).
    Пример статических:
    User::getStatusList() -- возвращает список возможных статусов для всех пользователей
    User::findById() -- ищёт в базе по ID и возвращает нового пользователя

    Пример нестатических:
    $user->setName('xxx'); мы работаем только с текущим пользователем
    $user->delete() мы работаем только с текущим пользователем
    Ответ написан
    8 комментариев
  • Бросать исключение или возвращать коды ошибок/успеха? Является ли исключением то, что метод не может выполнить свою задачу?

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

    Вы также всегда имеете возможность посмотреть популярные open-source решения и убедиться какой точки зрения придерживается сообщество.
    Ответ написан
    1 комментарий
  • Чем laravel от бутстрапа отличается?

    @jazzus
    Laravel это мозг, сердце, печень, почки. Ты их не видишь, но они есть (почти всегда). Бутстрап – лицо, кожа, волосы. Ты их видишь, но смысла в них без сердца немного. Потому что они связаны. Как печень работает, так и кожа-рожа выглядит. Как мозг работает так и человек себя ведет. Так же и с сайтом. Например, форма авторизации вк. Ты ее видишь. Кнопочки, цвета, формы. Это типа Bootstrap. Когда ты вводишь свои данные и нажимаешь кнопку отправить они улетают в Ларавел на сервер. Он эти данные получает и начинает проверять. Если то, если это, какой телефон, телефон ли и т.д. Это программист написал логику в Ларавеле на php. Ты эту логику не знаешь и не видишь, но она командует парадом, Bootstrap и всеми действиями юзера на сайте.
    Ответ написан
    1 комментарий
  • Бросать исключение или возвращать коды ошибок/успеха? Является ли исключением то, что метод не может выполнить свою задачу?

    index0h
    @index0h
    PHP, Golang. https://github.com/index0h
    Бросать исключение или возвращать коды ошибок/успеха?

    Бросать исключение.

    Является ли исключением то, что метод не может выполнить свою задачу?

    Конечно же.

    Но узнать является ли сумма(amount) корректной по-хорошему можно только в браузере/GUI или в Domain слое в самом методе transferMoney().

    К фронту не должно быть доверия, данные обязательно нужно проверять.
    Аргументы метода лучше проверять И на тип И на граничные значения. Например ваш amount по идее должен быть float + больше, или равен 0. Если amount таковым не является - бросайте исключение. Логика выше должна была это отсечь, еще на этапе валидации данных запроса.

    В transferMoney() нужно извлечь данные пользователя(который пересылает деньги) из БД и проверить есть ли у него такая сумма.

    Если ваш метод непосредственно имеет дело с кошельком пользователя - проверка в нем должна быть обязательно. Если же этот метод - только посредник, подобную проверку можно сделать в другом месте.

    Получается в методе transferMoney() есть одна причина неудачи, а что если добавится ещё одна причина, например, пользователю запрещено временно пересылать деньги?

    Тот же комментарий, что и про баланс.

    Поскольку они ожидаемые, то бросать исключения не логично.

    Почему же? Логика выше сможет обработать ваши ожидаемые исключения и через множественный catch определить, что не так. Это вполне нормально, и даже удобно.

    В случае если бы была одна причина неудачи, то можно было бы просто вернуть false.

    Очень хреновая практика. Как вы определите в вызывающем коде, что пошло не так? Что "false"? Баланса не хватает, нельзя делать покупки, или Меркурий в ретрограде?

    возвращать что-то на подобии [false, $error] и [true, null]

    Для php - это очень кривой подход. По двум причинам:
    1. Вы расширяете интерфейс метода, просто так.
    2. Вы нагружаете вызывающий код дополнительными обвязками проверок, опять же просто так.
    В этом нет смысла так как есть механизм try-catch, который отлично решает это задачу.
    Вот пример, допустим ваш transferMoney($amount, User $recipient) должен возвращать объект транзакции, пусть его сигнатура будет:
    transferMoney(float $amount, User $recipient): Transaction
    Вызывающий код знает, что он обязан в конце получить транзакцию, а если что-то пойдет не так - будет исключение, нет смысла в дополнительных проверках, а что если первый элемент массива false, а что если он true, но второй элемент не null, а что если второй элемент не тот, что ожидалось, а что если первый элемент - строка, и т.д.

    transferMoney() не должен подстраиваться под слой повыше, в нём не должно быть никаких предположений, что пользователь введёт что-то правильно или неправильно, он просто должен ожидать только валидные данные, если они неправильные, то это исключительная ситуация.

    Верно

    То есть transferMoney() выбросит исключение, которое подымется до Controller'a, и на основе которого Controller отправит 400 Bad Request и причину неудачи.

    Угу

    Или всё таки первый подход к проблеме лучше(первый абзац)?

    Первый подход - это путь боли, ошибок и отчаянья.

    Вот вам еще чтива: https://github.com/index0h/php-conventions
    Ответ написан
    1 комментарий
  • Чем можно проводить проверку в PHP?

    FanatPHP
    @FanatPHP
    Чебуратор тега РНР
    Я думаю, человек спрашивает про операторы ветвления.
    То есть нужен тернарный и его сокращённые формы: элвис, и объединения с null

    (условие) ? значение 1 : значение 2; // если условие, то вернем значение 1, иначе значение 2
    $var ?:  значение 2; // если $var не пустое, то вернем его, если нет - то значение 2
    $var ??  значение 2; // если $var существует, то вернем его, если нет - то значение 2
    Ответ написан
    2 комментария
  • Какие различия между undefined, null, NaN?

    @kyzinatra
    Все просто.
    undefined и null это 2 специальных типа данных. они равны только друг другу при == (не строгом сравнении) и не равны ничему более.
    NaN - то есть not a number(не число).(Я думаю все и так ясно). Появляется при ошибки в вычислениях.
    let num = "Hi" * 12;
    console.log(num) // NaN
    Можешь почитать:
    https://learn.javascript.ru/types
    https://learn.javascript.ru/type-conversions
    Ответ написан
    Комментировать
  • Что такое Promise и зачем они нужны?

    Sanasol
    @Sanasol Куратор тега JavaScript
    нельзя просто так взять и загуглить ошибку
    Это обещание.

    Обещаю что отдам(fulfilled) тебе твои деньги, а ты пока подожди, но это не точно(rejected).
    Ответ написан
    Комментировать
  • Безопаснее с VPN или без него?

    markus_saar
    @markus_saar
    CEO at hidemy.name
    Можно исходить из такой логики. У вашего интернет-провайдера есть достаточно много информации о вас: договор с паспортными данными, информация в какой квартире находится точка доступа, mac-адрес вашего роутера и мн. др.

    Вместе с этим, по закону он обязан сохранять весь ваш трафик как минимум за последние полгода, а обычное текстовое логирование "какие сайты открывал, к каким ip-адресам подключался и когда" может храниться ещё дольше.

    Посещение сайтов https действительно предотвращает сохранение информации о вашей активности на этих сайтах, но не предотвращает сохранение самого факта посещения их, времени, количества скачанной и отправленной информации. Сайты http, и отправленные на них данные, будут сохранены полностью в открытом виде. Иногда можно нарваться на https сайты, в которых, по недосмотру, формы могут отправлять данные в открытом виде по http. Благо, современные браузеры научились ругаться на такое.

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

    При использовании VPN, интернет-провайдер и владелец точки Wi-Fi не будут иметь доступа не только к зашифрованному трафику, но и не увидят вообще никакой разборчивой активности. Только факт подключения к некоему IP-адресу (vpn-серверу) и поток шифрованного трафика в обе стороны.

    К выбору VPN-сервиса подойдите также ответственно. Изучите отзывы, как давно сервис на рынке и были ли инциденты с утечками, политика конфиденциальности — это минимум. И, конечно же, бесплатных VPN не бывает.
    Ответ написан
    2 комментария
  • Какой сервис приема платежей из Европы в Россию выбрать?

    DevMan
    @DevMan
    палка же. если условия удовлетворяют и вам важно доверие от клиентов.
    Ответ написан
    Комментировать
  • Безопаснее с VPN или без него?

    CityCat4
    @CityCat4 Куратор тега VPN
    //COPY01 EXEC PGM=IEBGENER
    Если нет доверия...то правильно ли использовать VPN

    Единственный VPN, к которому может быть доверие - это тот, который настраивали Вы сами. Ко всем остальным VPN доверия быть не должно - потому что Вы не можете на самом деле проверить, что они делают и как они хранят свои логи (а как показывает практика, когда контроль невозможен, то возможны самые неестественные формы заработка - то есть сливать будут все и всем подряд)

    Кстати, ссылка в ответе выше - замечательная и всем рекомендуется к прочтению.
    Ответ написан
    4 комментария
  • Оцените сайт. Что добавить, что улучшить?

    IgorPI
    @IgorPI
    Девочки красивые!
    5+
    Ответ написан
    Комментировать
  • Как сделать из домашнего пк сервер VPS?

    Бесполезная затея, кому что-то нужно возьмут в Европе.
    Ответ написан
    Комментировать