本篇文章给大家分享的是有关怎么在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框架中操作视图和视图布局,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注天达云行业资讯频道。