laravel框架頁面數據渲染HTML compact的用法
向視圖中傳遞變量
我們在開發web應用當中,通常都不是為了寫靜態頁面而生的,我們需要跟數據打交道,那麽這個時候,問題就來了,在一個MVC的框架中,怎麽將數據傳給視圖呢?比如我們要在 ArticleController
的 index
方法的視圖輸出一個 $title
的變量,在Laravel中,有下面幾種常見的方法:
使用with()方法
public function index()
{
$title = ‘文章標題1‘;
return view(‘articles.lists‘)->with(‘title‘,$title);
}
這樣的 with(‘title‘,$title)
中,第一個 ‘title‘
就是key,第二個 $title
就是值,這樣我們就可以在我們的 articles/lists.blade.php
中輸出這個變量了:
<body>
<h1><?php echo $title; ?></h1>
</body>
刷新我們的 blog.dev
,就可以看到類似這樣的頁面了:
而在blade引擎中,我們可以這樣輸出變量:
<body>
<h1>{{ $title }}</h1>
</body>
其實在blade引擎中, {{ $title }}
<?php echo $title; ?>
,不過這裏的 {{ }}
符號會將數據原樣輸出,比如你將 $title
寫成這樣:
public function index()
{
$title = ‘<span style="color: red">文章</span>標題1‘;
return view(‘articles.lists‘)->with(‘title‘,$title);
}
這個時候你用 {{ $title }}
輸出,會看到類似下面這樣:
如果你想將 $title
<h1>{!! $title !!}</h1>
這裏的 {{ }}
和 {!! !!}
是blade的最基礎的用法,這兩個我們會用得特別多,後面我會詳細說說blade的用法。
直接給view()傳參數
使用這個方法的時候,你可以這樣寫:
public function index()
{
$title = ‘<span style="color: red">文章</span>標題1‘;
return view(‘articles.lists‘,[‘title‘=>$title]);
}
刷新頁面,你依然會看到一樣的輸出。這裏需要說明一下,如果你傳多個變量,比如:
public function index()
{
$title = ‘<span style="color: red">文章</span>標題1‘;
$intro = ‘文章一的簡介‘;
return view(‘articles.lists‘,[
‘title‘=>$title,
‘introduction‘=>$intro
]);
}
在傳遞的數組中:
[
‘title‘=>$title,
‘introduction‘=>$intro
]
每一個key會在視圖中作為變量,而 value
就作為變量的值。所以在視圖中我們需要這樣輸出:
<body>
<h1>{!! $title !!}</h1>
<p>{{ $introduction }}</p>
</body>
這裏應寫成 {{ $introduction }}
,而不是 {{ $intro }}
。
使用compact
使用compact是這樣寫的:
public function index()
{
$title = ‘<span style="color: red">文章</span>標題1‘;
$intro = ‘文章一的簡介‘;
return view(‘articles.lists‘,compact(‘title‘,‘intro‘));
}
compact()
的字符串可以就是變量的名字,多個變量名用逗號隔開。這個時候註意更改視圖的變量輸出。
以上就是Laravel中常用的幾種向視圖傳遞變量的方法,選擇一種你喜歡的方式並堅持這一種寫法就可以了,我是使用第三種。
laravel框架頁面數據渲染HTML compact的用法