View中渲染view视图文件的前置和后置方法,以及渲染动态内容的方法:

   /**
      * @return string|boolean the view file currently being rendered. False if no view file is being rendered.
      */
     public function getViewFile()
     {
         return end($this->_viewFiles);//返回[_viewFiles]中的最后一个view文件,即默认被渲染的文件
     }

     /**
      * This method is invoked right before [[renderFile()]] renders a view file.
      * Render的前置事件,在执行[renderFile()]方法时被调用,默认触发[[EVENT_BEFORE_RENDER]]事件
      * The default implementation will trigger the [[EVENT_BEFORE_RENDER]] event.
      * If you override this method, make sure you call the parent implementation first.
      * 如果要重写该方法,要确保首先调用父类的同名方法
      * @param string $viewFile the view file to be rendered.
      * @param array $params the parameter array passed to the [[render()]] method.
      * @return boolean whether to continue rendering the view file.
      */
     public function beforeRender($viewFile, $params)
     {
         //实例化ViewEvent
         $event = new ViewEvent([
             'viewFile' => $viewFile,
             'params' => $params,
         ]);
         //触发[EVENT_BEFORE_RENDER]事件
         $this->trigger(self::EVENT_BEFORE_RENDER, $event);

         return $event->isValid;//返回值可以判断是否继续渲染文件
     }

     /**
      * This method is invoked right after [[renderFile()]] renders a view file.
      * Render的后置事件,在执行[renderFile()]方法后被调用,默认触发[[EVENT_AFTER_RENDER]]事件
      * The default implementation will trigger the [[EVENT_AFTER_RENDER]] event.
      * If you override this method, make sure you call the parent implementation first.
      * 如果要重写该方法,要确保首先调用父类的同名方法
      * @param string $viewFile the view file being rendered.
      * @param array $params the parameter array passed to the [[render()]] method.
      * @param string $output the rendering result of the view file. Updates to this parameter
      * will be passed back and returned by [[renderFile()]].
      */
     public function afterRender($viewFile, $params, &$output)
     {
         if ($this->hasEventHandlers(self::EVENT_AFTER_RENDER)) {//判断[EVENT_AFTER_RENDER]事件是否有处理函数
            //实例化ViewEvent
             $event = new ViewEvent([
                 'viewFile' => $viewFile,
                 'params' => $params,
                 'output' => $output,
             ]);
              //触发[EVENT_AFTER_RENDER]事件
             $this->trigger(self::EVENT_AFTER_RENDER, $event);
             $output = $event->output;//执行后置事件后的输出结果
         }
     }

     /**
      * Renders a view file as a PHP script.
      * 将一个view文件当作PHP脚本渲染
      * This method treats the view file as a PHP script and includes the file.
      * It extracts the given parameters and makes them available in the view file.
      * The method captures the output of the included view file and returns it as a string.
      * 将传入的参数转换为变量,包含并执行view文件,返回执行结果
      * This method should mainly be called by view renderer or [[renderFile()]].
      *
      * @param string $_file_ the view file.
      * @param array $_params_ the parameters (name-value pairs) that will be extracted and made available in the view file.
      * @return string the rendering result
      */
     public function renderPhpFile($_file_, $_params_ = [])
     {
         //ob_start() — 打开输出控制缓冲
         ob_start();
         // ob_implicit_flush ()  — 默认为关闭缓冲区,打开绝对输出后,每个脚本输出都直接发送到浏览器,不再需要调用 flush()
         ob_implicit_flush(false);
         extract($_params_, EXTR_OVERWRITE);//extract() - 用于将一个数组转换为变量使用,键名为变量名,键值为对应的变量值
         require($_file_);
         //ob_get_clean() — 得到当前缓冲区的内容并删除当前输出缓
         return ob_get_clean();
     }

     /**
      * Renders dynamic content returned by the given PHP statements.
      * 渲染动态内容
      * This method is mainly used together with content caching (fragment caching and page caching)
      * 该方法主要用来聚合缓存的内容(片段缓存和页面缓存)
      * when some portions of the content (called *dynamic content*) should not be cached.
      * The dynamic content must be returned by some PHP statements.
      * 用来渲染某些被PHP语句返回的动态内容
      * @param string $statements the PHP statements for generating the dynamic content.
      * @return string the placeholder of the dynamic content, or the dynamic content if there is no
      * active content cache currently.
      */
     public function renderDynamic($statements)
     {
         if (!empty($this->cacheStack)) {//动态内容的栈列表不为空
             $n = count($this->dynamicPlaceholders);//计算动态内容条数
             $placeholder = "<![CDATA[YII-DYNAMIC-$n]]>";//生成占位符--动态内容前缀--起标记作用
             $this->addDynamicPlaceholder($placeholder, $statements);//添加动态内容占位符

             return $placeholder;
         } else {
             return $this->evaluateDynamicContent($statements);//动态内容的栈列表为空,值行传入的PHP语句,返回执行结果
         }
     }

     /**
      * Adds a placeholder for dynamic content.
      * 给dynamic content添加一个占位符
      * This method is internally used.
      * 该方法是内部使用的
      * @param string $placeholder the placeholder name
      * @param string $statements the PHP statements for generating the dynamic content
      */
     public function addDynamicPlaceholder($placeholder, $statements)
     {
         foreach ($this->cacheStack as $cache) {
             $cache->dynamicPlaceholders[$placeholder] = $statements;//给widget中的[FragmentCache]添加占位符
         }
         $this->dynamicPlaceholders[$placeholder] = $statements;//给当前视图添加动态内容占位符
     }

     /**
      * Evaluates the given PHP statements.
      * 求给定的PHP语句的值
      * This method is mainly used internally to implement dynamic content feature.
      * 该方法是内部使用实现动态内容功能
      * @param string $statements the PHP statements to be evaluated.
      * @return mixed the return value of the PHP statements.
      */
     public function evaluateDynamicContent($statements)
     {
         return eval($statements);//eval() 函数用于执行文本方式输入的php语句
     }

GitHub地址: https://github.com/mogambos/yii-2.0.7/blob/master/vendor/yiisoft/yii2/base/View.php

Yii源码阅读笔记(十九)的更多相关文章

  1. Yii源码阅读笔记(九)

    Behvaior类,Behavior类是所有事件类的基类: namespace yii\base; /** * Behavior is the base class for all behavior ...

  2. Yii源码阅读笔记(一)

    今天开始阅读yii2的源码,想深入了解一下yii框架的工作原理,同时学习一下优秀的编码规范和风格.在此记录一下阅读中的小心得. 每个框架都有一个入口文件,首先从入口文件开始,yii2的入口文件位于we ...

  3. Yii源码阅读笔记(二十九)

    动态模型DynamicModel类,用于实现模型内数据验证: namespace yii\base; use yii\validators\Validator; /** * DynamicModel ...

  4. Yii源码阅读笔记(三十五)

    Container,用于动态地创建.注入依赖单元,映射依赖关系等功能,减少了许多代码量,降低代码耦合程度,提高项目的可维护性. namespace yii\di; use ReflectionClas ...

  5. Yii源码阅读笔记(三十四)

    Instance类, 表示依赖注入容器或服务定位器中对某一个对象的引用 namespace yii\di; use Yii; use yii\base\InvalidConfigException; ...

  6. Yii源码阅读笔记(三十二)

    web/Application类的注释,继承base/Application类,针对web应用的一些处理: namespace yii\web; use Yii; use yii\base\Inval ...

  7. Yii源码阅读笔记(三十)

    Widget类是所有小部件的基类,开始,结束和渲染小部件内容的方法的注释: namespace yii\base; use Yii; use ReflectionClass; /** * Widget ...

  8. Yii源码阅读笔记(二十八)

    Yii/web中的Controller类,实现参数绑定,启动csrf验证功能,重定向页面功能: namespace yii\web; use Yii; use yii\base\InlineActio ...

  9. Yii源码阅读笔记(二十六)

    Application 类中设置路径的方法和调用ServiceLocator(服务定位器)加载运行时的组件的方法注释: /** * Handles the specified request. * 处 ...

随机推荐

  1. MySQL常用的自带函数

    MySQL自带函数十分丰富,合理使用可以减少很多编码工作. >>数学函数 数学函数主要用于处理数字,包括整型.浮点数等.数学函数包括绝对值函数.正弦函数.余弦函数.获取随机数的函数等.AB ...

  2. PHP“Cannot use object of type stdClass as array” (php在调用json_decode从字符串对象生成json对象时的报错)

    php再调用json_decode从字符串对象生成json对象时,如果使用[]操作符取数据,会得到下面的错误 错误:Cannot use object of type stdClass as arra ...

  3. UVa 11437:Triangle Fun(计算几何综合应用,求直线交点,向量运算,求三角形面积)

    Problem ATriangle Fun Input: Standard Input Output: Standard Output In the picture below you can see ...

  4. ML 03、机器学习的三要素

    机器学习算法原理.实现与实践——机器学习的三要素 1 模型 在监督学习中,模型就是所要学习的条件概率分布或决策函数.模型的假设空间包含所有可能的条件概率分布或决策函数.例如,假设决策函数是输入变量的线 ...

  5. 电赛菜鸟营培训(零)——Keil环境搭建

    一.Keil开发软件安装 1.安装keil软件 2.使用注册机进行破解 将方框内的ID号复制到注册机,然后得到License,放到最底下就可以完成了. 二.Keil工程搭建 表示参考数据手册,在这里建 ...

  6. Kali Linux 2016.2初体验使用总结

    Kali Linux 2016.2初体验使用总结 Kali Linux官方于8月30日发布Kali Linux 2016的第二个版本Kali Linux 2016.2.该版本距离Kali Linux  ...

  7. Xamarin Android布局文件没有智能提示

    Xamarin Android布局文件没有智能提示 在Visual Studio 2015中,Android项目的Main.axml文件没有智能提示,不便于布局文件的编写.解决办法:(1)从Xamar ...

  8. iOS数组排序

    [_fields sortUsingComparator:^NSComparisonResult(UITextField *obj1, UITextField *obj2) { /* NSOrdere ...

  9. Sql 字符串替换

    (1) 字符串替换 Update SongADD_EMH0055 SET songno = REPLACE(songno, '231', '233') where songno like '%1022 ...

  10. ural 1157. Young Tiler

    1157. Young Tiler Time limit: 1.0 secondMemory limit: 64 MB One young boy had many-many identical sq ...