vue脚手架和html,HTML和静态资源

HTML和静态资源

HTML

Index 文件

public/index.html文件是一个会被 html-webpack-plugin 处理的模板。在构建过程中,资源链接会被自动注入。另外,Vue CLI 也会自动注入 resource hint(preload/prefetch、manifest 和图标链接(当用到 PWA 插件时)以及构建过程中处理的 JavaScript 和 CSS 文件的资源链接。

插值

因为 index 文件被用作模板,所以你可以使用 lodash template 语法插入内容:用来做不转义插值;

用来做 HTML 转义插值;

用来描述 JavaScript 流程控制。

除了被html-webpack-plugin暴露的默认值之外,所有客户端环境变量也可以直接使用。例如,BASE_URL的用法:

更多内容可以查阅:publicPath

Preload

是一种 resource hint,用来指定页面加载后很快会被用到的资源,所以在页面加载的过程中,我们希望在浏览器开始主体渲染之前尽早 preload。

默认情况下,一个 Vue CLI 应用会为所有初始化渲染需要的文件自动生成 preload 提示。

这些提示会被@vue/preload-webpack-plugin 注入,并且可以通过chainWebpack的config.plugin('preload')进行修改和删除。

Prefetch

是一种 resource hint,用来告诉浏览器在页面加载完成后,利用空闲时间提前获取用户未来可能会访问的内容。

默认情况下,一个 Vue CLI 应用会为所有作为 async chunk 生成的 JavaScript 文件(通过动态import()按需 code splitting 的产物)自动生成 prefetch 提示。

这些提示会被@vue/preload-webpack-plugin 注入,并且可以通过chainWebpack的config.plugin('prefetch')进行修改和删除。

示例:// vue.config.js

module.exports = {

chainWebpack: config => {

// 移除 prefetch 插件

config.plugins.delete('prefetch')

// 或者

// 修改它的选项:

config.plugin('prefetch').tap(options => {

options[0].fileBlacklist = options[0].fileBlacklist || []

options[0].fileBlacklist.push(/myasyncRoute(.)+?\.js$/)

return options

})

}

}

当 prefetch 插件被禁用时,你可以通过 webpack 的内联注释手动选定要提前获取的代码区块:import(/* webpackPrefetch: true */ './someAsyncComponent.vue')

webpack 的运行时会在父级区块被加载之后注入 prefetch 链接。Prefetch 链接将会消耗带宽。如果你的应用很大且有很多 async chunk,而用户主要使用的是对带宽较敏感的移动端,那么你可能需要关掉 prefetch 链接并手动选择要提前获取的代码区块。

不生成 index

当基于已有的后端使用 Vue CLI 时,你可能不需要生成index.html,这样生成的资源可以用于一个服务端渲染的页面。这时可以向vue.config.js加入下列代码:// vue.config.js

module.exports = {

// 去掉文件名中的 hash

filenameHashing: false,

// 删除 HTML 相关的 webpack 插件

chainWebpack: config => {

config.plugins.delete('html')

config.plugins.delete('preload')

config.plugins.delete('prefetch')

}

}

然而这样做并不是很推荐,因为:硬编码的文件名不利于实现高效率的缓存控制。

硬编码的文件名也无法很好的进行 code-splitting(代码分段),因为无法用变化的文件名生成额外的 JavaScript 文件。

硬编码的文件名无法在现代模式下工作。

你应该考虑换用 indexPath 选项将生成的 HTML 用作一个服务端框架的视图模板。

构建一个多页应用

不是每个应用都需要是一个单页应用。Vue CLI 支持使用vue.config.js中的pages选项构建一个多页面的应用。构建好的应用将会在不同的入口之间高效共享通用的 chunk 以获得最佳的加载性能。

处理静态资源

静态资源可以通过两种方式进行处理:在 JavaScript 被导入或在 template/CSS 中通过相对路径被引用。这类引用会被 webpack 处理。

放置在public目录下或通过绝对路径被引用。这类资源将会直接被拷贝,而不会经过 webpack 的处理。

从相对路径导入

当你在 JavaScript、CSS 或*.vue文件中使用相对路径(必须以.开头)引用一个静态资源时,该资源将会被包含进入 webpack 的依赖图中。在其编译过程中,所有诸如...、background: url(...)和 CSS @import的资源 URL 都会被解析为一个模块依赖。

例如,url(./image.png)会被翻译为require('./image.png'),而:image.png

将会被编译到:h('img', { attrs: { src: require('./image.png') }})

在其内部,我们通过file-loader用版本哈希值和正确的公共基础路径来决定最终的文件路径,再用url-loader将小于 4kb 的资源内联,以减少 HTTP 请求的数量。

你可以通过 chainWebpack 调整内联文件的大小限制。例如,下列代码会将其限制设置为 10kb:// vue.config.js

module.exports = {

chainWebpack: config => {

config.module

.rule('images')

.use('url-loader')

.loader('url-loader')

.tap(options => Object.assign(options, { limit: 10240 }))

}

}

URL 转换规则如果 URL 是一个绝对路径(例如/images/foo.png),它将会被保留不变。

如果 URL 以.开头,它会作为一个相对模块请求被解释且基于你的文件系统中的目录结构进行解析。

如果 URL 以~开头,其后的任何内容都会作为一个模块请求被解析。这意味着你甚至可以引用 Node 模块中的资源:foo.png

如果 URL 以@开头,它也会作为一个模块请求被解析。它的用处在于 Vue CLI 默认会设置一个指向/src的别名@。(仅作用于模版中)

public文件夹

任何放置在public文件夹的静态资源都会被简单的复制,而不经过 webpack。你需要通过绝对路径来引用它们。

注意我们推荐将资源作为你的模块依赖图的一部分导入,这样它们会通过 webpack 的处理并获得如下好处:脚本和样式表会被压缩且打包在一起,从而避免额外的网络请求。

文件丢失会直接在编译时报错,而不是到了用户端才产生 404 错误。

最终生成的文件名包含了内容哈希,因此你不必担心浏览器会缓存它们的老版本。

public目录提供的是一个应急手段,当你通过绝对路径引用它时,留意应用将会部署到哪里。如果你的应用没有部署在域名的根部,那么你需要为你的 URL 配置 publicPath 前缀:在public/index.html或其它通过html-webpack-plugin用作模板的 HTML 文件中,你需要通过设置链接前缀:

在模板中,你首先需要向你的组件传入基础 URL:data () {

return {

publicPath: process.env.BASE_URL

}

}

然后:

何时使用public文件夹你需要在构建输出中指定一个文件的名字。

你有上千个图片,需要动态引用它们的路径。

有些库可能和 webpack 不兼容,这时你除了将其用一个独立的标签引入没有别的选择。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值