<template>
<div>
<!-- 成功引入的三种方法: -->
<!-- 1 -->
<img src="~@/da.jpg" width="100">
<!-- 2 -->
<div class="img1"></div>
<!-- 3 -->
<div class="img2" :style="{backgroundImage: 'url(' + img + ')' }"></div>
</div>
</template>
<script>
import Img from '@/da.jpg'
export default {
data () {
return {
img: Img,
}
}
}
</script>
<style>
.img1{
width: 100px;
height: 100px;
background: url('~@/da.jpg') 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>
当我们在Vue.js项目中引用图片时,关于图片路径有以下几种情形:
使用一
我们在data里面定义好图片路径
1 |
|
然后,在template模板里面
1 2 |
|
这样是错误的写法,我们应该用v-bind绑定图片的srcs属性
1 |
|
或者
1 |
|
这种方式是按照正常HTML语法引用路径,放在模板里可以被webpack打包出来。
使用二
当我们需要在js代码里面写图片路径的时候,如果我们在data里面写
1 2 |
|
此时webpack只会把它当做字符串处理从而找不到图片地址,此时我们可以使用import引入图片路径:
1 2 |
|
在data里面定义
1 |
|
情形三
我们也可以把图片放在外层的static文件夹里面,然后在data里面定义:
1 2 |
|