uniapp的picker组件:解决多个uv-picker时,每个picker高亮的内容显示不是已选择项的问题

本文主要是介绍uniapp的picker组件:解决多个uv-picker时,每个picker高亮的内容显示不是已选择项的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先看看是不是你想要的:

解决前:

uv-picker解决高亮和已选择项不同的问题

解决后:

解决后的uv-picker高亮及选择项

背景:

    此项目是使用vue3+uniapp开发的h5项目,项目的某个页面有两个或多个下拉选项,选择的第一个下拉框的第二个值,在选择第二个下拉框时,第二个下拉框高亮展示第二个值,跟着第一个下拉框的顺序去高亮展示了。

需求:

    假设有两个下拉选项,且每个选项都有3个可选值。当第一个下拉框选择第二个选项时,再对第二个下拉框进行选择时,此时应该是第一个选项高亮,但现在是第二个选项高亮了,即第二个下拉框高亮的选项是跟着第一个下拉框选择的顺序走了。

上代码,代码里有注释,请看:

html标签:<view><view><uv-form><uv-form-item required label="目的" borderBottom prop="gx2fz70f4j"><view class="picker-box" @tap="showLy('gx2fz70f4j')"><view>{{getLabel(formData.gx2fz70f4j, gx2fz70f4jList) || '请选择'}}</view><uni-icons type="right" color="#999"></uni-icons></view></uv-form-item><uv-form-item required label="等级" borderBottom prop="gx2fz70f4k"><view class="picker-box" @tap="showLy('gx2fz70f4k')"><view>{{getLabel(formData.gx2fz70f4k, gx2fz70f4kList) || '请选择'}}</view><uni-icons type="right" color="#999"></uni-icons></view></uv-form-item></uv-form></view><!--ref:获取picker组件的信息columns: picker组件显示的选项内容,是个数组;confirm: picker组件的确定按钮方法;keyName: picker组件显示的内容--><uv-picker ref="picker" :columns="[range1]" @confirm="confirmTop" keyName="label"></uv-picker></view>js:// 定义变量
const formData = ref({gx2fz70f4j: undefined, // 目的gx2fz70f4k: undefined, // 等级
})// 定义picker组件即uv-picker标签的ref
const picker = ref(null)// picker组件显示的选项
const range1 = ref(undefined)// 定义picker组件显示的选项,即uv-picker标签的columns
const gx2fz70f4jList = ref([{value: "1",label: "初验",key: "1"},{value: "2",label: "终验",key: "2"}])const gx2fz70f4kList = ref([{value: "2",label: "二级",key: "2"},{value: "3",label: "三级",key: "3"}])const pickerSelect = (k) => { // picker组件的高亮项为已选择的项range1.value.find((e, i) => {if (formData.value[k] && e.value === formData.value [k]) {// 重要!!! ref绑定的picker.value对象上的innerIndex是个数组,数组只有一项,即已选择的这一项picker.value.innerIndex = [i]}})}const showLy = (k) => {switch (k) {case 'gx2fz70f4j':range1.value = gx2fz70f4jList.valuepickerSelect(k)break;case 'gx2fz70f4k':range1.value = gx2fz70f4kList.valuepickerSelect(k)break;}picker.value.open()}const confirmTop = (e) => {formData.value[key] = e.value[0].value}const getLabel = (val, list) => { // 展示已选择项的labelif (!list) returnreturn list?.find(v => v.value == val)?.label}

功能的实现的主要问题在于picker.value.innerIndex = [i],已注释,请留意。欢迎评论~~~

这篇关于uniapp的picker组件:解决多个uv-picker时,每个picker高亮的内容显示不是已选择项的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078926

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec