位置: 编程技术 - 正文

详解PHP的Yii框架中自带的前端资源包的使用(php框架有哪些官网)

编辑:rootadmin

推荐整理分享详解PHP的Yii框架中自带的前端资源包的使用(php框架有哪些官网),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php框架介绍,php各大框架以及实现原理,php框架ci,php框架介绍,php框架symfony,php框架ci,php yii框架,php框架介绍,内容如对您有帮助,希望把文章链接给更多的朋友!

Yii中的资源是和Web页面相关的文件,可为CSS文件,JavaScript文件,图片或视频等, 资源放在Web可访问的目录下,直接被Web服务器调用。

通过程序自动管理资源更好一点,例如,当你在页面中使用 yiijuiDatePicker 小部件时, 它会自动包含需要的CSS和JavaScript文件,而不是要求你手工去找到这些文件并包含, 当你升级小部件时,它会自动使用新版本的资源文件,在本教程中,我们会详述Yii提供的强大的资源管理功能。

资源包

Yii在资源包中管理资源,资源包简单的说就是放在一个目录下的资源集合, 当在视图中注册一个资源包,在渲染Web页面时会包含包中的CSS和JavaScript文件。

定义资源包

资源包指定为继承yiiwebAssetBundle的PHP类,包名为可自动加载的PHP类名, 在资源包类中,要指定资源所在位置,包含哪些CSS和JavaScript文件以及和其他包的依赖关系。

如下代码定义基础应用模板使用的主要资源包:

如上AppAsset 类指定资源文件放在 @webroot 目录下,对应的URL为 @web,资源包中包含一个CSS文件 css/site.css,没有JavaScript文件, 依赖其他两个包 yiiwebYiiAsset 和 yiibootstrapBootstrapAsset, 关于yiiwebAssetBundle 的属性的更多详细如下所述:

yiiwebAssetBundle::sourcePath: 指定包包含资源文件的根目录, 当根目录不能被Web访问时该属性应设置,否则,应设置 yiiwebAssetBundle::basePath 属性和yiiwebAssetBundle::baseUrl。 路径别名 可在此处使用; yiiwebAssetBundle::basePath: 指定包含资源包中资源文件并可Web访问的目录, 当指定yiiwebAssetBundle::sourcePath 属性, 资源管理器 会发布包的资源到一个可Web访问并覆盖该属性, 如果你的资源文件在一个Web可访问目录下,应设置该属性,这样就不用再发布了。 路径别名 可在此处使用。

yiiwebAssetBundle::baseUrl: 指定对应到yiiwebAssetBundle::basePath目录的URL, 和 yiiwebAssetBundle::basePath 类似,如果你指定 yiiwebAssetBundle::sourcePath 属性, 资源管理器 会发布这些资源并覆盖该属性,路径别名 可在此处使用。yiiwebAssetBundle::js: 一个包含该资源包JavaScript文件的数组,注意正斜杠"/"应作为目录分隔符, 每个JavaScript文件可指定为以下两种格式之一:

相对路径表示为本地JavaScript文件 (如 js/main.js),文件实际的路径在该相对路径前加上 yiiwebAssetManager::basePath,文件实际的URL在该路径前加上yiiwebAssetManager::baseUrl。 绝对URL地址表示为外部JavaScript文件,如 或//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js. yiiwebAssetBundle::css: 一个包含该资源包JavaScript文件的数组,该数组格式和 yiiwebAssetBundle::js 相同。 yiiwebAssetBundle::depends: 一个列出该资源包依赖的其他资源包(后两节有详细介绍)。 yiiwebAssetBundle::jsOptions: 当调用yiiwebView::registerJsFile()注册该包 每个 JavaScript文件时, 指定传递到该方法的选项。 yiiwebAssetBundle::cssOptions: 当调用yiiwebView::registerCssFile()注册该包 每个 css文件时, 指定传递到该方法的选项。 yiiwebAssetBundle::publishOptions: 当调用yiiwebAssetManager::publish()发布该包资源文件到Web目录时 指定传递到该方法的选项,仅在指定了yiiwebAssetBundle::sourcePath属性时使用。

资源位置

资源根据它们的位置可以分为:

源资源: 资源文件和PHP源代码放在一起,不能被Web直接访问,为了使用这些源资源,它们要拷贝到一个可Web访问的Web目录中 成为发布的资源,这个过程称为发布资源,随后会详细介绍。发布资源: 资源文件放在可通过Web直接访问的Web目录中;外部资源: 资源文件放在你的Web应用不同的Web服务器上;当定义资源包类时候,如果你指定了yiiwebAssetBundle::sourcePath 属性,就表示任何使用相对路径的资源会被 当作源资源;如果没有指定该属性,就表示这些资源为发布资源(因此应指定yiiwebAssetBundle::basePath 和 yiiwebAssetBundle::baseUrl 让Yii知道它们的位置)。

推荐将资源文件放到Web目录以避免不必要的发布资源过程,这就是之前的例子指定 yiiwebAssetBundle::basePath 而不是 yiiwebAssetBundle::sourcePath.

对于 扩展来说,由于它们的资源和源代码都在不能Web访问的目录下, 在定义资源包类时必须指定yiiwebAssetBundle::sourcePath属性。

注意: yiiwebAssetBundle::sourcePath 属性不要用@webroot/assets,该路径默认为 yiiwebAssetManager资源管理器将源资源发布后存储资源的路径,该路径的所有内容会认为是临时文件, 可能会被删除。资源依赖

当Web页面包含多个CSS或JavaScript文件时,它们有一定的先后顺序以避免属性覆盖, 例如,Web页面在使用jQuery UI小部件前必须确保jQuery JavaScript文件已经被包含了, 我们称这种资源先后次序称为资源依赖。

资源依赖主要通过yiiwebAssetBundle::depends 属性来指定, 在AppAsset 示例中,资源包依赖其他两个资源包: yiiwebYiiAsset 和 yiibootstrapBootstrapAsset 也就是该资源包的CSS和JavaScript文件要在这两个依赖包的文件包含 之后 才包含。

资源依赖关系是可传递,也就是人说A依赖B,B依赖C,那么A也依赖C。

资源选项

可指定yiiwebAssetBundle::cssOptions 和 yiiwebAssetBundle::jsOptions 属性来自定义页面包含CSS和JavaScript文件的方式, 这些属性值会分别传递给 yiiwebView::registerCssFile() 和 yiiwebView::registerJsFile() 方法, 在视图 调用这些方法包含CSS和JavaScript文件时。

注意: 在资源包类中设置的选项会应用到该包中 每个 CSS/JavaScript 文件,如果想对每个文件使用不同的选项, 应创建不同的资源包并在每个包中使用一个选项集。例如,只想IE9或更高的浏览器包含一个CSS文件,可以使用如下选项:

这会是包中的CSS文件使用以下HTML标签包含进来:

为链接标签包含<noscript>可使用如下代码:

为使JavaScript文件包含在页面head区域(JavaScript文件默认包含在body的结束处)使用以下选项:

Bower 和 NPM 资源

大多数 JavaScript/CSS 包通过Bower 和/或 NPM管理, 如果你的应用或扩展使用这些包,推荐你遵循以下步骤来管理库中的资源:

修改应用或扩展的 composer.json 文件将包列入require 中, 应使用bower-asset/PackageName (Bower包) 或 npm-asset/PackageName (NPM包)来对应库。创建一个资源包类并将你的应用或扩展要使用的JavaScript/CSS 文件列入到类中, 应设置 yiiwebAssetBundle::sourcePath 属性为@bower/PackageName 或 @npm/PackageName, 因为根据别名Composer会安装Bower或NPM包到对应的目录下。注意: 一些包会将它们分布式文件放到一个子目录中,对于这种情况,应指定子目录作为 yiiwebAssetBundle::sourcePath属性值,例如,yiiwebJqueryAsset使用 @bower/jquery/dist 而不是 @bower/jquery。使用资源包

为使用资源包,在视图中调用yiiwebAssetBundle::register()方法先注册资源, 例如,在视图模板可使用如下代码注册资源包:

如果在其他地方注册资源包,应提供视图对象,如在 小部件 类中注册资源包, 可以通过 $this->view 获取视图对象。

当在视图中注册一个资源包时,在背后Yii会注册它所依赖的资源包,如果资源包是放在Web不可访问的目录下,会被发布到可访问的目录, 后续当视图渲染页面时,会生成这些注册包包含的CSS和JavaScript文件对应的<link> 和 <script> 标签, 这些标签的先后顺序取决于资源包的依赖关系以及在 yiiwebAssetBundle::css和yiiwebAssetBundle::js 的列出来的前后顺序。

自定义资源包

Yii通过名为 assetManager的应用组件实现[[yiiwebAssetManager] 来管理应用组件, 通过配置yiiwebAssetManager::bundles 属性,可以自定义资源包的行为, 例如,yiiwebJqueryAsset 资源包默认从jquery Bower包中使用jquery.js 文件, 为了提高可用性和性能,你可能需要从Google服务器上获取jquery文件,可以在应用配置中配置assetManager,如下所示:

可通过类似yiiwebAssetManager::bundles配置多个资源包,数组的键应为资源包的类名(最开头不要反斜杠), 数组的值为对应的配置数组.

提示: 可以根据条件判断使用哪个资源,如下示例为如何在开发环境用jquery.js,否则用jquery.min.js:

可以设置资源包的名称对应false来禁用想禁用的一个或多个资源包,当视图中注册一个禁用资源包, 视图不会包含任何该包的资源以及不会注册它所依赖的包,例如,为禁用yiiwebJqueryAsset,可以使用如下配置:

可设置yiiwebAssetManager::bundles为false禁用 所有 的资源包。

资源部署

有时你想"修复" 多个资源包中资源文件的错误/不兼容,例如包A使用1..1版本的jquery.min.js, 包B使用2.1.1版本的jquery.js,可自定义每个包来解决这个问题,更好的方式是使用资源部署特性来部署不正确的资源为想要的, 为此,配置yiiwebAssetManager::assetMap属性,如下所示:

yiiwebAssetManager::assetMap的键为你想要修复的资源名,值为你想要使用的资源路径, 当视图注册资源包,在yiiwebAssetBundle::css 和 yiiwebAssetBundle::js 数组中每个相关资源文件会和该部署进行对比, 如果数组任何键对比为资源文件的最后文件名(如果有的话前缀为 yiiwebAssetBundle::sourcePath),对应的值为替换原来的资源。 例如,资源文件my/path/to/jquery.js 匹配键 jquery.js.

详解PHP的Yii框架中自带的前端资源包的使用(php框架有哪些官网)

注意: 只有相对相对路径指定的资源对应到资源部署,替换的资源路径可以为绝对路径,也可为和yiiwebAssetManager::basePath相关的路径。资源发布

如前所述,如果资源包放在Web不能访问的目录,当视图注册资源时资源会被拷贝到一个Web可访问的目录中, 这个过程称为资源发布,yiiwebAssetManager会自动处理该过程。

资源默认会发布到@webroot/assets目录,对应的URL为@web/assets, 可配置yiiwebAssetManager::basePath 和 yiiwebAssetManager::baseUrl 属性自定义发布位置。

除了拷贝文件方式发布资源,如果操作系统和Web服务器允许可以使用符号链接,该功能可以通过设置 yiiwebAssetManager::linkAssets 为 true 来启用。

使用以上配置,资源管理器会创建一个符号链接到要发布的资源包源路径,这比拷贝文件方式快并能确保发布的资源一直为最新的。

常用资源包

Yii框架定义许多资源包,如下资源包是最常用,可在你的应用或扩展代码中引用它们。

yiiwebYiiAsset: 主要包含yii.js 文件,该文件完成模块JavaScript代码组织功能, 也为 data-method 和 data-confirm属性提供特别支持和其他有用的功能。 yiiwebJqueryAsset: 包含从jQuery bower 包的jquery.js文件。 yiibootstrapBootstrapAsset: 包含从Twitter Bootstrap 框架的CSS文件。 yiibootstrapBootstrapPluginAsset: 包含从Twitter Bootstrap 框架的JavaScript 文件来支持Bootstrap JavaScript插件。 yiijuiJuiAsset: 包含从jQuery UI库的CSS 和 JavaScript 文件。

如果你的代码需要jQuery, jQuery UI 或 Bootstrap,应尽量使用这些预定义资源包而非自己创建, 如果这些包的默认配置不能满足你的需求,可以自定义配置,详情参考自定义资源包。

资源转换

除了直接编写CSS 和/或 JavaScript代码,开发人员经常使用扩展语法来编写,再使用特殊的工具将它们转换成CSS/Javascript。 例如,对于CSS代码可使用LESS 或 SCSS, 对于JavaScript 可使用 TypeScript。

可将使用扩展语法的资源文件列到资源包的yiiwebAssetBundle::css 和 yiiwebAssetBundle::js中,如下所示:

当在视图中注册一个这样的资源包,yiiwebAssetManager资源管理器会自动运行预处理工具将使用扩展语法 的资源转换成CSS/JavaScript,当视图最终渲染页面时,在页面中包含的是CSS/Javascipt文件,而不是原始的扩展语法代码文件。

Yii使用文件扩展名来表示资源使用哪种扩展语法,默认可以识别如下语法和文件扩展名:

LESS: .less SCSS: .scss Stylus: .styl CoffeeScript: .coffee TypeScript: .ts

Yii依靠安装的预处理工具来转换资源,例如,为使用LESS,应安装lessc 预处理命令。

可配置yiiwebAssetManager::converter自定义预处理命令和支持的扩展语法,如下所示:

如上所示,通过yiiwebAssetConverter::commands 属性指定支持的扩展语法, 数组的键为文件扩展名(前面不要.),数组的值为目标资源文件扩展名和执行资源转换的命令, 命令中的标记 {from} 和{to}会分别被源资源文件路径和目标资源文件路径替代。

补充: 除了以上方式,也有其他的方式来处理扩展语法资源,例如,可使用编译工具如grunt 来监控并自动转换扩展语法资源,此时,应使用资源包中编译后的CSS/Javascript文件而不是原始文件。合并和压缩资源

一个Web页面可以包含很多CSS 和/或 JavaScript 文件,为减少HTTP 请求和这些下载文件的大小, 通常的方式是在页面中合并并压缩多个CSS/JavaScript 文件为一个或很少的几个文件,并使用压缩后的文件而不是原始文件。

补充: 合并和压缩资源通常在应用在产品上线模式,在开发模式下使用原始的CSS/JavaScript更方便调试。接下来介绍一种合并和压缩资源文件而不需要修改已有代码的方式:

找出应用中所有你想要合并和压缩的资源包,将这些包分成一个或几个组,注意每个包只能属于其中一个组,合并/压缩每个组里CSS文件到一个文件,同样方式处理JavaScript文件,为每个组定义新的资源包:设置yiiwebAssetBundle::css 和 yiiwebAssetBundle::js 属性分别为压缩后的CSS和JavaScript文件;自定义设置每个组内的资源包,设置资源包的yiiwebAssetBundle::css 和 yiiwebAssetBundle::js 属性为空, 并设置它们的 yiiwebAssetBundle::depends 属性为每个组新创建的资源包。使用这种方式,当在视图中注册资源包时,会自动触发原始包所属的组资源包的注册,然后,页面就会包含以合并/压缩的资源文件, 而不是原始文件。

示例

使用一个示例来解释以上这种方式:

鉴定你的应用有两个页面X 和 Y,页面X使用资源包A,B和C,页面Y使用资源包B,C和D。

有两种方式划分这些资源包,一种使用一个组包含所有资源包,另一种是将(A,B,C)放在组X,(B,C,C)放在组Y, 哪种方式更好?第一种方式优点是两个页面使用相同的已合并CSS和JavaScript文件使HTTP缓存更高效,另一方面,由于单个组包含所有文件, 已合并的CSS和Javascipt文件会更大,因此会增加文件传输时间,在这个示例中,我们使用第一种方式,也就是用一个组包含所有包。

补充: 将资源包分组并不是无价值的,通常要求分析现实中不同页面各种资源的数据量,开始时为简便使用一个组。在所有包中使用工具(例如 Closure Compiler, YUI Compressor) 来合并和压缩CSS和JavaScript文件, 注意合并后的文件满足包间的先后依赖关系,例如,如果包A依赖B,B依赖C和D,那么资源文件列表以C和D开始,然后为B最后为A。

合并和压缩之后,会得到一个CSS文件和一个JavaScript文件,假定它们的名称为all-xyz.css 和 all-xyz.js, xyz 为使文件名唯一以避免HTTP缓存问题的时间戳或哈希值。

现在到最后一步了,在应用配置中配置yiiwebAssetManager 资源管理器如下所示:

如自定义资源包 小节中所述,如上配置改变每个包的默认行为, 特别是包A、B、C和D不再包含任何资源文件,都依赖包含合并后的all-xyz.css 和 all-xyz.js文件的包all, 因此,对于页面X会包含这两个合并后的文件而不是包A、B、C的原始文件,对于页面Y也是如此。

最后有个方法更好地处理上述方式,除了直接修改应用配置文件,可将自定义包数组放到一个文件,在应用配置中根据条件包含该文件,例如:

如上所示,在产品上线模式下资源包数组存储在assets-prod.php文件中,不是产品上线模式存储在assets-dev.php文件中。

使用 asset 命令

Yii提供一个名为asset控制台命令来使上述操作自动处理。

为使用该命令,应先创建一个配置文件设置哪些资源包要合并以及分组方式,可使用asset/template 子命令来生成一个模板, 然后修改模板成你想要的。

该命令在当前目录下生成一个名为assets.php的文件,文件的内容类似如下:

应修改该文件的bundles的选项指定哪些包你想要合并,在targets选项中应指定这些包如何分组,如前述的可以指定一个或多个组。

注意: 由于在控制台应用别名 @webroot and @web 不可用,应在配置中明确指定它们。JavaScript文件会被合并压缩后写入到js/all-{hash}.js文件,其中 {hash} 会被结果文件的哈希值替换。

jsCompressor 和 cssCompressor 选项指定控制台命令或PHP回调函数来执行JavaScript和CSS合并和压缩, Yii默认使用Closure Compiler来合并JavaScript文件, 使用YUI Compressor来合并CSS文件, 你应手工安装这些工具或修改选项使用你喜欢的工具。

根据配置文件,可执行asset 命令来合并和压缩资源文件并生成一个新的资源包配置文件assets-prod.php:

yii asset assets.php config/assets-prod.php

php获取本机真实IP地址实例代码 本文实例为大家分享了php获取本机真实IP地址实例代码,供大家参考。主要是获取操作系统为win/xp、win7的本机IP真实地址,和获取操作系统为linux类型

PHP操作FTP类 (上传、下载、移动、创建等) 本文针对PHP操作FTP类进行详细介绍,php实现FTP上传、FTP下载、FTP移动、FTP创建等,供大家参考,具体内容如下1.使用PHP操作FTP-用法php//联接FTP服务器$conn=

PHP数学运算函数大汇总(经典值得收藏) 本文汇总分析了PHP数学运算函数。分享给大家供大家参考,具体如下:一、常用函数说明:Abs:取得绝对值。Acos:取得反余弦值。Asin:取得反正弦值。Atan:

标签: php框架有哪些官网

本文链接地址:https://www.jiuchutong.com/biancheng/293327.html 转载请保留说明!

上一篇:PHP-FPM实现性能优化(php ffi 性能)

下一篇:php获取本机真实IP地址实例代码(php获取本机ip地址)

  • 外贸企业出口流程图
  • 为客户购买的机票怎么退
  • 清包工取费标准
  • 财务担保费计入什么科目
  • 5000以下固定资产怎么做账
  • 注册资金证明包含哪些
  • 注册资本金实缴和认缴区别
  • 当前企业不存在是怎么回事
  • 固定资产投资转化为gdp比例
  • 建筑安装项目要求有哪些
  • 事业单位借款怎么做账
  • 实收资本印花税税率多少
  • 代销产品缴纳增值税吗
  • 代驾公司增值税怎么交
  • 因公出差的人身故怎么办
  • 收到投资款不做资本可以做什么?
  • 本月已认证发票还能撤销吗
  • 现金日记账对方科目是什么意思
  • 第一次申领发票可以增额吗?
  • 美团佣金收费标准结构图
  • 固定资产计提完折旧怎么处理
  • 上年费用未计提
  • 增值税出口服务包括什么
  • 原材料当做废品怎么做
  • php fwrite函数
  • linux抓包 udp
  • 元素垂直水平居中方式
  • 注意力机制cbam
  • html5/css3
  • 什么是多模态研究
  • layui树形下拉框
  • 增值税专用发票上注明的价款含税吗
  • 预缴所得税可以调减吗
  • 税务文书送达期限是多少天
  • mysql是自动提交的吗
  • 其他收益结转到什么账户
  • 个体户交个税新政策
  • 企业开办期间费用需要开发票吗
  • 去年的电费能查到吗
  • 纳税人申报的方法有哪些
  • SQL Server UPDATE语句的用法详解
  • 小规模纳税人附加税费
  • 信用减值损失是什么项目
  • 开发票,对方收取税点,如何计算?
  • 专项应付款转入资本公积的规定
  • 中标费用入什么科目
  • 新租赁准则入账
  • 不验旧能领购发票吗
  • 研发费用范围不包括
  • 小规模纳税人如何缴纳企业所得税
  • 会计做账什么意思
  • 支付宝里的收入和支出明细能查多久的?
  • windows2003怎么开启远程
  • XP系统怎么设置双屏幕
  • mac在哪设置
  • centos7 阿里云 yum
  • centos基础命令
  • 如何使用调制解调器
  • win8.1安装更新卡住
  • linux who am i
  • 电脑windows7打不开怎么办
  • win10 win+l
  • win10系统自带虚拟机怎么用
  • ,linux
  • opengl 输入框
  • 使用jQuery获取data-的自定义属性
  • android5种布局
  • android yield
  • jquery each return
  • 工作笔记都写什么内容
  • 前端跑马灯实现
  • 仿百度首页html代码静态
  • javascript的基本数据
  • 广西地方税务网站官网
  • 荆州市物业管理
  • 注册会计师和注册建造师哪个难考
  • 怎么找到税控系统发票作废怎么操作
  • 湖北国税网上办税大厅官网
  • 黄金消费税如何征收
  • 从哪个国家进口牛肉
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设