uniapp更好的下拉刷新动画

原生的uniapp的下拉刷新是一个普通的加载框
样式真的很单一。后来手动改成了一个gif图片

在这里插入图片描述

才算满意一些。但是现在又有更好的加载样式了。

在这里插入图片描述

这种体验就更好了。
真的原生app接近了一些。不过这个效果在安卓机上能显示出来。在苹果手机上还是一个加载的loading

接下来把代码奉上。

第一步:在pages.json 里面加下图的一句话。然后刷新页面之后只要往下拉。这个动画出就出了。

在这里插入图片描述

{
			"path": "pages/shop/home", //vue商城首页
			"style": {
				"navigationBarTitleText": "商城首页",
				"navigationBarBackgroundColor": "#56D5FF",
				"enablePullDownRefresh": true,
				"app-plus": {

				}
			}
		},

第二步。此时动画有了可是不能及时的收回。所以要在当前页面做一些其它的配置让体验更好一些。

onLoad(){
		
		
		//1.刚进入页面的时候就加载这个动画
		uni.startPullDownRefresh();
		
	
	},
	// 2.下拉刷新
	onPullDownRefresh() {
			console.log('refresh');
			setTimeout(function () {
				uni.stopPullDownRefresh();
				// 这里放刷新数据的方法
			}, 1000);
		},

第三步。默认下拉的动画圈圈是绿色的。如果不喜欢可以更改。

还是要在pages.json里面的进行一个简单的配置。

{
			"path": "pages/shop/home", //vue商城首页
			"style": {
				"navigationBarTitleText": "商城首页",
				"navigationBarBackgroundColor": "#56D5FF",
				"enablePullDownRefresh": true,
				"app-plus": {
                "pullToRefresh": {
                        "support": true,
                        "color": "#000000", //小圈圈的颜色
                        "style": "circle" //小圈圈的样式
                    }
				}
			}
		},

 这样一个简单的体验很好的下拉框就做好了。 如果有帮到你。请点一个赞支持一下。后续还有更多好玩的。。

 在这里插入图片描述


————————————————
版权声明:本文为CSDN博主「兄弟连勇闯天涯」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/endianzhijia/article/details/89412888

  • 5
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
根据提供的引用内容,uniapp并没有提供专门用于gif图片优化的API。但是我们可以通过一些方法来减小gif图片的大小,从而达到优化的效果。 1. 减少gif图片的帧数:可以通过减少gif图片的帧数来减小gif图片的大小,从而达到优化的效果。 2. 降低gif图片的分辨率:可以通过降低gif图片的分辨率来减小gif图片的大小,从而达到优化的效果。 3. 转换为其他格式:可以将gif图片转换为其他格式,例如jpeg格式,从而达到优化的效果。 下面是一个将gif图片转换为jpeg格式的例子: ```javascript // 引入gif.js库 import GIF from 'gif.js'; // 将gif图片转换为jpeg格式 function gifToJpeg(gifUrl) { return new Promise((resolve, reject) => { const gif = new GIF({ workers: 2, quality: 10, }); // 加载gif图片 const img = new Image(); img.onload = () => { const canvas = document.createElement('canvas'); canvas.width = img.width; canvas.height = img.height; const ctx = canvas.getContext('2d'); ctx.drawImage(img, 0, 0); const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height); // 将gif图片的每一帧添加到gif对象中 for (let i = 0; i < gif.frames.length; i++) { const frame = gif.frames[i]; const imageData = frame.getImageData(); ctx.putImageData(imageData, 0, 0); gif.addFrame(ctx, { delay: frame.delay, copy: true }); } // 将gif对象转换为jpeg格式 gif.on('finished', (blob) => { const reader = new FileReader(); reader.readAsDataURL(blob); reader.onloadend = () => { resolve(reader.result); }; }); gif.render(); }; img.src = gifUrl; }); } // 使用示例 gifToJpeg('https://example.com/example.gif').then((result) => { console.log(result); // 输出转换后的jpeg图片 }); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值