Laravel - передать более одной переменной для просмотра

57

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

Как мне изменить строку return $view->with('persons', $persons);, чтобы передать переменную $ms в представление?

    function view($view)
    {
        $ms = Person::where('name', 'Foo Bar');

        $persons = Person::order_by('list_order', 'ASC')->get();

        return $view->with('persons', $persons);
    }
Теги:
laravel-3

8 ответов

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

Просто передайте это как массив:

$data = [
    'name'  => 'Raphael',
    'age'   => 22,
    'email' => '[email protected]'
];

return View::make('user')->with($data);

Или связать их, как упомянуто @Antonio.

  • 5
    Гораздо элегантнее, чем цепочка "с"
  • 1
    Рекомендуемый способ - использовать компактный метод для передачи переменных. Это выглядит довольно элегантно.
65

Вот как вы это делаете:

function view($view)
{
    $ms = Person::where('name', '=', 'Foo Bar')->first();

    $persons = Person::order_by('list_order', 'ASC')->get();

    return $view->with('persons', $persons)->with('ms', $ms);
}

Вы также можете использовать compact():

function view($view)
{
    $ms = Person::where('name', '=', 'Foo Bar')->first();

    $persons = Person::order_by('list_order', 'ASC')->get();

    return $view->with(compact('persons', 'ms'));
}

Или сделать это в одной строке:

function view($view)
{
    return $view
            ->with('ms', Person::where('name', '=', 'Foo Bar')->first())
            ->with('persons', Person::order_by('list_order', 'ASC')->get());
}

Или даже отправить его как массив:

function view($view)
{
    $ms = Person::where('name', '=', 'Foo Bar')->first();

    $persons = Person::order_by('list_order', 'ASC')->get();

    return $view->with('data', ['ms' => $ms, 'persons' => $persons]));
}

Но в этом случае вам придется обращаться к ним следующим образом:

{{ $data['ms'] }}
  • 0
    Да, я получил это далеко в то же время. Но теперь, когда я пытаюсь получить доступ к нему в представлении, например, {{ $ms->name }} я получаю Undefined property: Laravel\Database\Eloquent\Query::$name Чего мне не хватает?
  • 0
    Вы пропускаете ->first() в первой строке вашего метода.
Показать ещё 3 комментария
26

Используйте компактный

function view($view)
{
    $ms = Person::where('name', '=', 'Foo Bar')->first();

    $persons = Person::order_by('list_order', 'ASC')->get();
    return View::make('users', compact('ms','persons'));
}
18

Передача нескольких переменных в представление Laravel

//Passing variable to view using compact method    
$var1=value1;
$var2=value2;
$var3=value3;
return view('viewName', compact('var1','var2','var3'));

//Passing variable to view using with Method
return view('viewName')->with(['var1'=>value1,'var2'=>value2,'var3'=>'value3']);

//Passing variable to view using Associative Array
return view('viewName', ['var1'=>value1,'var2'=>value2,'var3'=>value3]);

Прочитайте здесь Передача данных в представления в Laravel

3

Похоже на аналогичную проблему, но если вы не хотите возвращать представление с файлом вида, вы можете сделать это:

return $view->with(compact('myVar1', 'myVar2', ..... , 'myLastVar'));
1

Пожалуйста, попробуйте это,

$ms = Person::where('name', 'Foo Bar')->first();
$persons = Person::order_by('list_order', 'ASC')->get();
return View::make('viewname')->with(compact('persons','ms'));
0
    $oblast = Oblast::all();
    $category = Category::where('slug', $catName)->first();
    $availableProjects = $category->availableProjects;
    return view('pages.business-area')->with(array('category'=>$category, 'availableProjects'=>$availableProjects, 'oblast'=>$oblast));
0

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

$category = Category::all();
$category = Category::pluck('name', 'id');
$item = Subject::find($id);
return View::make('subject.edit')->with(array('item'=>$item, 'category'=>$category));

Ещё вопросы

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