微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

vue.js引用背景图background无效的3种解决方案

#vue.js项目中,出现css调用background背景图无效?如何解决

或者调用<img>标签,也无效果

直接上代码,自行对比查找一下:

效果图预览

效果图

1. 正确的代码,示例如下


<template>
  <div class="demo">
    <!-- 成功引入的三种方法: -->
    <!-- 图1 -->
    <div class="img1"></div>
    <!-- 图2 -->
    <div class="img2" :style="{backgroundImage: 'url(' + bg2 + ')' }"></div>
    <!-- 图3 -->
    <img src="~@/../static/images/logo3.png" width="100">
  </div>
</template>
<script>
import Bg2 from '@/../static/images/logo2.png'
export default {
	name: 'App',data () {
	    return {
			bg2: Bg2,}
	}
}
</script>
<style>
	.demo{width: 100px;margin: 50px auto;}
	.img1{
	    width: 100px;
		height: 100px;
	    background: url('~@/../static/images/logo1.png') center center no-repeat;
	    background-size: 100px auto;
	}
	.img2{
		width: 100px;
	    height: 100px;
	    background-position: center center;
	    background-repeat:  no-repeat;
	    background-size: 100px auto;
	}
</style>

上述代码中,出现了诸如:~@/和 @/,如果删除后,测试效果也正常,你也可以都去掉,不影响。

2. 错误代码,截图对比

如下:

错误的代码演示

报错结果截图如下:

错误代码演示的结果:报错

修改为正确代码方法,类比如下:

<div :style="{backgroundImage: 'url(https://cn.vuejs.org/images/logo.png)',width: '400px',height: '400px'}">foo</div>

具体参考官方文档:Class 与 Style 绑定

相比其他方法

如果你用了vue-cli脚手架,在build/utils.js中找到ExtractTextPlugin位置在对象中加入这句publicPath: '../../'就行了(本人未测试)。

其他未测试到的状况,本文暂不深入发掘,如有发现另类bug,后续将会补充。

vue添加背景图没反应

table需要添加背景图,添加backgroundImage后发现不起作用,于是网上一番搜索,发现加了require后就好了

backgroundImage: ‘url(’ + require(‘图片地址’) + ‘)’,原来vue中的js引入图片,必须require进来。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐