首页 > 其他 > 详细

Laravel向视图传值

时间:2019-03-24 22:50:58      阅读:167      评论:0      收藏:0      [点我收藏+]

向视图中传递变量 我们在开发web应用当中,通常都不是为了写静态页面而生的,我们需要跟数据打交道,那么这个时候,问题就来了,在一个MVC的框架中,怎么将数据传给视图呢?比如我们要在 ArticleController 的 index 方法的视图输出一个 $title 的变量,在Laravel中,有下面几种常见的方法:

方法一:

public function index()
{
$title = ‘文章标题1‘;
return view(‘articles.lists‘)->with(‘title‘,$title);
}

使用with()方法 这样的 with(‘title’,title)中,第一个′title′就是key,第二个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 echotitle }} 会被解析为类似 这样的输出 <?php echotitle; ?> ,不过这里的 {{ }} 符号会将数据原样输出,比如你将 $title 写成这样:

public function index()
{
$title = ‘<span style="color: red">文章</span>标题1‘;
return view(‘articles.lists‘)->with(‘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
 

public function index()
{
$title = ‘<span style="color: red">文章</span>标题1‘;
$intro = ‘文章一的简介‘;
return view(‘articles.lists‘,compact(‘title‘,‘intro‘));
}

compact() 的字符串可以就是变量的名字,多个变量名用逗号隔开。这个时候注意更改视图的变量输出。

 

Laravel向视图传值

原文:https://www.cnblogs.com/peteremperor/p/10591004.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!