Vue在css中图片路径问题解决的配置方法

 更新时间:2023年06月26日 09:17:54   作者:他的猫MM  
这篇文章主要为大家介绍了Vue在css中图片路径问题解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

css外设置background-image

在css外设置background-image时,不能直接使用url,应该使用

<li  :style="'background-image:url(require('./../assets/banner_top2.png'))'"></li>

在css中设置background-image时,使用相对路径在webpack打包后出现问题,图片路径到了static下

在build/util.js中配置publicPath:“../../”

    if (options.extract) {
      return ExtractTextPlugin.extract({
        use: loaders,
        fallback: 'vue-style-loader',
        publicPath: '../../'
      })

webpack对css文件打包时会验证图片资源是否获取成功,若找不到资源文件,就会报错。同时注释的资源图片也会进行检查。

在webpack.base.conf.js中使用别名(resolve.alias)解决scss @import相对路径问题(webpack5以上版本会自动配置@为当前目录src):

当遇到样式过多时或者公共样式,我们会将样式单独写在一个文件夹common.scss;

配置别名:@相当于目录src

resolve: {
    extensions: ['.js', '.vue', '.json'],
    alias: {
      'vue$': 'vue/dist/vue.esm.js',
      '@': resolve('src'),
    }
  }

两种引入方式

在js中:

//原来是这样写
import './../src/scss/common.scss';
//定义别名后可以这样写
import '@/scss/common.scss';

在scss文件中:注意在这里需要加~在@符号前面

//原本这样写
@import './../scss/common.scss';
//现在这样写
@import '~@/scss/common.scss';

使用别名不仅简单方便,同时避免了相对路径使用时出现的问题,例如在a.scss文件中引入b.scss

//a.scss
@import '@/scss/module/b.scss';
//b.scss
div{
   background-image: url('~@/assets/images/1.png');
}

这时再在另外的文件中引入a.scss,则b文件中的图片资源的相对路径就会改变,找不到资源图片报错。如果使用上面方法则会避免这些错误。

注意:如果你的引入的样式文件格式为scss则,在style标签上应设置:(css,less等同理,在js中引入没有这个顾虑)

<style lang="scss" scoped>
    @import '~@/styles/register/main.scss';
</style>

为了避免不必要的错误,最好在css中引入css样式,scss中引入scss样式,不要混淆。

以上就是Vue在css中图片路径问题解决的详细内容,更多关于Vue css图片路径的资料请关注脚本之家其它相关文章!

相关文章

  • vue+Java后端进行调试时解决跨域问题的方式

    vue+Java后端进行调试时解决跨域问题的方式

    今天在开发中遇到有点小问题,vue+Java后端进行调试时如何解决跨域问题,下面小编给大家分享解决方法,感兴趣的朋友一起看看吧
    2017-10-10
  • vue.js中指令Directives详解

    vue.js中指令Directives详解

    这篇文章主要为大家详细介绍了vue.js中指令Directives,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • vue和js中实现模糊查询方式

    vue和js中实现模糊查询方式

    这篇文章主要介绍了vue和js中实现模糊查询方式,具有很好的参考价值,希望对大家有所帮助。也希望大家多多支持脚本之家
    2022-08-08
  • vue中h5端打开app(判断是安卓还是苹果)

    vue中h5端打开app(判断是安卓还是苹果)

    这篇文章主要介绍了vue中h5端打开app(判断是安卓还是苹果),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Nuxt的路由配置和参数传递方式

    Nuxt的路由配置和参数传递方式

    这篇文章主要介绍了Nuxt的路由配置和参数传递方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue mounted 调用两次的完美解决办法

    vue mounted 调用两次的完美解决办法

    在开发中发现其中一个页面moutned调用了两次,而其他页面正常,表示很懵逼,然后查找原因,终于找到了,其实归根到底是要知道mounted的调用机制问题。这篇文章主要介绍了vue mounted 调用两次的解决办法,需要的朋友可以参考下
    2018-10-10
  • vue+axios 前端实现登录拦截的两种方式(路由拦截、http拦截)

    vue+axios 前端实现登录拦截的两种方式(路由拦截、http拦截)

    本文通过实例代码给大家介绍了vue+axios 前端实现登录拦截的方法,主要通过路由拦截和http拦截,具体实例代码大家跟随小编一起通过本文学习吧
    2018-10-10
  • Vue3通过hooks方式封装节流和防抖的代码详解

    Vue3通过hooks方式封装节流和防抖的代码详解

    vue3 中的 hooks 就是函数的一种写法,就是将文件的一些单独功能的js代码进行抽离出来,放到单独的js文件中,或者说是一些可以复用的公共方法/功能,本文给大家介绍了Vue3通过hooks方式封装节流和防抖,需要的朋友可以参考下
    2024-10-10
  • vue-router钩子函数实现路由守卫

    vue-router钩子函数实现路由守卫

    这篇文章主要介绍了vue-router钩子函数实现路由守卫,对vue感兴趣的同学,可以参考下
    2021-04-04
  • Vue中$emit调用父组件异步方法模拟.then实现方式

    Vue中$emit调用父组件异步方法模拟.then实现方式

    这篇文章主要介绍了Vue中$emit调用父组件异步方法模拟.then实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-09-09

最新评论