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中常用的幾種向視圖傳遞變量的方法,選擇一種你喜歡的方式並堅持這一種寫法就可以了,我是使用第三種。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM