【bug】uniapp的image组件渲染gif图,只有第一次点击的时候有动效,需要每次点击都有gif效果,已解决

前两天遇到的问题,暂时没有解决,就搁置了。

不解决又难受,还好今天解决了,记录下

需求:

两个gif图,分别代表点击之后的男生和女生,并且有两个静态的男生和女生图片

当男生静态图被点击的时候切换男生的gif图,女生静态图被点击的时候切换女生的gif图

主要就是根据动态变量控制静态图和gif的图切换,但是来回多点击几次后发现,只有第一次从静态图切换到gif图的时候,才有gif的动态效果

然后才知道,原来在uni-app中使用image组件展示gif图片的时候,通常会遇到只有第一次点击时有动态效果,第二次点击不展示的问题。这是因为image组件默认会对同一个src地址的图片进行缓存,导致第二次点击时直接从缓存中读取,而不会重新加载图片。

解决思路就是:每次点击的图片链接地址加上一个随机参数,强制让image组件去重新加载图片

我这里是vue3的写法,只是写法不同,实现效果一样的

bash 复制代码
			<view class="chose-sex-image">
				<view @click="choseSex('boy')" >			
					<image v-if="data.isStaticBoy" src="静态boy图片路径.png" 
						style="width: 161rpx; height: 184rpx"></image>
					<image v-else :src="data.boygif" style="width: 200rpx; height: 200rpx">
					</image>
				</view>

				<view @click.stop="choseSex('girl')" >				
					<image v-if="data.isStaticGirl" src="静态girl图片路径.png"
						style="width: 161rpx; height: 184rpx"></image>
					<image v-else :src="data.girlgif" style="width: 200rpx; height: 200rpx">
					</image>
				</view>
			</view>
		</view>
c 复制代码
	const data = ref({
		isStaticGirl: true,
		isStaticBoy: true,		
		boygif: '动态boy路径.gif',
		girlgif: '动态girl路径.gif'
	});
bash 复制代码
	function choseSex(key) {
		if (key === "boy") {
			data.value.isStaticBoy = false;
			data.value.isStaticGirl = true;		
			data.value.boygif = '/static/images/动态boy路径.gif?' + new Date().getTime();
		} else {
			data.value.isStaticGirl = false;
			data.value.isStaticBoy = true;		
			data.value.girlgif = '/static/images/动态girl路径.gif?' + new Date().getTime();
		}
	}

这样,每次点击图片时都会重新加载图片,从而实现每次点击都有动态效果的效果。

亲测有效~~~

相关推荐
Q_Q5110082855 小时前
python+uniapp基于微信小程序团购系统
spring boot·python·微信小程序·django·uni-app·node.js·php
炒毛豆5 小时前
uniapp微信小程序+vue3基础内容介绍~(含标签、组件生命周期、页面生命周期、条件编译(一码多用)、分包))
vue.js·微信小程序·uni-app
盛夏绽放10 小时前
关于 uni-app 与原生微信小程序中的生命周期 —— 一次“生命旅程”的解读
微信小程序·小程序·uni-app
知识分享小能手11 小时前
uni-app 入门学习教程,从入门到精通,uni-app 基础知识详解 (2)
前端·javascript·windows·学习·微信小程序·小程序·uni-app
2501_9160088912 小时前
iOS 发布全流程详解,从开发到上架的流程与跨平台使用 开心上架 发布实战
android·macos·ios·小程序·uni-app·cocoa·iphone
东巴图13 小时前
分解如何利用c++修复小程序的BUG
开发语言·c++·bug
风清云淡_A14 小时前
【uniapp】uni.uploadFile上传数据多出一个304的get请求处理方法
uni-app
shykevin14 小时前
uni-app x商城,商品列表组件封装以及使用
windows·uni-app
cesske15 小时前
uniapp 编译支付宝小程序canvas 合成图片实例,支付宝小程序 canvas 渲染图片 可以换成自己的图片即可
小程序·uni-app·apache
Q_Q5110082851 天前
python+uniapp基于微信小程序的旅游信息系统
spring boot·python·微信小程序·django·flask·uni-app·node.js