博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
yii2 视图(布局)中各种函数总结报告及使用场景
阅读量:6520 次
发布时间:2019-06-24

本文共 3060 字,大约阅读时间需要 10 分钟。

yii2布局文件里有很多函数,你是否研究过他们都是干嘛用的?这篇文章告诉你~

我们以安装完yii2程序后默认的布局为例说明

// @app/views/layouts/main.php/* @var $this \yii\web\View *//* @var $content string */use yii\helpers\Html;use yii\widgets\Breadcrumbs;use app\assets\AppAsset;AppAsset::register($this);?>
beginPage() ?>
<?= Html::encode($this->title) ?>
head() ?>
beginBody() ?>

© My Company

endBody() ?>
endPage() ?>复制代码

首先要说的是,布局其实就是视图,一种特殊的视图而已,所以我们明说布局函数,实质在说视图类View。

我就是我 $this

既然是一种特殊的视图,所以布局里面的 $this 对象其实就是当前视图本身,这在默认布局的注释里已经说明。

/* @var $this \yii\web\View *//* @var $content string */复制代码

所以我建议你在阅读本文的时候,打开yii\web\View源代码同步进行。

写啥是啥 $content

这是在布局文件里除了 $this 外的第二个变量,我们都知道布局就像一个容器一样将基础架构先画出来,然后想用此结构的视图直接使用就可以了,那么 $content 就是使用此布局的视图自己的内容。

开山函数 beginPage 和 endPage

记住,所有的HTML我们都应该包含在 beginPage 和 endPage 函数之间,它们代表一个页面的开始和结束。

之外它们还分别触发了下面的两个事件

View::EVENT_BEGIN_PAGEView::EVENT_END_PAGE复制代码

如果你想统计视图页面内代码的渲染时间,可以在这两个事件上做做手脚。当然,endPage的作用要更加大,后面会单独拿出来说明。

资源在哪我说的算 head()

确切的说,该函数只是告诉了yii要将资源文件(比如js和css)放到页面的哪里,一般它在head标签内,如果你将它移到其他地方,你会发现将来页面的js文件和css文件等也转移了。

head有啥我来做 renderHeadHtml()

从名字你就可以知道,它负责将头部的一些代码渲染出来,比如js和css等文件的具体html标签,具体放哪?那必须是放到head()函数里指定的位置了,另外,这是一个protected类型方法,你不要想着能直接->就调用它,没门,它仅仅为View类的其他方法服务。

beginBody 和 endBody

这两个函数和 beginPage 和 endPage 有雷同的地方,就是做了两个标记,代表body的开始和结束,作为位置标签,另外也触发了两个事件

View::EVENT_BEGIN_BODYView::EVENT_END_BODY复制代码

当然 endBody 和 endPage 一样,还有其他职责,放到最后说,你先了解他们代表开始和结束,同时触发事件即可。

中场总结

上面说了 head、beginBody、endBody 都具有标签的作用,View为其设计了3个常量作为代表,分别如下

PH_HEAD // $this->head()PH_BODY_BEGIN // $this->beginBody()PH_BODY_END // $this->endBody复制代码

根据我们上面的了解,先画一个图出来,看看布局的可视化样子。

// 我是图$this->beginPage()- -- $this->head() // PH_HEAD-- -- $this->beginBody() // PH_BODY_BEGIN$content$this->endBody() // PH_BODY_END-- - $this->endPage()复制代码

renderBodyBeginHtml 和 renderBodyEndHtml 函数

上面我们知道有一个叫做 renderHeadHtml 方法负责往 PH_HEAD 位置放资源文件,那么PH_BODY_BEGIN和PH_BODY_END 也应该同类待遇,renderBodyBeginHtml和renderBodyEndHtml就是干这个的。

而从代码来看 renderBodyBeginHtml 和 renderBodyEndHtml 做的事情和 renderHeadHtml 差不多,都是资源的具体代码话,你是否记得我们在兄弟连时候有一节( )说过关于asset资源类位置的问题(指定资源在页面的上部还是下部),对,renderBodyBeginHtml、renderBodyEndHtml 等就是做这个的。

我们分条说下

  • renderBodyBeginHtml渲染的是位置为 POS_BEGIN 的js文件
  • renderBodyEndHtml渲染的是位置为 POS_END、POS_READY、POS_LOAD的js文件
  • renderHeadHtml渲染的是位置为POS_HEAD的js文件和所有css文件(无位置功能)以及一些head的metaTags。

现在你明白了吧,到此刻,你知道了有三个函数负责三个位置的代码渲染,而这些渲染其实就是资源的代码实现。

再说endPage

到现在,万事俱备,但是东风在哪里?它就是endPage

看一部分endPage的源代码我们

echo strtr($content, [    self::PH_HEAD => $this->renderHeadHtml(),    self::PH_BODY_BEGIN => $this->renderBodyBeginHtml(),    self::PH_BODY_END => $this->renderBodyEndHtml($ajaxMode),]);复制代码

endPage活生生的实现了代码和位置之间的替换,说白了就是字符串替换。。。

当然,在View类里还有一些小方法,比如registerJs()、clear()等等,阿北相信当你了解了布局(视图)形成的流程后,这些很容易看懂,如果还不懂,请留言此贴问。

最后一个例子

如果我们把最后相应给客户的页面比作一栋大楼。那么看看角色的分类

  • 布局 代表大楼图纸(代表着一个框架)
  • 资源类 代表购物清单
  • View的三个render函数 代表具体的建筑工人,采购资源类,并放到大楼里。
  • endPage函数,就是售楼许可证,保证所有资源都到位。
  • 使用布局的视图 就是人,入驻大楼,没有视图的布局都是纸老虎。

(完)

本文原创发布于微信公众号 北哥小报 , 严谨的原创技术文,Q群:171277552。

微信扫码可以关注

转载地址:http://xvrfo.baihongyu.com/

你可能感兴趣的文章
Android第三方开源FloatingActionButton(com.getbase.floatingactionbutton)【1】
查看>>
【75位联合作者Nature重磅】AI药神:机器学习模型有望提前五年预测白血病!
查看>>
精通SpringBoot——第二篇:视图解析器,静态资源和区域配置
查看>>
JavaScript基础(六)面向对象
查看>>
总结几点Quartz的经验
查看>>
从veth看虚拟网络设备的qdisc
查看>>
企业的最佳选择?开放式混合云大行其道
查看>>
物联网、自动化的冲击下未来20年职场六大趋势
查看>>
《Java核心技术 卷Ⅱ 高级特性(原书第10版)》一3.6.2 使用StAX解析器
查看>>
9月26日云栖精选夜读:阿里Java代码规约插件即将全球首发,邀您来发布仪式现场...
查看>>
日立预计08财年亏损78亿美元 将裁员7千人
查看>>
北京市交管局联合高德地图发布北京中考出行提示
查看>>
四步奠定SDN部署基石
查看>>
防火墙迁移:提高安全弹性与可用性的5种方
查看>>
如何防止应用程序泄密?
查看>>
一文带你看懂物联网开源操作系统
查看>>
【短视频SDK】短视频SDK License的策略
查看>>
什么是实践中真正在用的数据科学系统?
查看>>
台积电:高雄地震对生产影响比预期略高
查看>>
新型智慧城市:构建“互联网+”新生活
查看>>