本篇文章给大家分享的是有关怎么在Yii框架中操作视图和视图布局,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
Yii 视图
控制器方法代码:
public function actionIndex(){ $data = array( 'name' => 'zhangsan', 'age' => 12, 'address' => array('北京市','朝阳区'), 'intro' => '我是简介,<script>alert("123");</script>' ); return $this->renderPartial('index',$data);//第二个参数赋值 }
视图代码:
<?php use yii\helpers\Html; use yii\helpers\HtmlPurifier; ?> <h2>Hello index view</h2> <h3>姓名:<?php echo $name;?></h3> <h3>年龄:<?=$age?></h3> <h3>地址:<?=$address[0]?> <?=$address[1]?></h3> <h3>简介:<?=Html::encode($intro)?> </h3> <h3>简介:<?=HtmlPurifier::process($intro)?> </h3>
Yii 视图布局
控制器代码:
//设置的布局文件 public $layout = 'common'; public function actionAbout(){ $data = array('page_name'=>'About'); //render方法会把视图文件common的内容放到$content当中,并显示布局文件。 return $this->render('about',$data); }
公共视图common代码:
<!DOCTYPE html> <html> <head> <title></title> <meta charset="UTF-8"> </head> <body> <h2>这是Common内容</h2> <div> <?=$content?> </div> </body> </html>
视图about代码,并调用了activity视图:
<h2> Hello <?=$page_name?></h2> <?php echo $this->render('activity',array('page_name'=>'activity'));?>
视图activity代码:
<h2> Hello <?=$page_name?></h2>
结论:视图引用了公共布局文件,并且在一个视图中调用另一个视图文件。
Yii 视图数据块
控制器代码:
public $layout = 'common'; public function actionStudent(){ $data = array('page_name'=>'Student'); return $this->render('student',$data); } public function actionTeacher(){ $data = array('page_name'=>'Teacher'); return $this->render('teacher',$data); }
公共布局文件common代码:
<!DOCTYPE html> <html> <head> <title> <?php if(isset($this->blocks['webTitle'])):?> <?=$this->blocks['webTitle'];?> <?php else:?> commom <?php endif;?> </title> <meta charset="UTF-8"> </head> <body> <h2>这是Common内容</h2> <div> <?=$content?> </div> </body> </html>
视图student代码:
<?php $this->beginBlock('webTitle');?> <?=$page_name?>页面 <?php $this->endBlock();?> <h2> Hello <?=$page_name?></h2>
视图teacher代码:
<h2> Hello <?=$page_name?></h2> <?php $this->beginBlock('webTitle');?> <?=$page_name?>页面 <?php $this->endBlock();?>
以上就是怎么在Yii框架中操作视图和视图布局,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。