Vue.js 动态为img的src赋值

需求是这样:
ajax获取数据如下

{
    "code": "200",
    "data": {
        "SumAmount": 200,
        "List": [{
            "amount": 100,
            "sex": "male",
            "fee": 1,
            "id": 98,
            "status": 2,
            "time": "2015-08-11"
        }, {
            "amount": 100,
            "sex": "female",
            "fee": 0,
            "id": 8,
            "status": 2,
            "time": "2015-06-12"
        }]
    },
    "msg": "success"
}

然后渲染列表到页面,如果男,则将img的src设为"images/male.png",反之设为"images/female.png"


两个都可以实现,为了在html中看起来舒服点还是用filter吧,虽然也就一个判断逻辑,但是判断语句加上url,这就不美观了,当然,这只是个人习惯,直接用指令的话直观点

<img v-attr="src: sex=='male'?'images/male.png':'images/female.png'">
<img v-attr="src: sex | isM">

对应的filter

filters: {
            isM: function (val) {
                 return val == 'male' ? 'images/male.png' : 'images/female.pn'
            }
        }

方法很多,我写我推荐的吧:

首先男女这样的标示属于装饰性内容,我建议写到css里面。也就是说用背景图的形式来控制现实男女

这样你有两个class .male female

<span class={{sex}}></span>

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Vue.js 本身并没有提供制作图片缩略图的功能,但是我们可以利用第三方库或者插件来实现。以下是一种使用插件 vue-image-size 插件来制作图片缩略图的方法: 1. 安装 vue-image-size 插件: ``` npm install vue-image-size ``` 2. 在 Vue 组件中引入 vue-image-size 并使用: ``` <template> <div> <img :src="imageUrl" @load="onImgLoad" /> <img :src="thumbnailUrl" /> </div> </template> <script> import VueImageSize from 'vue-image-size'; export default { components: { VueImageSize, }, data() { return { imageUrl: 'https://example.com/image.jpg', thumbnailUrl: '', thumbnailWidth: 100, thumbnailHeight: 100, }; }, methods: { onImgLoad({ target }) { const { width, height } = target; this.thumbnailUrl = this.$imageSize.createThumbnail(this.imageUrl, this.thumbnailWidth, this.thumbnailHeight, { width, height }); }, }, }; </script> ``` 在上述代码中,我们首先引入了 vue-image-size 插件,然后在组件中使用 VueImageSize 组件。在 data 中定义了需要加载的原始图片地址 imageUrl,以及制作缩略图后的图片地址 thumbnailUrl 和缩略图宽高 thumbnailWidth 和 thumbnailHeight。在 onImgLoad 方法中,利用 $imageSize.createThumbnail 方法制作缩略图,并将生成的缩略图地址赋值给 thumbnailUrl 变量。最后在模板中渲染出原始图片和缩略图。 需要注意的是,vue-image-size 插件依赖于 canvas,所以在使用之前需要确保浏览器支持 canvas。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值