Nuxt资源文件夹,别名,图片url和css

栏目: CSS · 发布时间: 5年前

内容简介:Nuxt 有两种资源文件夹它们的区别文档上已经说得很清楚:如果你的静态资源文件需要 Webpack 做构建编译处理,可以放到 assets 目录,否则可以放到 static 目录中去。

资源文件夹

Nuxt 有两种资源文件夹 assetsstatic

它们的区别文档上已经说得很清楚:

如果你的静态资源文件需要 Webpack 做构建编译处理,可以放到 assets 目录,否则可以放到 static 目录中去。

具体表现就是:

(图片或字体)的尺寸小于 1K 的时候,它将会被转换成 Base-64 data URL 来内联引用;否则它将被拷贝至指定的子目录(在 .nuxt 目录下),并被重命名(加上 7 位的哈希码作为版本标识)以实现更好的缓存策略。

而 static 里面的资源不会做这些处理。

所以引用的方式也不同:

<!-- 引用 static 目录下的图片 -->
<img src="/my-image.png" />

<!-- 引用 assets 目录下经过 webpack 构建处理后的图片 -->
<img src="~/assets/my-image-2.png" />

别名

Nuxt 有两种默认别名写法 ~@

我个人推荐 @ ,因为在 2.0 后 ~ 可能会出问题:

请注意: 从 Nuxt 2.0 开始,~/alias 将无法在 CSS 文件中正确解析。你必须在 url CSS 引用中使用~assets(没有斜杠)或@别名,即 background:url(“~assets/banner.svg”)

sass/css 引用图片的路径

在 scss 或 css 中最好不要使用别名路径,而应该遵循 css 规范,路径相对于 css 本身。因为别名往往在 scss,css 中不起作用。

如果你打算将图片放到 assets 中,那么你最好在 scss 和 css 中使用相对路径引用图片。

动态 src 的写法

正确的写法:

<img :src="require('@/assets/img/myimg' + n + '.jpg')">

上面的例子里,因为图片是放到了 assets 里面且又使用了别名,所以要让 webpack 知道,就要使用 require

错误的写法(没有 require):

<img :src="'@/assets/img/myimg' + n + '.jpg'">

错误的写法(src 没有冒号):

<img src="require('@/assets/img/myimg' + n + '.jpg')">

这一点来说,确实不如 React 的纯 javascript 来的直观。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

高性能网站建设指南

高性能网站建设指南

Steve Souders / 刘彦博 / 电子工业出版社 / 2008年 / 35.00元

本书结合Web 2.0以来Web开发领域的最新形势和特点,介绍了网站性能问题的现状、产生的原因,以及改善或解决性能问题的原则、技术技巧和最佳实践。重点关注网页的行为特征,阐释优化Ajax、CSS、JavaScript、Flash和图片处理等要素的技术,全面涵盖浏览器端性能问题的方方面面。在《高性能网站建设指南》中,作者给出了14条具体的优化原则,每一条原则都配以范例佐证,并提供了在线支持。《高性能......一起来看看 《高性能网站建设指南》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具