yii2源码学习笔记(二十)
Widget类是所有部件的基类。yii2\base\Widget.php
<?php
/**
* @link http://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license http://www.yiiframework.com/license/
*/ namespace yii\base; use Yii;
use ReflectionClass; /**
* Widget is the base class for widgets.
* Widget是所有小部件的基类
* @property string $id ID of the widget. 小部件标识
* @property \yii\web\View $view The view object that can be used to render views or view files. Note that the
* type of this property differs in getter and setter. See [[getView()]] and [[setView()]] for details.
* 用于渲染视图或视图文件的视图对象 在getter 和 setter中是不同的
* @property string $viewPath The directory containing the view files for this widget. This property is
* read-only. 包含此控件的视图文件目录
*
* @author Qiang Xue <qiang.xue@gmail.com>
* @since 2.0
*/
class Widget extends Component implements ViewContextInterface
{
/**
* @var integer a counter used to generate [[id]] for widgets.
* @internal 用于生成widget ID的计数器
*/
public static $counter = ;
/**
* @var string the prefix to the automatically generated widget IDs.
* @see getId() 自动生成的前缀
*/
public static $autoIdPrefix = 'w';
/**
* @var Widget[] the widgets that are currently being rendered (not ended). This property
* is maintained by [[begin()]] and [[end()]] methods. 目前正在渲染的小部件
* @internal
*/
public static $stack = []; /**
* Begins a widget. 开始一个部件
* This method creates an instance of the calling class. It will apply the configuration
* to the created instance. A matching [[end()]] call should be called later.
* 将应用配置文件创建调用类的实例,与[end()]方法相对应
* @param array $config name-value pairs that will be used to initialize the object properties
* 用于初始化属性的参数
* @return static the newly created widget instance 静态新创建的部件实例
*/
public static function begin($config = [])
{
$config['class'] = get_called_class();//后期静态绑定类的名称
/* @var $widget Widget */
$widget = Yii::createObject($config);//通过类名和传入的配置,实例化调用类
static::$stack[] = $widget;//将对象放入正在渲染的部件堆栈中 return $widget;
} /**
* Ends a widget. 结束小部件
* Note that the rendering result of the widget is directly echoed out.渲染结果是直接呼应的
* @return static the widget instance that is ended. 静态结束的部件实例。
* @throws InvalidCallException if [[begin()]] and [[end()]] calls are not properly nested
*/
public static function end()
{
if (!empty(static::$stack)) {//正在呈现的小部件堆栈中存在调用类实例
$widget = array_pop(static::$stack);//从堆栈中删除最后一个实例
if (get_class($widget) === get_called_class()) {
echo $widget->run(); //如果删除的实例类名和当前调用类名相同,输出小部件的内容
return $widget;
} else {
throw new InvalidCallException("Expecting end() of " . get_class($widget) . ", found " . get_called_class());
}
} else {
throw new InvalidCallException("Unexpected " . get_called_class() . '::end() call. A matching begin() is not found.');
}
} /**
* Creates a widget instance and runs it. 创建一个部件实例,并运行
* The widget rendering result is returned by this method. 返回部件渲染的结果。
* @param array $config name-value pairs that will be used to initialize the object properties
* 用于初始化对象属性的参数
* @return string the rendering result of the widget. 控件的渲染结果。
*/
public static function widget($config = [])
{
ob_start(); //打开输出缓冲区
ob_implicit_flush(false);//关闭绝对刷新
/* @var $widget Widget */
$config['class'] = get_called_class(); //获取调用类的类名
$widget = Yii::createObject($config); //实例化类
$out = $widget->run();//运行部件 return ob_get_clean() . $out; //返回内部缓冲区的内容,关闭缓冲区
} private $_id; /**
* Returns the ID of the widget. 返回插件的标识
* @param boolean $autoGenerate whether to generate an ID if it is not set previously
* 是否生成一个唯一标识,如果没有设置
* @return string ID of the widget. 部件唯一标识
*/
public function getId($autoGenerate = true)
{
if ($autoGenerate && $this->_id === null) {
//如果标识为空,并且设置为允许自动生成标识,自动生成
$this->_id = static::$autoIdPrefix . static::$counter++;
} return $this->_id;
} /**
* Sets the ID of the widget. 设置小部件标识
* @param string $value id of the widget. 部件的标识。
*/
public function setId($value)
{
$this->_id = $value;
} private $_view; /**
* Returns the view object that can be used to render views or view files.返回视图对象
* The [[render()]] and [[renderFile()]] methods will use
* this view object to implement the actual view rendering.
* [render()]和[renderFile()]方法用视图对象实现实际的视图显示。
* If not set, it will default to the "view" application component.
* @return \yii\web\View the view object that can be used to render views or view files.
*/
public function getView()
{
if ($this->_view === null) {
$this->_view = Yii::$app->getView();//如果视图对象为空,调用getView()取得视图对象实例
} return $this->_view;
} /**
* Sets the view object to be used by this widget. 设置当前部件调用的视图对象实例
* @param View $view the view object that can be used to render views or view files.
*/
public function setView($view)
{
$this->_view = $view;//要用的视图对象
} /**
* Executes the widget. 执行部件
* @return string the result of widget execution to be outputted.
* 控件执行的结果输出。
*/
public function run()
{
} /**
* Renders a view.
* The view to be rendered can be specified in one of the following formats:
* 渲染一个视图 实际调用View类中的同名方法 渲染的视图可以用下列方式指定路径
* - path alias (e.g. "@app/views/site/index");
* - absolute path within application (e.g. "//site/index"): the view name starts with double slashes.
* The actual view file will be looked for under the [[Application::viewPath|view path]] of the application.
* - absolute path within module (e.g. "/site/index"): the view name starts with a single slash.
* The actual view file will be looked for under the [[Module::viewPath|view path]] of the currently
* active module.
* - relative path (e.g. "index"): the actual view file will be looked for under [[viewPath]].
*
* If the view name does not contain a file extension, it will use the default one `.php`.
*
* @param string $view the view name. 视图名
* @param array $params the parameters (name-value pairs) that should be made available in the view.
* 在视图中可用的参数
* @return string the rendering result. 渲染结果
* @throws InvalidParamException if the view file does not exist.
*/
public function render($view, $params = [])
{
//调用view类中的render渲染指定的视图
return $this->getView()->render($view, $params, $this);
} /**
* Renders a view file. 渲染一个视图文件 同上
* @param string $file the view file to be rendered. This can be either a file path or a path alias.
* @param array $params the parameters (name-value pairs) that should be made available in the view.
* @return string the rendering result.
* @throws InvalidParamException if the view file does not exist.
*/
public function renderFile($file, $params = [])
{
return $this->getView()->renderFile($file, $params, $this);
} /**
* Returns the directory containing the view files for this widget. 返回视图文件路径
* The default implementation returns the 'views' subdirectory under the directory containing the widget class file.
* @return string the directory containing the view files for this widget.
*/
public function getViewPath()
{
$class = new ReflectionClass($this);
//取得部件类文件的目录,拼接为视图目录
return dirname($class->getFileName()) . DIRECTORY_SEPARATOR . 'views';
}
}
yii2源码学习笔记(二十)的更多相关文章
- yii2源码学习笔记(十八)
View继承了component,用于渲染视图文件:yii2\base\View.php <?php /** * @link http://www.yiiframework.com/ * @co ...
- yii2源码学习笔记(二)
yii\base\Object代码详解 <?php /** * @link http://www.yiiframework.com/ * @copyright Copyright (c) 200 ...
- yii2源码学习笔记(九)
Application是所有应用程序类的基类,接下来了解一下它的源码.yii2\base\Application.php. <?php /** * @link http://www.yiifra ...
- yii2源码学习笔记(八)
Action是所有控制器的基类,接下来了解一下它的源码.yii2\base\Action.php <?php /** * @link http://www.yiiframework.com/ * ...
- jquery源码学习笔记二:jQuery工厂
笔记一里记录,jQuery的总体结构如下: (function( global, factory ) { //调用factory(工厂)生成jQuery实例 factory( global ); }( ...
- 老刘 Yii2 源码学习笔记之 Action 类
Action 的概述 InlineAction 就是内联动作,所谓的内联动作就是放到controller 里面的 actionXXX 这种 Action.customAction 就是独立动作,就是直 ...
- jQuery源码学习笔记二
//添加实例属性和方法 jQuery.fn = jQuery.prototype = { // 版本,使用方式:$().jquery弹出当前引入的jquery的版本 jquery: core_vers ...
- yii2源码学习笔记(十二)
继续了解controller基类. /** * Runs a request specified in terms of a route.在路径中指定的请求. * The route can be e ...
- yii2源码学习笔记(十四)
Module类是模块和应用类的基类. yiisoft\yii2\base\Module.php <?php /** * @link http://www.yiiframework.com/ * ...
随机推荐
- SweetAlert 使用
$(".delete").click(function(){ var work_name = $(this).data('name'); var item_id = $(this) ...
- Selenium 进行web自动化测试
1.安装火狐版本时注意,如果无法正常安装,应该点击右键---以管理员身份运行 2.安装成功后,选择工具--选项--高级--更新,停止其自动化更新 3.maven里面加载应有的selenium的组件
- javaSE-基础部分整理
JavaSE基础部分整理 1.java介绍 1.Java分为三个部分: javaSE,javaEE,javaME; java重要性之一:跨平台(操作系统). 跨平台:一次编译,到处运行. Java虚拟 ...
- ApkTool动态打包
引言: APK在推广的时候可能会须要动态打包APK.比方公布到不同渠道的时候,须要在manifest文件里改动渠道信息.或者app在推广的时候.须要在apk包里面加上推广人信息等. 环境变量: 1.J ...
- mongodb地理位置索引
初始化集合(经度在前,纬度在后) ? 1 2 3 mongos> db.checkins.insert({ "_id" : "101", "lo ...
- JAVA编程心得-多态设计初步
面向对象的思想中,封装,继承,多态作为特性会在开发中广泛应用,一个健壮的系统除了功能强大以外,它的可扩展性应该也很强,多态恰好应用了这个思路. 下面我以杨小聪去某地的方式为例,我们知道首先杨小聪要去某 ...
- zoj 3672 思考题
http://acm.zju.edu.cn/onlinejudge/showProblem.do? problemId=4915 真是老了.脑子不会动了,可是事实上就算如今搜了题解A了,还是没总结出思 ...
- iOS 网络编程:XML解析
1 XML文档结构 1.1 简介 XML 指可扩展标记语言(eXtensible Markup Language).XML 被设计用来传输和存储数据.其非常像HTML的标记语言,但与之不同的是,XML ...
- Lambda表达式(C语言-gcc编译器)
前言 先来啰嗦几句,身边的朋友,同事都喜欢在博客上记录自己在学习计算机编程技术路程上的一些问题和心得.就我个人而言,这是个好习惯,特别是在计算机编程领域,技术方向种类繁多,永无止境.所以,我也开始我人 ...
- 第二种方式读取并显示HDFS中的内容
1.讀取HDFS内容的java客戶端代碼: package Hdfs; import java.io.InputStream; import java.net.URI; import org.apac ...