Squeak.ru - шаблоны программирования

Исключение Laravel добавляет значения из результатов модели

Laravel имеет возможность добавить массив $appends к каждой модели, делая дополнительные значения автоматически доступными, как если бы они были атрибутами базы данных, путем добавления средств доступа для каждого.

Обычно это очень удобно, за исключением того, что в этом случае мне нужно ТОЛЬКО получить поля, которые я поместил в select(), потому что DataTables ожидает только то, что я ему отправляю.

Пример:

Item::select(['image', 'name', 'color']);

Возвращает добавленные поля после color в атрибутах.

Как принудительно исключить добавленные значения при возврате результатов?

Или, в качестве альтернативы, как заставить DataTable игнорировать определенные атрибуты?

Не уверен, что это наименее затратный по времени маршрут.

В настоящее время используется пакет yajra/laravel-datatables для отправки данных в запрос jQuery DataTables AJAX.


Ответы:


1

Вы можете вызвать каждую функцию в объекте коллекции, а затем использовать метод setHidden, чтобы исключить нежелательные поля, подобные этому.

$item= Item::select(['image', 'name', 'color'])->get()->each(function($row){
                    $row->setHidden(['appendedField1', 'appendedField2']);
                });

А для yajra/laravel-datatables вы можете использовать что-то вроде

$item= Item::select(['image', 'name', 'color']);
return Datatables::of($item)->remove_column('appendedField1');
29.10.2015
  • К сожалению, я не могу использовать get() для результатов до перехода к пакету yajra/laravel-datatables, который передает его в пакет jQuery DataTables через AJAX. Забыл упомянуть этот пакет. В противном случае это было бы идеальным решением! 30.10.2015
  • Я думаю, вы можете использовать метод remove_column('columnName') в пакете yajra/laravel-datatables. 30.10.2015
  • Чтобы решить эту проблему, я сделал $appends общедоступным в своей модели Item, создал переменную $DT = Datatables::of($items);, а затем использовал call_user_func_array([$DT, 'removeColumn'], $items->first()->appends); перед возвратом make(). Должен вызываться таким образом с yajra/laravel-datatables-oracle v3 при передаче массива. 30.10.2015
  • Исправление, не могу сделать это таким образом, или это испортит нумерацию страниц. Пришлось создать для него статический метод, который я разместил в решении. +1 ваш ответ за помощь в поиске полного решения. 30.10.2015

  • 2

    Чтобы решить эту проблему, я добавил этот метод в свою модель Item:

    public static function getAppends()
    {
        $vars = get_class_vars(__CLASS__);
    
        return $vars['appends'];
    }
    

    Затем использовал следующий код в контроллере:

    $items = Item::select(['image', 'name', 'color']);
    
    $DT = Datatables::of($items);
    
    call_user_func_array([$DT, 'removeColumn'], Item::getAppends()); // Has to be called this way with yajra/laravel-datatables-oracle v3.* if passing an array.
    
    return $DT->make(true);
    
    30.10.2015
    Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

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

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...