vue2.0 资源文件assets和static的区别详解


Posted in Javascript onApril 08, 2018

资源文件处理

在我们的项目结构里,有两个资源文件的路径,分别是:src/assets 和 static/。那这两个到底有什么区别呢?

Webpacked 资源

为了回答这个问题,我们首先需要理解webpack是怎样处理静态资源的。在*.vue组件中,所有的templates和css都会被vue-html-loader 和 css-loader解析,寻找资源的URL。

举个例子,在 <img src="./logo.png"> 和 background: url(./logo.png), “./logo.png”中,都是相对资源路径,都会被Webpack解析成模块依赖 。

由于logo.png不是JavaScript,当被看成一个模块依赖的时候,我们需要使用url-loader 和 file-loader进行处理。 该模板已经配置好了这些loaders,所以你能够使用相对/模块路径时不需要担心部署的问题。由于这些资源可能在构建的时候被内联/复制/重命名, 所以它们从本质上来说是你源码的一部分。这就是为什么我们建议将交由webpack处理的静态资源和其它源文件一样放在/src路径下面。实际上,你甚至不需要把它们全都放在/src/assets路径下:你可以基于模块/组件的使用来组织文件结构。例如,你可以把每个组件和属于它的静态资源放在它自己的目录下。

资源处理规则

相对URL, e.g. ./assets/logo.png 将会被解释成一个模块依赖。它们会被一个基于你的Webpack输出配置自动生成的URL替代。没有前缀的URL, e.g. assets/logo.png 将会被看成相对URL,并且转换成./assets/logo.png

前缀带~的URL 会被当成模块请求, 类似于require(‘some-module/image.png'). 如果你想要利用Webpack的模块处理配置,就可以使用这个前缀。例如,如果你有一个对于assets的路径解析,你需要使用 <img src="~assets/logo.png"> 来确保解析是对应上的。相对根目录的URL, e.g. /assets/logo.png 是不会被处理的

在 Javascript中获取资源路径

为了能让Webpack返回正确的资源路径,你需要使用require(‘./relative/path/to/file.jpg'),由file-loader进行解析,然后返回处理过的URL。例如:

computed: {
 background () {
  return require('./bgs/' + this.id + '.jpg')
 }
}

注意上面的例子,在最终的构建时将会包含./bgs/路径下的所有图片 这是因为Webpack不能猜出来在运行时会用到其中的哪个,所以会包含所有的。

“真实的” 静态资源

作为对比,在static/下的文件都不会被Webpack处理:它们使用相同的文件名,直接拷贝到最终的路径。你必须使用绝对路径来引用这些文件,取决于在config.js里面加入的build.assetsPublicPath 和 build.assetsSubDirectory。

举个例子,下面的默认值是:

// config/index.js
module.exports = {
 // ...
 build: {
  assetsPublicPath: '/',
  assetsSubDirectory: 'static'
 }
}

所有放在 static/目录下的文件都应该是使用绝对URL/static/[filename]引用的。如果你将assetSubDirectory的值改成assets, 那么这些URL就会被变成 /assets/[filename]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery如何通过name名称获取当前name的value值
Dec 20 Javascript
浅谈JavaScript 框架分类
Nov 10 Javascript
BootStrap CSS全局样式和表格样式源码解析
Jan 20 Javascript
整理关于Bootstrap列表组的慕课笔记
Mar 29 Javascript
JavaScript函数绑定用法实例分析
Nov 14 Javascript
详解基于vue的服务端渲染框架NUXT
Jun 20 Javascript
详解javascript appendChild()的完整功能
Aug 18 Javascript
Vue中插入HTML代码的方法
Sep 21 Javascript
浅谈开发eslint规则
Oct 01 Javascript
Element-ui自定义table表头、修改列标题样式、添加tooltip、:render-header使用
Apr 11 Javascript
node.js命令行教程图文详解
May 27 Javascript
详解Node.js如何处理ES6模块
May 15 Javascript
通过vue-router懒加载解决首次加载时资源过多导致的速度缓慢问题
Apr 08 #Javascript
vuex 项目结构目录及一些简单配置介绍
Apr 08 #Javascript
JS求Number类型数组中最大元素方法
Apr 08 #Javascript
angular2模块和共享模块详解
Apr 08 #Javascript
vue下拉列表功能实例代码
Apr 08 #Javascript
详解Vue-cli webpack移动端自动化构建rem问题
Apr 07 #Javascript
vue-cli开发环境实现跨域请求的方法
Apr 07 #Javascript
You might like
UCenter中的一个可逆加密函数authcode函数代码
2010/07/20 PHP
CodeIgniter中使用Smarty3基本配置
2015/06/29 PHP
支付宝服务窗API接口开发php版本
2016/07/20 PHP
PHP实现的mysql操作类【MySQL与MySQLi方式】
2017/10/07 PHP
Javascript 判断客户端浏览器类型代码
2010/03/01 Javascript
jQuery+slidereveal实现的面板滑动侧边展出效果
2015/03/14 Javascript
详解nodejs与javascript中的aes加密
2016/05/22 NodeJs
基于jQuery的AJAX和JSON实现纯html数据模板
2016/08/09 Javascript
socket.io学习教程之基本应用(二)
2017/04/29 Javascript
mui back 返回刷新页面的实例
2017/12/06 Javascript
Vue修改mint-ui默认样式的方法
2018/02/03 Javascript
对angularJs中controller控制器scope父子集作用域的实例讲解
2018/10/08 Javascript
[00:16]热血竞技场
2019/03/06 DOTA
自己使用总结Python程序代码片段
2015/06/02 Python
简单的python协同过滤程序实例代码
2018/01/31 Python
python爬取基于m3u8协议的ts文件并合并
2019/04/26 Python
Python使用pyserial进行串口通信的实例
2019/07/02 Python
Python爬取视频(其实是一篇福利)过程解析
2019/08/01 Python
mac安装python3后使用pip和pip3的区别说明
2020/09/01 Python
python爬虫scrapy基本使用超详细教程
2021/02/20 Python
python实现MySQL指定表增量同步数据到clickhouse的脚本
2021/02/26 Python
灵活运用CSS3特性绘制简易版围棋效果
2016/09/28 HTML / CSS
分享30个新鲜的CSS3打造的精美绚丽效果(附演示下载)
2012/12/28 HTML / CSS
HTML5本地存储localStorage、sessionStorage基本用法、遍历操作、异常处理等
2014/05/08 HTML / CSS
美国批发零售网站:GearXS
2016/07/26 全球购物
杭州联环马网络笔试题面试题
2013/08/04 面试题
初三化学教学反思
2014/01/23 职场文书
优秀班干部事迹材料
2014/01/26 职场文书
会议邀请书范文
2014/02/02 职场文书
销售内勤岗位职责
2014/04/15 职场文书
捐款倡议书格式范文
2014/05/14 职场文书
建筑施工安全责任书
2014/07/24 职场文书
助人为乐道德模范事迹材料
2014/08/16 职场文书
基于go interface{}==nil 的几种坑及原理分析
2021/04/24 Golang
jQuery ajax - getScript() 方法和getJSON方法
2021/05/14 jQuery
详解CSS不定宽溢出文本适配滚动
2021/05/24 HTML / CSS