yii2源码学习笔记(二十),yii2源码学习笔记
yii2源码学习笔记(二十),yii2源码学习笔记
Widget类是所有部件的基类。yii2\base\Widget.php
<span> 1</span> <?<span>php </span><span> 2</span> <span>/*</span><span>* </span><span> 3</span> <span> * @link </span><span>http://www.yiiframework.com/</span> <span> 4</span> <span> * @copyright Copyright (c) 2008 Yii Software LLC </span><span> 5</span> <span> * @license </span><span>http://www.yiiframework.com/license/</span> <span> 6</span> <span>*/</span> <span> 7</span> <span> 8</span> <span>namespace</span> yii\<span>base</span><span>; </span><span> 9</span> <span> 10</span> <span>use Yii; </span><span> 11</span> <span>use ReflectionClass; </span><span> 12</span> <span> 13</span> <span>/*</span><span>* </span><span> 14</span> <span> * Widget is the base class for widgets. </span><span> 15</span> <span> * Widget是所有小部件的基类 </span><span> 16</span> <span> * @property string $id ID of the widget. 小部件标识 </span><span> 17</span> <span> * @property \yii\web\View $view The view object that can be used to render views or view files. Note that the </span><span> 18</span> <span> * type of this property differs in getter and setter. See [[getView()]] and [[setView()]] for details. </span><span> 19</span> <span> * 用于渲染视图或视图文件的视图对象 在getter 和 setter中是不同的 </span><span> 20</span> <span> * @property string $viewPath The directory containing the view files for this widget. This property is </span><span> 21</span> <span> * read-only. 包含此控件的视图文件目录 </span><span> 22</span> <span> * </span><span> 23</span> <span> * @author Qiang Xue <qiang.xue@gmail.com> </span><span> 24</span> <span> * @since 2.0 </span><span> 25</span> <span>*/</span> <span> 26</span> <span>class</span><span> Widget extends Component implements ViewContextInterface </span><span> 27</span> <span>{ </span><span> 28</span> <span>/*</span><span>* </span><span> 29</span> <span> * @var integer a counter used to generate [[id]] for widgets. </span><span> 30</span> <span> * @internal 用于生成widget ID的计数器 </span><span> 31</span> <span>*/</span> <span> 32</span> <span>public</span> <span>static</span> $counter = <span>0</span><span>; </span><span> 33</span> <span>/*</span><span>* </span><span> 34</span> <span> * @var string the prefix to the automatically generated widget IDs. </span><span> 35</span> <span> * @see getId() 自动生成的前缀 </span><span> 36</span> <span>*/</span> <span> 37</span> <span>public</span> <span>static</span> $autoIdPrefix = <span>'</span><span>w</span><span>'</span><span>; </span><span> 38</span> <span>/*</span><span>* </span><span> 39</span> <span> * @var Widget[] the widgets that are currently being rendered (not ended). This property </span><span> 40</span> <span> * is maintained by [[begin()]] and [[end()]] methods. 目前正在渲染的小部件 </span><span> 41</span> <span> * @internal </span><span> 42</span> <span>*/</span> <span> 43</span> <span>public</span> <span>static</span> $stack =<span> []; </span><span> 44</span> <span> 45</span> <span> 46</span> <span>/*</span><span>* </span><span> 47</span> <span> * Begins a widget. 开始一个部件 </span><span> 48</span> <span> * This method creates an instance of the calling class. It will apply the configuration </span><span> 49</span> <span> * to the created instance. A matching [[end()]] call should be called later. </span><span> 50</span> <span> * 将应用配置文件创建调用类的实例,与[end()]方法相对应 </span><span> 51</span> <span> * @param array $config name-value pairs that will be used to initialize the object properties </span><span> 52</span> <span> * 用于初始化属性的参数 </span><span> 53</span> <span> * @return static the newly created widget instance 静态新创建的部件实例 </span><span> 54</span> <span>*/</span> <span> 55</span> <span>public</span> <span>static</span> function begin($config =<span> []) </span><span> 56</span> <span> { </span><span> 57</span> $config[<span>'</span><span>class</span><span>'</span>] = get_called_class();<span>//</span><span>后期静态绑定类的名称</span> <span> 58</span> <span>/*</span><span> @var $widget Widget </span><span>*/</span> <span> 59</span> $widget = Yii::createObject($config);<span>//</span><span>通过类名和传入的配置,实例化调用类</span> <span> 60</span> <span>static</span>::$stack[] = $widget;<span>//</span><span>将对象放入正在渲染的部件堆栈中</span> <span> 61</span> <span> 62</span> <span>return</span><span> $widget; </span><span> 63</span> <span> } </span><span> 64</span> <span> 65</span> <span>/*</span><span>* </span><span> 66</span> <span> * Ends a widget. 结束小部件 </span><span> 67</span> <span> * Note that the rendering result of the widget is directly echoed out.渲染结果是直接呼应的 </span><span> 68</span> <span> * @return static the widget instance that is ended. 静态结束的部件实例。 </span><span> 69</span> <span> * @throws InvalidCallException if [[begin()]] and [[end()]] calls are not properly nested </span><span> 70</span> <span>*/</span> <span> 71</span> <span>public</span> <span>static</span><span> function end() </span><span> 72</span> <span> { </span><span> 73</span> <span>if</span> (!empty(<span>static</span>::$stack)) {<span>//</span><span>正在呈现的小部件堆栈中存在调用类实例</span> <span> 74</span> $widget = array_pop(<span>static</span>::$stack);<span>//</span><span>从堆栈中删除最后一个实例</span> <span> 75</span> <span>if</span> (get_class($widget) ===<span> get_called_class()) { </span><span> 76</span> echo $widget->run(); <span>//</span><span>如果删除的实例类名和当前调用类名相同,输出小部件的内容</span> <span> 77</span> <span>return</span><span> $widget; </span><span> 78</span> } <span>else</span><span> { </span><span> 79</span> <span>throw</span> <span>new</span> InvalidCallException(<span>"</span><span>Expecting end() of </span><span>"</span> . get_class($widget) . <span>"</span><span>, found </span><span>"</span><span> . get_called_class()); </span><span> 80</span> <span> } </span><span> 81</span> } <span>else</span><span> { </span><span> 82</span> <span>throw</span> <span>new</span> InvalidCallException(<span>"</span><span>Unexpected </span><span>"</span> . get_called_class() . <span>'</span><span>::end() call. A matching begin() is not found.</span><span>'</span><span>); </span><span> 83</span> <span> } </span><span> 84</span> <span> } </span><span> 85</span> <span> 86</span> <span>/*</span><span>* </span><span> 87</span> <span> * Creates a widget instance and runs it. 创建一个部件实例,并运行 </span><span> 88</span> <span> * The widget rendering result is returned by this method. 返回部件渲染的结果。 </span><span> 89</span> <span> * @param array $config name-value pairs that will be used to initialize the object properties </span><span> 90</span> <span> * 用于初始化对象属性的参数 </span><span> 91</span> <span> * @return string the rendering result of the widget. 控件的渲染结果。 </span><span> 92</span> <span>*/</span> <span> 93</span> <span>public</span> <span>static</span> function widget($config =<span> []) </span><span> 94</span> <span> { </span><span> 95</span> ob_start(); <span>//</span><span>打开输出缓冲区</span> <span> 96</span> ob_implicit_flush(<span>false</span>);<span>//</span><span>关闭绝对刷新</span> <span> 97</span> <span>/*</span><span> @var $widget Widget </span><span>*/</span> <span> 98</span> $config[<span>'</span><span>class</span><span>'</span>] = get_called_class(); <span>//</span><span>获取调用类的类名</span> <span> 99</span> $widget = Yii::createObject($config); <span>//</span><span>实例化类</span> <span>100</span> $<span>out</span> = $widget->run();<span>//</span><span>运行部件</span> <span>101</span> <span>102</span> <span>return</span> ob_get_clean() . $<span>out</span>; <span>//</span><span>返回内部缓冲区的内容,关闭缓冲区</span> <span>103</span> <span> } </span><span>104</span> <span>105</span> <span>private</span><span> $_id; </span><span>106</span> <span>107</span> <span>/*</span><span>* </span><span>108</span> <span> * Returns the ID of the widget. 返回插件的标识 </span><span>109</span> <span> * @param boolean $autoGenerate whether to generate an ID if it is not set previously </span><span>110</span> <span> * 是否生成一个唯一标识,如果没有设置 </span><span>111</span> <span> * @return string ID of the widget. 部件唯一标识 </span><span>112</span> <span>*/</span> <span>113</span> <span>public</span> function getId($autoGenerate = <span>true</span><span>) </span><span>114</span> <span> { </span><span>115</span> <span>if</span> ($autoGenerate && $<span>this</span>->_id === <span>null</span><span>) { </span><span>116</span> <span>//</span><span>如果标识为空,并且设置为允许自动生成标识,自动生成</span> <span>117</span> $<span>this</span>->_id = <span>static</span>::$autoIdPrefix . <span>static</span>::$counter++<span>; </span><span>118</span> <span> } </span><span>119</span> <span>120</span> <span>return</span> $<span>this</span>-><span>_id; </span><span>121</span> <span> } </span><span>122</span> <span>123</span> <span>/*</span><span>* </span><span>124</span> <span> * Sets the ID of the widget. 设置小部件标识 </span><span>125</span> <span> * @param string $value id of the widget. 部件的标识。 </span><span>126</span> <span>*/</span> <span>127</span> <span>public</span><span> function setId($value) </span><span>128</span> <span> { </span><span>129</span> $<span>this</span>->_id =<span> $value; </span><span>130</span> <span> } </span><span>131</span> <span>132</span> <span>private</span><span> $_view; </span><span>133</span> <span>134</span> <span>/*</span><span>* </span><span>135</span> <span> * Returns the view object that can be used to render views or view files.返回视图对象 </span><span>136</span> <span> * The [[render()]] and [[renderFile()]] methods will use </span><span>137</span> <span> * this view object to implement the actual view rendering. </span><span>138</span> <span> * [render()]和[renderFile()]方法用视图对象实现实际的视图显示。 </span><span>139</span> <span> * If not set, it will default to the "view" application component. </span><span>140</span> <span> * @return \yii\web\View the view object that can be used to render views or view files. </span><span>141</span> <span>*/</span> <span>142</span> <span>public</span><span> function getView() </span><span>143</span> <span> { </span><span>144</span> <span>if</span> ($<span>this</span>->_view === <span>null</span><span>) { </span><span>145</span> $<span>this</span>->_view = Yii::$app->getView();<span>//</span><span>如果视图对象为空,调用getView()取得视图对象实例</span> <span>146</span> <span> } </span><span>147</span> <span>148</span> <span>return</span> $<span>this</span>-><span>_view; </span><span>149</span> <span> } </span><span>150</span> <span>151</span> <span>/*</span><span>* </span><span>152</span> <span> * Sets the view object to be used by this widget. 设置当前部件调用的视图对象实例 </span><span>153</span> <span> * @param View $view the view object that can be used to render views or view files. </span><span>154</span> <span>*/</span> <span>155</span> <span>public</span><span> function setView($view) </span><span>156</span> <span> { </span><span>157</span> $<span>this</span>->_view = $view;<span>//</span><span>要用的视图对象</span> <span>158</span> <span> } </span><span>159</span> <span>160</span> <span>/*</span><span>* </span><span>161</span> <span> * Executes the widget. 执行部件 </span><span>162</span> <span> * @return string the result of widget execution to be outputted. </span><span>163</span> <span> * 控件执行的结果输出。 </span><span>164</span> <span>*/</span> <span>165</span> <span>public</span><span> function run() </span><span>166</span> <span> { </span><span>167</span> <span> } </span><span>168</span> <span>169</span> <span>/*</span><span>* </span><span>170</span> <span> * Renders a view. </span><span>171</span> <span> * The view to be rendered can be specified in one of the following formats: </span><span>172</span> <span> * 渲染一个视图 实际调用View类中的同名方法 渲染的视图可以用下列方式指定路径 </span><span>173</span> <span> * - path alias (e.g. "@app/views/site/index"); </span><span>174</span> <span> * - absolute path within application (e.g. "//site/index"): the view name starts with double slashes. </span><span>175</span> <span> * The actual view file will be looked for under the [[Application::viewPath|view path]] of the application. </span><span>176</span> <span> * - absolute path within module (e.g. "/site/index"): the view name starts with a single slash. </span><span>177</span> <span> * The actual view file will be looked for under the [[Module::viewPath|view path]] of the currently </span><span>178</span> <span> * active module. </span><span>179</span> <span> * - relative path (e.g. "index"): the actual view file will be looked for under [[viewPath]]. </span><span>180</span> <span> * </span><span>181</span> <span> * If the view name does not contain a file extension, it will use the default one `.php`. </span><span>182</span> <span> * </span><span>183</span> <span> * @param string $view the view name. 视图名 </span><span>184</span> <span> * @param array $params the parameters (name-value pairs) that should be made available in the view. </span><span>185</span> <span> * 在视图中可用的参数 </span><span>186</span> <span> * @return string the rendering result. 渲染结果 </span><span>187</span> <span> * @throws InvalidParamException if the view file does not exist. </span><span>188</span> <span>*/</span> <span>189</span> <span>public</span> function render($view, $<span>params</span> =<span> []) </span><span>190</span> <span> { </span><span>191</span> <span>//</span><span>调用view类中的render渲染指定的视图</span> <span>192</span> <span>return</span> $<span>this</span>->getView()->render($view, $<span>params</span>, $<span>this</span><span>); </span><span>193</span> <span> } </span><span>194</span> <span>195</span> <span>/*</span><span>* </span><span>196</span> <span> * Renders a view file. 渲染一个视图文件 同上 </span><span>197</span> <span> * @param string $file the view file to be rendered. This can be either a file path or a path alias. </span><span>198</span> <span> * @param array $params the parameters (name-value pairs) that should be made available in the view. </span><span>199</span> <span> * @return string the rendering result. </span><span>200</span> <span> * @throws InvalidParamException if the view file does not exist. </span><span>201</span> <span>*/</span> <span>202</span> <span>public</span> function renderFile($file, $<span>params</span> =<span> []) </span><span>203</span> <span> { </span><span>204</span> <span>return</span> $<span>this</span>->getView()->renderFile($file, $<span>params</span>, $<span>this</span><span>); </span><span>205</span> <span> } </span><span>206</span> <span>207</span> <span>/*</span><span>* </span><span>208</span> <span> * Returns the directory containing the view files for this widget. 返回视图文件路径 </span><span>209</span> <span> * The default implementation returns the 'views' subdirectory under the directory containing the widget class file. </span><span>210</span> <span> * @return string the directory containing the view files for this widget. </span><span>211</span> <span>*/</span> <span>212</span> <span>public</span><span> function getViewPath() </span><span>213</span> <span> { </span><span>214</span> $<span>class</span> = <span>new</span> ReflectionClass($<span>this</span><span>); </span><span>215</span> <span>//</span><span>取得部件类文件的目录,拼接为视图目录</span> <span>216</span> <span>return</span> dirname($<span>class</span>->getFileName()) . DIRECTORY_SEPARATOR . <span>'</span><span>views</span><span>'</span><span>; </span><span>217</span> <span> } </span><span>218</span> }

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

小红书笔记怎么删除?在小红书APP中是可以编辑笔记的,多数的用户不知道小红书笔记如何的删除,接下来就是小编为用户带来的小红书笔记删除方法图文教程,感兴趣的用户快来一起看看吧!小红书使用教程小红书笔记怎么删除1、首先打开小红书APP进入到主页面,选择右下角【我】进入到专区;2、之后在我的专区,点击下图所示的笔记页面,选择要删除的笔记;3、进入到笔记页面,右上角【三个点】;4、最后下方会展开功能栏,点击【删除】即可完成。

作为一名小红书的用户,我们都曾遇到过发布过的笔记突然不见了的情况,这无疑让人感到困惑和担忧。在这种情况下,我们该怎么办呢?本文将围绕“小红书发布过的笔记不见了怎么办”这一主题,为你详细解答。一、小红书发布过的笔记不见了怎么办?首先,不要惊慌。如果你发现笔记不见了,保持冷静是关键,不要慌张。这可能是由于平台系统故障或操作失误引起的。检查发布记录很简单。只需打开小红书App,点击“我”→“发布”→“所有发布”,就可以查看自己的发布记录。在这里,你可以轻松找到之前发布的笔记。3.重新发布。如果找到了之

小红书怎么在笔记中添加商品链接?在小红书这款app中用户不仅可以浏览各种内容还可以进行购物,所以这款app中关于购物推荐、好物分享的内容是非常多的,如果小伙伴在这款app也是一个达人的话,也可以分享一些购物经验,找到商家进行合作,在笔记中添加连接之类的,很多人都愿意使用这款app购物,因为不仅方便,而且有很多达人会进行一些推荐,可以一边浏览有趣内容,一边看看有没有适合自己的衣服商品。一起看看如何在笔记中添加商品链接吧!小红书笔记添加商品链接方法 在手机桌面上打开app。 在app首页点击

在word中编辑文字内容时,有时会需要输入公式符号。有的小伙们不知道在word根号输入的方法,小面就让小编跟小伙伴们一起分享下word根号输入的方法教程。希望对小伙伴们有所帮助。首先,打开电脑上的Word软件,然后打开要编辑的文件,并将光标移动到需要插入根号的位置,参考下方的图片示例。2.选择【插入】,再选择符号里的【公式】。如下方的图片红色圈中部分内容所示:3.接着选择下方的【插入新公式】。如下方的图片红色圈中部分内容所示:4.选择【根式】,再选择合适的根号。如下方的图片红色圈中部分内容所示:

如何解决jQueryAJAX报错403的问题?在开发网页应用程序时,经常会使用jQuery来发送异步请求。然而,有时候在使用jQueryAJAX时可能会遇到错误代码403,表示服务器禁止访问。这种情况通常是由服务器端的安全设置所导致的,但可以通过一些方法来解决这个问题。本文将介绍如何解决jQueryAJAX报错403的问题,并提供具体的代码示例。一、使

学习C语言的魅力:解锁程序员的潜力随着科技的不断发展,计算机编程已经成为了一个备受关注的领域。在众多编程语言中,C语言一直以来都备受程序员的喜爱。它的简单、高效以及广泛应用的特点,使得学习C语言成为了许多人进入编程领域的第一步。本文将讨论学习C语言的魅力,以及如何通过学习C语言来解锁程序员的潜力。首先,学习C语言的魅力在于其简洁性。相比其他编程语言而言,C语

PHP代码在浏览器中如何显示源码而不被解释执行?PHP是一种服务器端脚本语言,通常用于开发动态网页。当PHP文件在服务器上被请求时,服务器会解释执行其中的PHP代码,并将最终的HTML内容发送到浏览器以供显示。然而,有时我们希望在浏览器中直接展示PHP文件的源代码,而不是被执行。本文将介绍如何在浏览器中显示PHP代码的源码,而不被解释执行。在PHP中,可以使

标题:从零开始学习Go语言中的main函数Go语言作为一种简洁、高效的编程语言,备受开发者青睐。在Go语言中,main函数是一个入口函数,每个Go程序都必须包含main函数作为程序的入口点。本文将从零开始介绍如何学习Go语言中的main函数,并提供具体的代码示例。一、首先,我们需要安装Go语言的开发环境。可以前往官方网站(https://golang.org
