Как передать данные во все представления в Laravel 5?

67

Я хочу, чтобы некоторые данные по умолчанию были доступны во всех представлениях в моем приложении Laravel 5.

Я попытался найти его, но только найти результаты для Laravel 4. Я прочитал документацию "Совместное использование данных со всеми видами" здесь, но я не могу понять, что делать. Где должен быть размещен следующий код?

View::share('data', [1, 2, 3]);

Спасибо за вашу помощь.

  • 0
    ну, вам нужен стартовый код для управления этим требованием?
  • 1
    Использование заголовка View :: share в поставщике услуг с результатами вызова базы данных приведет к ошибке приложения при запуске обновления базы данных db или попытке запуска в сумерках с недоступным соединением базы данных (длинный рассказ, .env.dusk.local is используется только после запуска поставщика услуг). Как уже упоминалось ниже, базовый контроллер или промежуточное программное обеспечение является лучшим.
Показать ещё 1 комментарий
Теги:
laravel-5

11 ответов

130
Лучший ответ

Эта цель может достигаться с помощью другого метода,

1. Использование BaseController

Как мне нравится настраивать вещи, я делаю класс BaseController, который расширяет собственный Laravels Controller и настраивает там различные глобальные вещи. Все остальные контроллеры затем расширяются от BaseController, а не от Laravels Controller.

class BaseController extends Controller
{
  public function __construct()
  {
    //its just a dummy data object.
    $user = User::all();

    // Sharing is caring
    View::share('user', $user);
  }
}

2. Использование фильтра

Если вам известно, что вы хотите, чтобы что-то настроенное для просмотров по каждому запросу по всему приложению, вы также можете сделать это через фильтр, который выполняется перед запросом - вот как я общаюсь с объектом User в Laravel.

App::before(function($request)
{
  // Set up global user object for views
  View::share('user', User::all());
});

ИЛИ

Вы можете определить свой собственный фильтр

Route::filter('user-filter', function() {
    View::share('user', User::all());
});

и назовите его простым вызовом фильтра.

Обновление по версии 5. *

3. Использование View Composer

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

Просмотр метода композитора может использоваться по-разному, Первый пример может выглядеть одинаково:

Вы можете создать каталог App\Http\ViewComposers.

Поставщик услуг

namespace App\Providers;
use Illuminate\Support\ServiceProvider;
class ViewComposerServiceProvider extends ServiceProvider {
    public function boot() {
        view()->composer("ViewName","App\Http\ViewComposers\TestViewComposer");
    }
}

После этого добавьте этого провайдера в config/app.php в разделе "Поставщики".

TestViewComposer

namespace App\Http\ViewComposers;

use Illuminate\Contracts\View\View;

class TestViewComposer {

    public function compose(View $view) {
        $view->with('ViewComposerTestVariable', "Calling with View Composer Provider");
    }
}

ViewName.blade.php

Here you are... {{$ViewComposerTestVariable}}

Этот метод может помочь только для определенного вида. Но если вы хотите вызвать ViewComposer для всех представлений, мы должны применить это единственное изменение к ServiceProvider.

namespace App\Providers;
use Illuminate\Support\ServiceProvider;
class ViewComposerServiceProvider extends ServiceProvider {
    public function boot() {
        view()->composer('*',"App\Http\ViewComposers\TestViewComposer");
    }
}

Ссылка

Документация Laravel

Для дальнейшего уточнения Laracast Episode

Если еще что-то непонятно с моей стороны, дайте мне знать.

  • 0
    Использование ViewComposer - это правильный способ передачи данных в ваши представления. Возможно, вам следует принять этот ответ.
  • 0
    Первый сохранил мою дату, спасибо.
Показать ещё 14 комментариев
46

Вы можете либо создать свой собственный поставщик услуг (ViewServiceProvider имя является общим), либо вы можете использовать существующий AppServiceProvider.

В выбранном поставщике введите код в метод загрузки.

public function boot() {
    view()->share('data', [1, 2, 3]);
}

Это сделает переменную $data доступной во всех ваших представлениях.

Если вы предпочитаете использовать фасад вместо помощника, измените view()-> на View::, но не забудьте оставить use View; в верхней части файла.

  • 0
    Спасибо, отлично работает. Предназначена ли функция загрузки для такого рода вещей, или вы рекомендуете создать своего поставщика услуг?
  • 2
    Если у вас есть только одна или две вещи, AppServiceProvider можно поделиться, поместите их в AppServiceProvider - это хорошо, но если у вас есть что-то большее, вам следует подумать о создании нового поставщика.
Показать ещё 4 комментария
7

Я нашел, что это самый простой. Создайте нового поставщика и пользователя подстановочный знак '*', чтобы прикрепить его ко всем представлениям. Работает также в 5.3: -)

<?php

namespace App\Providers;

use Illuminate\Http\Request;
use Illuminate\Support\ServiceProvider;

class ViewServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap the application services.
     * @return void
     */
    public function boot()
    {
        view()->composer('*', function ($view)
        {
            $user = request()->user();

            $view->with('user', $user);
        });
    }

    /**
     * Register the application services.
     *
     * @return void
     */
    public function register()
    {
        //
    }
}
  • 1
    Добавьте этого провайдера в массив провайдеров в вашем config / app "App \ Providers \ ViewServiceProvider :: class"
  • 0
    Да! Хороший улов! Спасибо :)
3

Лучший способ - обмен информацией с помощью View::share('var', $value);

Проблемы с составлением с использованием "*":

Рассмотрим следующий подход:

<?php
// from AppServiceProvider::boot()
$viewFactory = $this->app->make(Factory::class);

$viewFacrory->compose('*', GlobalComposer::class);

Из примерного вида лезвия:

  @for($i = 0; $i<1000; $i++)
    @include('some_partial_view_to_display_i', ['toDisplay' => $i])
  @endfor

Что происходит?

  • Класс GlobalComposer создается 1000 раз, используя App::make.
  • Выполняется событие composing:some_partial_view_to_display_i 1000 раз.
  • Функция compose внутри класса GlobalComposer вызывается 1000 раз.

Но частичный вид some_partial_view_to_display_i не имеет ничего общего с переменными, состоящими из GlobalComposer, но значительно увеличивает время рендеринга.

Лучший подход?

Использование View::share вдоль сгруппированного промежуточного программного обеспечения.

Route::group(['middleware' => 'WebMiddleware'], function(){
  // Web routes
});

Route::group(['prefix' => 'api'], function (){

});

class WebMiddleware {
  public function handle($request)
  {
    \View::share('user', auth()->user());
  }
}

Обновление

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

2

Документация слышится https://laravel.com/docs/5.4/views#view-composers, но я сломаю ее

  • Найдите каталог app\Providers в корневом каталоге вашего приложения и создайте файл ComposerServiceProvider.php и скопируйте и пропустите текст ниже в нем и сохраните его.

    <?php
        namespace App\Providers;
        use Illuminate\Support\Facades\View;
        use Illuminate\Support\ServiceProvider;
    
        class ComposerServiceProvider extends ServiceProvider
        {
            /**
            * Register bindings in the container.
            *
            * @return void
            */
        public function boot()
        {
            // Using class based composers...
            View::composer(
                'profile', 'App\Http\ViewComposers\ProfileComposer'
            );
    
            // Using Closure based composers...
            View::composer('dashboard', function ($view) {
                //
            });
        }
    
        /**
        * Register the service provider.
        *
        * @return void
        */
        public function register()
        {
            //
        }
    }
    
  • В корне вашего приложения откройте Config/app.php и найдите раздел "Провайдеры" в файле и скопируйте и пройдите мимо этого "App\Providers\ComposerServiceProvider", в массив.

Сделав это, мы создали поставщика услуг Composer. Когда вы запускаете приложение с профилем вида таким образом http://yourdomain/something/profile, вызывается поставщик услуг ComposerServiceProvider и класс App\Http\ViewComposers\ProfileComposer создает экземпляр вызова метода Composer из-за кода ниже внутри метода загрузки или функции.

 // Using class based composers...
 View::composer(
   'profile', 'App\Http\ViewComposers\ProfileComposer'
 );
  1. Если вы обновите приложение, вы получите сообщение об ошибке, поскольку класс App\Http\ViewComposers\ProfileComposer еще не существует. Теперь давайте создадим его.

Перейдите в каталог path application/Http

  • Создайте каталог с именем ViewComposers

  • Создайте файл ProfileComposer.php.

    class ProfileComposer
    {
        /**
        * The user repository implementation.
        *
        * @var UserRepository
        */
        protected $users;
    
        /**
        * Create a new profile composer.
        *
        * @param  UserRepository  $users
        * @return void
        */
        public function __construct(UserRepository $users)
        {
            // Dependencies automatically resolved by service container...
            $this->users = $users;
        }
    
        /**
        * Bind data to the view.
        *
        * @param  View  $view
        * @return void
        */
        public function compose(View $view)
        {
            $view->with('count', $this->users->count());
        }
    }
    

Теперь перейдите к своему представлению или в этом случае Profile.blade.php и добавьте

{{ $count }}

и это покажет количество пользователей на странице профиля.

Чтобы показать счет на всех страницах, измените

// Using class based composers...
View::composer(
    'profile', 'App\Http\ViewComposers\ProfileComposer'
);

To

// Using class based composers...
View::composer(
    '*', 'App\Http\ViewComposers\ProfileComposer'
);
  • 0
    <? php и пространство имен App \ Http \ ViewComposers; используйте Illuminate \ Contracts \ View \ View; отсутствует в ProfileComposer.php
2

В документации:

Как правило, вы должны отправлять вызовы методу share в службе метод загрузки поставщика. Вы можете добавить их в AppServiceProvider или создать отдельный поставщик услуг для размещения их.

Я согласен с Marwelln, просто поставьте его в AppServiceProvider в функции загрузки:

public function boot() {
    View::share('youVarName', [1, 2, 3]);
}

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

0

Метод Laravel 5.6: https://laravel.com/docs/5.6/views#passing-data-to-views

Пример: совместное использование коллекции моделей для всех представлений (AppServiceProvider.php):

use Illuminate\Support\Facades\View;
use App\Product;

public function boot()
{
    $products = Product::all();
    View::share('products', $products);

}
  • 0
    Это вызовет проблемы, если вы пытаетесь создать новое приложение с пустой базой данных.
0

добавьте их поставщику услуг приложений в режиме загрузки

<?php

namespace App\Providers;

use Illuminate\Support\Facades\View;

class AppServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap any application services.
     *
     * @return void
     */
    public function boot()
    {
        View::share('signedIn', \Auth::check());

     View::share('user', \Auth::user());
    }

    /**
     * Register the service provider.
     *
     * @return void
     */
    public function register()
    {
        //
    }
}
0

Внутри вашей папки конфигурации вы можете создать имя файла php, например, "variable.php" с содержимым ниже:

<?php return [ 'versionNumber' => '122231', ];

Теперь во всех представлениях вы можете использовать config('variable.versionNumber') для вызова этой переменной.

  • 0
    В некоторых случаях я делаю это так, потому что информация действительно глобальная, и вы можете получить к ней доступ из любого места. По этой причине я называю файл конфигурации «global.php» и помещаю туда все, что я хочу, чтобы было доступно во всех других частях моего кода. Единственным ограничением является то, что это для статических данных и кэшируется. Это не должно использоваться таким образом, если у вас есть постоянно меняющиеся данные.
0

Документация слышится https://laravel.com/docs/5.4/views#view-composers, но я сломаю ее 1. Посмотрите на каталог Провайдеры в корневом каталоге и создайте для ComposerServiceProvider.php содержимое

0

Я думаю, что лучший способ - View Composers. Если кто-то пришел сюда и захочет найти способ сделать это с помощью View Composers, прочитайте мой ответ = > Как передать переменную во всех представлениях?

Ещё вопросы

Сообщество Overcoder
Наверх
Меню