欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vant彈出列表多選輸入框下拉選擇代碼(可直接復(fù)制使用)

 更新時(shí)間:2024年01月05日 08:31:35   作者:跳動(dòng)的世界線  
vue項(xiàng)目無(wú)論是用element中的Select選擇器,還是使用公司維護(hù)的組件,都可以輕松實(shí)現(xiàn)單選和多選的需求,這篇文章主要給大家介紹了關(guān)于Vant彈出列表多選輸入框下拉選擇的相關(guān)資料,需要的朋友可以參考下

項(xiàng)目要做移動(dòng)端,部分功能遷移過(guò)程中發(fā)現(xiàn),VantUI組件庫(kù)不支持原Element組件庫(kù)的部分功能,例如el-select 可以做到輸入的同時(shí)下拉選擇 下拉多選。

故需要手動(dòng)改寫,分享記錄下代碼。

效果圖

代碼示例:

<script setup lang="ts">
import { ref,reactive,computed,watch,watchEffect,onMounted } from "vue";//各種API
import store from '../../store'
import router from '../../router'
import { useRouter } from 'vue-router';
const $router = useRouter();

onMounted(()=>{
  getEstimateTime('estimateTime').then((res) => {
    quickReplyList.value = res.data.map((v) => {
      return { text: v.codeName };
    });
    quickReplyList.value.forEach((item,index) => {
      item.value = index
    });
  });
  getUserList('SHJS').then(res=>{
    userAssignList.value = res.data
    userAssignList.value.forEach((item,index) => {
      item.text = item.userName
      item.value = index
      item.checked = false
    });
  })
})

const quickReplyList = ref([]);
function QuickReplySelect ({ selectedValues }) {
  userAssignReply.value = quickReplyList.value[selectedValues].text
  showPickerReply.value = false
};

const userAssign = ref([]);
const userAssignText = ref('');
const userAssignReply = ref('');
const userAssignList = ref([]);
const dialogShow = ref(false);
const showPickerCheckbox= ref(false);
const checkboxRefs = ref([]);
function toggle(index:number){
  checkboxRefs.value[index].toggle();
};
function zhipaiSelect () {
  let arr:any[] = [];
  if(userAssign.value.length>0){
    userAssign.value.forEach(it=>{
      arr.push(userAssignList.value.find(item=>item.userId==it).userName)
    })
  }
  userAssignText.value = arr.join()
  showPickerCheckbox.value = false
};
function zhipaihandleSubmit() {
  if(!userAssign.value){
    showToast('請(qǐng)選擇處理人');
    return
  }
  setAssign({
    userIds:userAssign.value,//數(shù)組
    label: userAssignReply.value
  }).then((res) => {
    showNotify({ type: 'success', message: '成功' });
    dialogShow .value = false
    userAssign.value = ''
    userAssignReply.value = ''
  });
}

</script>

<template>
  <div class="detail-div">
  <van-button round color="#169bd5" @click="dialogShow = true”  style="width:98vw"
                >認(rèn)  領(lǐng)</van-button>
  
    <van-dialog v-model:show="dialogShow"  title="測(cè)試下拉輸入框與彈窗選擇" 
                show-cancel-button @confirm="zhipaihandleSubmit" :before-close="onBeforeClose">
                
      <van-field>
        <template #input>
          <van-field
            v-model="userAssignText"
            is-link
            readonly
            label="處理人"
            placeholder="請(qǐng)選擇"
            @click="showPickerCheckbox= true"
          />
        </template>
      </van-field>

      <van-field  v-if="currentRow.status==2">
        <template #input>
          <van-field
            v-model="userAssignReply"
            label="快捷回復(fù)"
            placeholder="請(qǐng)輸入內(nèi)容"
          />
          <van-button @click="showPickerReply= true" size="mini" icon="arrow-down" />
        </template>
      </van-field>
    </van-dialog>
    
    <van-popup v-model:show="showPickerReply" position="bottom">
      <van-picker
        title="快捷回復(fù)"
        :columns="quickReplyList"
        @confirm="QuickReplySelect"
        @cancel="showPickerReply= false"
      />
    </van-popup>

    <!-- 彈窗多選列表 -->
    <van-popup v-model:show="showPickerCheckbox" position="bottom">
      <div style="display: flex;justify-content: space-between;height:44px;line-height:44px;">
        <van-button style="border:none;color:#969799;" @click="showPickerCheckbox= false" size="normal">取消</van-button>
        <span style="font-size:16px;font-weight:bold;">處理人</span>
        <van-button style="border:none;color:#6398fb;" @click="zhipaiSelect" size="normal">確認(rèn)</van-button>
      </div>
      <van-checkbox-group v-model="userAssign" ref="checkboxGroup">
        <van-cell
          v-for="(item, index) in userAssignList"
          clickable
          :key="item"
          :title="` ${item.userName}`"
          @click="toggle(index)"
        >
          <template #right-icon>
            <van-checkbox
              :name="item.userId"
              :ref="el => checkboxRefs[index] = el"
              @click.stop
            />
          </template>
        </van-cell>
      </van-checkbox-group>
    </van-popup>

  </div>
</template>

總結(jié) 

到此這篇關(guān)于Vant彈出列表多選輸入框下拉選擇的文章就介紹到這了,更多相關(guān)Vant彈出列表多選輸入框下拉選擇內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue項(xiàng)目啟動(dòng)后沒(méi)有局域網(wǎng)地址問(wèn)題

    vue項(xiàng)目啟動(dòng)后沒(méi)有局域網(wǎng)地址問(wèn)題

    這篇文章主要介紹了vue項(xiàng)目啟動(dòng)后沒(méi)有局域網(wǎng)地址問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • VUE注冊(cè)全局組件和局部組件過(guò)程解析

    VUE注冊(cè)全局組件和局部組件過(guò)程解析

    這篇文章主要介紹了VUE注冊(cè)全局組件和局部組件過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • 教你用vue實(shí)現(xiàn)一個(gè)有趣的圍繞圓弧動(dòng)畫效果

    教你用vue實(shí)現(xiàn)一個(gè)有趣的圍繞圓弧動(dòng)畫效果

    最近做的兩個(gè)項(xiàng)目都是關(guān)于vue的,做完整理一下,這篇文章主要給大家介紹了關(guān)于如何用vue實(shí)現(xiàn)一個(gè)有趣的圍繞圓弧動(dòng)畫效果的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • 基于Vue+ECharts實(shí)現(xiàn)地圖展示與交互

    基于Vue+ECharts實(shí)現(xiàn)地圖展示與交互

    這篇文章中,我將逐步介紹如何使用 Vue 和 ECharts 實(shí)現(xiàn)一個(gè)互動(dòng)式的地圖展示組件,其中支持返回上一層地圖、點(diǎn)擊查看不同城市的詳細(xì)信息,以及根據(jù)數(shù)據(jù)動(dòng)態(tài)展示不同的統(tǒng)計(jì)信息,感興趣的小伙伴跟著小編一起來(lái)看看吧
    2025-02-02
  • vue 使用vue-i18n做全局中英文切換的方法

    vue 使用vue-i18n做全局中英文切換的方法

    這篇文章主要介紹了vue 使用vue-i18n做全局中英文切換的實(shí)現(xiàn)方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2018-10-10
  • vant van-list下拉加載更多onload事件問(wèn)題

    vant van-list下拉加載更多onload事件問(wèn)題

    這篇文章主要介紹了vant van-list下拉加載更多onload事件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 關(guān)于vue 結(jié)合原生js 解決echarts resize問(wèn)題

    關(guān)于vue 結(jié)合原生js 解決echarts resize問(wèn)題

    這篇文章主要介紹了關(guān)于vue 結(jié)合原生js 解決echarts resize問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • vue里面的el-select綁定默認(rèn)值方式

    vue里面的el-select綁定默認(rèn)值方式

    這篇文章主要介紹了vue里面的el-select綁定默認(rèn)值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • el-select 點(diǎn)擊按鈕滾動(dòng)到選擇框頂部的實(shí)現(xiàn)代碼

    el-select 點(diǎn)擊按鈕滾動(dòng)到選擇框頂部的實(shí)現(xiàn)代碼

    本文通過(guò)實(shí)例代碼給大家分享el-select 點(diǎn)擊按鈕滾動(dòng)到選擇框頂部效果,主要代碼是在visibleChange在這個(gè)popper里面找到.el-select-dropdown__list,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • vue實(shí)現(xiàn)可視化可拖放的自定義表單的示例代碼

    vue實(shí)現(xiàn)可視化可拖放的自定義表單的示例代碼

    這篇文章主要介紹了vue實(shí)現(xiàn)可視化可拖放的自定義表單的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-03-03

最新評(píng)論