【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();
		}
	}

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

亲测有效~~~

相关推荐
西洼工作室3 小时前
uniapp+vue3+python对接阿里云短信认证服务alibabacloud_dypnsapi20170525
python·阿里云·uni-app
半天法师4 小时前
Bug 记录:UE 结构体转 JSON 时 Key 字段大小写异常 (Editor 与打包后表现不一致)
ai·ue5·json·bug
张小俊_4 小时前
WPF 跨线程 UI 更新与硬编码赋值引发的 Bug 排查
c#·bug·wpf
wuxianda10304 小时前
苹果App上架4.3a问题3天解决方案汇报总结
开发语言·javascript·uni-app·ecmascript·ios上架·苹果上架
_pengliang4 小时前
uni-app 实现sse流式音频技术方案
uni-app·音视频
鸿儒5171 天前
记录一个C++ Windows程序移植到Linux系统的bug
开发语言·c++·bug
MY_TEUCK1 天前
【AI 应用】前端接口联调工程化:把 Swagger 接入沉淀成可复用 Skill
前端·人工智能·uni-app·状态模式
上架ipa1 天前
uniapp打包ios配置、申请证书、测试和上架综合教程
uni-app
00后程序员张1 天前
完整指南 iOS App上架到App Store的步骤详解
macos·ios·小程序·uni-app·objective-c·cocoa·iphone
hhzz1 天前
记录微信小程序tabbar不显示问题:uni-app Vue 3 自定义 tabBar 不渲染
vue.js·微信小程序·uni-app