热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Yii框架分析(九)——视图渲染流程

Yii框架分析(九)——视图渲染流程

MVC架构中,View主要是用于展示信息的。Yii中的视图层文件由2部分组成:布局视图、部分视图。web系统的大部分页面都存在相同的元素:logo、菜单、foot栏等,我们把这些相同的元素组成的视图文件称为布局视图,一般web系统需要2个布局,即前台布局和后台布局,前台布局是给用户看的,后台布局是给管理员看的。每个页面所独有的部分视图称为部分视图。

视图布局

可以使用上图进行描述,我们将菜单栏、导航栏和Footer栏放到布局文件中,即所有页面复用一个布局文件,然后每个页面(Action)有各自的部分视图文件。
接下来看一下视图文件的存放路径。WebApp可以配置视图文件路径和布局文件路径同时还会指定一个默认的布局文件;每个Controller的视图文件存放在WebApp指定的视图路径下,以Controller的名字职位后缀,Controller还可以指定自己使用哪个布局文件。
WebApp成员属性 说明
viewPath 用于指定视图文件路径,所有的视图文件必须在这个文件下
默认protected/views
layoutPath 用于指定布局文件路径,所有的布局文件必须在这个文件下
默认protected/views/layouts,该路径下有:main.php、column.php
viewPath 用于指定系统视图文件路径,默认protected/views/system
layout 指定默认使用的布局文件,默认为main

比如当前正在执行PostController的modifyAction,PostController指定使用column布局,那么这个请求所使用的布局文件为protected/views/layouts/column.php,视图文件为protected/views/post/modify.php。
视图层中还有2个重要的概念:客户端脚本组件、Widget。
客户端脚本组件:该组件用于管理客户端脚本(Javascript和css),可以通过该组件向视图中添加Javascript和css,客户端脚本组件统一管理这些代码,在页面输出的最后一步对客户端脚本(Javascript和css)进行渲染。
Widget:又称小物件,通过Widget可以对页面进行模块化,Widget可以看成是一个没有布局的控制器。通过Widget可以把公用的页面元素进行复用,比如:Menu Widget、列表Widget、表格Widget、分页Widget等等。

视图渲染流程

视图层的渲染分3个步骤完成:
Step1:渲染部分视图,即渲染每个页面各自特有的视图片断;
Step2:将渲染布局视图,即即渲染每个页面共有的页面元素,同时将Step1的结果插入到布局视图中。在Step1和Step2中,可能还需要渲染Widget,比如日历Widget、菜单Widget等。这2个步骤中可以注册自己使用了哪些js和css;
Step3:渲染js和css。将前2步注册的js和css添加到html页面的制定位置。

由于加载顺序的原因,导致的结果是在部分视图中使用registerCssFile或者registerScriptFile导入的css文件或者js文件会出现在布局视图文件中注册的css或js文件之前,造成页面样式及动态效果的混乱,如何解决这个问题呢?

其实很简单,那就是在protected/components/Controller.php中重写init方法,将布局视图中的注册全局js或css文件的方法定义在init方法中即可:

public function init(){
    Yii::app()->clientScript->registerCoreScript('jquery');
    Yii::app()->clientScript->registerCssFile(Yii::app()->baseUrl . '/css/style.css');
    parent::init();
}

这样就可以保证jquery.js和style.css文件在所有其他js及css文件之前定义在head标签中。


推荐阅读
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • MySQL锁机制详解
    本文深入探讨了MySQL中的锁机制,包括表级锁、行级锁以及元数据锁,通过实例详细解释了各种锁的工作原理及其应用场景。同时,文章还介绍了如何通过锁来优化数据库性能,避免常见的并发问题。 ... [详细]
  • 本文深入探讨了JavaScript中实现继承的四种常见方法,包括原型链继承、构造函数继承、组合继承和寄生组合继承。对于正在学习或从事Web前端开发的技术人员来说,理解这些继承模式对于提高代码质量和维护性至关重要。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 深入解析Spring Boot自动配置机制
    本文旨在深入探讨Spring Boot的自动配置机制,特别是如何利用配置文件进行有效的设置。通过实例分析,如Http编码自动配置,我们将揭示配置项的具体作用及其背后的实现逻辑。 ... [详细]
  • Asp.net MVC 中 Bundle 配置详解:合并与压缩 JS 和 CSS 文件
    本文深入探讨了 Asp.net MVC 中如何利用 Bundle 功能来合并和压缩 JavaScript 和 CSS 文件,提供了详细的配置步骤和示例代码,适合开发人员参考学习。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
author-avatar
如果你在的时候的世界_266
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有