微信小程序自定義多列選擇器使用
本文實(shí)例為大家分享了微信小程序自定義多列選擇器的具體代碼,供大家參考,具體內(nèi)容如下
項(xiàng)目需要,需要實(shí)現(xiàn)一個(gè)多列選擇器,在用戶(hù)確定之前,無(wú)論列表如何轉(zhuǎn),都不會(huì)影響已確定值的顯示,只要用戶(hù)選擇確定才會(huì)把新選擇的內(nèi)容更新到已確定的顯示值上。
目前個(gè)人思路是保存兩份,一份用來(lái)存放用戶(hù)選擇的中間值,當(dāng)用戶(hù)點(diǎn)擊確定時(shí),把中間值更新為已確認(rèn)值。如果用戶(hù)選擇取消,就把中間值更新為已確認(rèn)值。
因?yàn)槲⑿判〕绦蛑械亩嗔羞x擇器是用數(shù)組存放數(shù)據(jù),因此在拷貝中涉及到深拷貝,必須是深拷貝才能實(shí)現(xiàn)上面的設(shè)想。
因此可以下面代碼實(shí)現(xiàn)深拷貝:
var arr=JSON.parse(JSON.stringify(this.data.multiArray));
wxml:
<picker bindcancel="cancelAddr" mode="multiSelector" bindchange="bindMultiPickerChange" bindcolumnchange="bindMultiPickerColumnChange" value="{{demoIndex}}" range="{{demoArray}}">
? ? ? ? ? ? <view class="picker">
? ? ? ? ? ? ? ? 收貨地址:{{multiArray[0][multiIndex[0]]}}-{{multiArray[1][multiIndex[1]]}}-{{multiArray[2][multiIndex[2]]}}
? ? ? ? ? ? </view>
? ? ? ? </picker>js:
data:{
??? ?multiArray: [
? ? ? ['廣大生活區(qū)', '廣大教學(xué)區(qū)'],
? ? ? ['B1', 'B2', 'B3'],
? ? ? ['一樓', '二樓', '三樓']
? ? ],
? ? demoArray: ?[
? ? ? ['廣大生活區(qū)', '廣大教學(xué)區(qū)'],
? ? ? ['B1', 'B2', 'B3'],
? ? ? ['一樓', '二樓', '三樓']
? ? ],
? ? //實(shí)際顯示值
? ? multiIndex: [0, 0, 0],
? ? //臨時(shí)變量
? ? demoIndex: [0, 0, 0],
? ? teach: ["文清樓", "文新樓", "文俊西樓"],
? ? life: ['B1', 'B2', 'B3']
? ? }
//修改過(guò)程中取消修改
? cancelAddr() {
? ? var arr = JSON.parse(JSON.stringify(this.data.multiArray));
? ? var index = JSON.parse(JSON.stringify(this.data.multiIndex));
? ? this.setData({
? ? ? demoArray: arr,
? ? ? demoIndex: index
? ? })
? },
? //地址選擇器改變
? bindMultiPickerColumnChange(e) {
? ? var value = e.detail.value;
? ? var column = e.detail.column;
? ? var demoArray = this.data.demoArray;
? ? var demoIndex = this.data.demoIndex;
? ? if (column === 0 && value != demoIndex[0]) {
? ? ? if (value === 0) {
? ? ? ? demoArray[1] = this.data.life;
? ? ? } else {
? ? ? ? demoArray[1] = this.data.teach;
? ? ? }
? ? }
? ? demoIndex[column] = value;
? ? this.setData({
? ? ? demoArray: demoArray,
? ? ? demoIndex: demoIndex
? ? })
? },
? //確定選中的地址
? bindMultiPickerChange() {
? ? console.log("all change");
? ? var arr = JSON.parse(JSON.stringify(this.data.demoArray));
? ? var index = JSON.parse(JSON.stringify(this.data.demoIndex));
? ? this.setData({
? ? ? multiArray: arr,
? ? ? multiIndex: index
? ? })
? },效果圖(上面代碼的數(shù)據(jù)數(shù)量刪除了部分):


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript常用數(shù)組操作方法,包含ES6方法
這篇文章主要介紹了JavaScript常用數(shù)組操作方法,包含ES6方法,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒借鑒價(jià)值,需要的朋友可以參考下2018-09-09
js showModalDialog彈出窗口實(shí)例詳解
本篇文章主要是對(duì)js showModalDialog彈出窗口進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-01-01
JavaScript實(shí)現(xiàn)word轉(zhuǎn)png的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何使用JavaScript實(shí)現(xiàn)word轉(zhuǎn)png的功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02
詳解JavaScript創(chuàng)建數(shù)組的三種方式
這篇文章主要介紹了JavaScript創(chuàng)建數(shù)組的三種方式:直接聲明,?以對(duì)象方式創(chuàng)建數(shù)組和使用?Array.from()?方法創(chuàng)建,并通過(guò)代碼示例講解的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-06-06
JavaScript關(guān)于提高網(wǎng)站性能的幾點(diǎn)建議(一)
這篇文章主要介紹了JavaScript關(guān)于提高網(wǎng)站性能的幾點(diǎn)建議(一)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07
JavaScript中split與join函數(shù)的進(jìn)階使用技巧
這篇文章主要介紹了JavaScript中split與join函數(shù)的進(jìn)階使用技巧,split和join通常被用來(lái)操作數(shù)組和字符串之間的轉(zhuǎn)換,需要的朋友可以參考下2016-05-05
javascript語(yǔ)句中的CDATA標(biāo)簽的意義
javascript語(yǔ)句中的CDATA標(biāo)簽的意義...2007-05-05

