uniapp使用扩展组件uni-data-select出现的问题汇总

前言

不知道大家有没有学习过我的这门课程那,《uniCloud云开发Vue3版本官方推荐用法》,这么课程已经得到了官方推荐,想要快速上手unicloud的小伙伴们,可以学习一下这么课程哦,不要忘了给一键三连呀。

在录制这门课程的时候,可能在视频中出现的一些问题,没有发现或者没有解决,因此写一篇文章记录一下已知的bug以及扩展知识。

问题一:uni-data-select组件collection连数据库,orderby属性不能排序的问题

javascript 复制代码
<uni-data-select 
	ref="selectRef" 
	collection="xxm-bizhi-classify"
	field="_id as value, name as text"
	:where="`enable == true`"
	orderby="sort asc"
	v-model="selectValue"

>
></uni-data-select>

如上所示代码,如果想要根据数据库内的sort这个字段进行排序,这样写是起不到作用的,原因是field没有讲排序字段sort过滤出来。

解决办法: 只需要在field过滤的时候,将sort字段过来出来即可,如下所示:

field="_id as value, name as text , sort"

问题二:发布成功后,上传选择的分类值依然存在

这个问题,挺多小伙伴反映了,就是发布成功后,上次选择的下拉框值依然存在,很影响下一次的操作,官方文档也没给提供属性或方法解决,如下所示:

如果你进入到扩展组件uni-data-select内部的话,你就知道什么原因了,因为发布成功之后,会将你最后选择的值记录到缓存中,再次打开的话,会读取缓存,所以就一直存在了,如下代码是uni-data-select的方法:

javascript 复制代码
// 获取缓存
getCache(name = this.getCurrentCacheKey()) {
	let cacheData = uni.getStorageSync(this.cacheKey) || {};
	return cacheData[name];
},
// 设置缓存
setCache(value, name = this.getCurrentCacheKey()) {
	let cacheData = uni.getStorageSync(this.cacheKey) || {};
	cacheData[name] = value;
	uni.setStorageSync(this.cacheKey, cacheData);
}

解决办法: 只需要在合适的场景下,调用组件的clearVal()方法即可。

javascript 复制代码
//給uni-data-select组件定义ref
const selectValue = ref("");

//可以在页面加载完毕后,执行clearVal()方法进行清除
onMounted(()=>{
	selectRef.value.clearVal();
})

//或者在表单提交完成后清除
const submit = ()=>{
	...自己的业务逻辑;
	selectRef.value.clearVal(); //清空选择
}
相关推荐
Rysxt_1 天前
uni-app 使用教程:从入门到发布
uni-app
homelook2 天前
uniapp蓝牙demo
uni-app
2501_915909063 天前
手机崩溃日志导出的工程化体系,从系统级诊断到应用行为分析的多工具协同方法
android·ios·智能手机·小程序·uni-app·iphone·webview
郑州光合科技余经理3 天前
技术视角:海外版一站式同城生活服务平台源码解析
java·开发语言·uni-app·php·排序算法·objective-c·生活
wangdaoyin20103 天前
UniApp中使用LivePlayer进行视频或在流媒体播放
uni-app·liveplayer·h5播放视频
2501_915106323 天前
App HTTPS 抓包实战解析,从代理调试到真实网络流量观察的完整抓包思路
网络协议·http·ios·小程序·https·uni-app·iphone
游戏开发爱好者83 天前
苹果App Store应用程序上架方式全面指南
android·小程序·https·uni-app·iphone·webview
2501_916008893 天前
深入理解 iPhone 文件管理,从沙盒结构到开发调试的多工具协同实践
android·ios·小程序·https·uni-app·iphone·webview
一室易安3 天前
解决使用 UniApp 搭配 Vue3 小程序开始 使用uview-plus 的返回顶部up-back-top中onPageScroll 不触发的问题
小程序·uni-app
yilan_n3 天前
鸿蒙应用上传
vue.js·华为·uni-app