mycjk31 2017-06-07 11:05:32 7896次浏览 0条评论 1 0 0

▪ HTML 转义

为了过滤从最终用户来的数据以避免XSS攻击。应该通过调用 yii\helpers\Html::encode() 编码纯文本,例如:

<?php use yii\helpers\Html; ?>

<div class="index-div">
   <h1><?= Html::encode($this->title) ?></h1>
</div>

注:title 是 YII 视图类中预定义的一个成员变量,所以可以直接通过 $this->title 引用。

▪ 视图渲染

要渲染控制器中的视图,可以使用下面的方法:

  • render() − 渲染一个视图,并应用布局
  • renderFile() − 在一个给定的文件路径或别名来渲染视图
  • renderAjax() − 渲染视图但不使用布局,但所有的注入JS和CSS文件
  • renderPartial() − 渲染视图,但不使用布局
  • renderContent() − 渲染一个静态字符串并应用布局

要渲染其他视图中的视图,您可以使用下面的方法:

  • render() − 渲染一个视图
  • renderFile() − 在一个给定的文件路径或别名来渲染视图
  • renderAjax() − 渲染视图但不使用布局,但所有的注入JS和CSS文件

▪ 视图赋值

1. 方法一(推荐)

// 控制器中赋值变量
public function actionIndex()  
{  
    $this->getView()->params['title'] = 'here is index';  
    return $this->render('index');  
}  

// 视图中显示变量
<?php echo $this->params['title']; ?>

注:params 是 YII 视图类中预定义的一个成员变量,所以可以直接通过 $this->params 引用。

优点:在视图文件中你可能需要处理控制器传递过来的变量,比如:$title = $this->params['title'],那么通过 $title$this->params['title'] 这两个写法你可以很容易区分哪个变量是在视图文件中临时定义的,哪个变量是从控制器中传递过来;同时也防止变量因为名字相同而覆盖。

2. 方法二

// 控制器中赋值变量
public function actionIndex()  
{  
    $params = array('title'=>'here is index');
    return $this->render('index', $params);  
}  

// 视图中显示变量
<?php echo $title; ?>

更多Yii2文章参见 https://my.oschina.net/lengdo/blog

    没有找到数据。
您需要登录后才可以评论。登录 | 立即注册