Vue el-autocomplete遠(yuǎn)程搜索下拉框并實(shí)現(xiàn)自動(dòng)填充功能(推薦)
官網(wǎng)的demo獻(xiàn)上
在elementui Input輸入框中可以找到遠(yuǎn)程搜索組件,獲取服務(wù)端的數(shù)據(jù)
官網(wǎng)中的數(shù)據(jù)list都是寫(xiě)在loadAll()中的,而如果我們此時(shí)要用到mock的數(shù)據(jù)就要在此基礎(chǔ)上對(duì)代碼進(jìn)行修改。
-mock數(shù)據(jù)的獲取-
我們要獲取遠(yuǎn)程mock中所有學(xué)生的學(xué)號(hào)信息,根據(jù)輸入的數(shù)據(jù)來(lái)遠(yuǎn)程查找目標(biāo),并且在選中該目標(biāo)后能夠自動(dòng)填充對(duì)應(yīng)的姓名、生日、手機(jī)等信息,實(shí)現(xiàn)快速獲取信息的功能,再也不用手動(dòng)一個(gè)個(gè)去輸入所有的數(shù)據(jù)啦~
在template中添加el-autocomplete
<el-autocomplete placeholder="請(qǐng)輸入studentID" v-model="form.studentID" :fetch-suggestions="querySearchAsync" @select="handleSelect" > </el-autocomplete>
在script中添加以下函數(shù)
//queryString 為在框中輸入的值 //cb 回調(diào)函數(shù),將處理好的數(shù)據(jù)推回 querySearchAsync(queryString, cb) { var studentBasic = this.studentBasic; console.log(studentBasic) var results = queryString ? studentBasic.filter(this.createStateFilter(queryString)) : studentBasic; console.log('results '+results) clearTimeout(this.timeout); this.timeout = setTimeout(() => { cb(results); }, 0.5*1000); }, //根據(jù)輸入的字段進(jìn)行篩選 createStateFilter(queryString) { return (state) => { return (state.value.toString().toLowerCase().indexOf(queryString.toLowerCase()) === 0); }; }, //將其他數(shù)據(jù)自動(dòng)補(bǔ)全,采用覆蓋的方法 handleSelect(item){ this.form.name = item.name; this.form.studentID = item.value; this.form.birth = item.birthday; this.form.region = item.city; this.form.phone = item.phone; }
選中目標(biāo)學(xué)號(hào)以后自動(dòng)補(bǔ)全其他mock的數(shù)據(jù)
-
-踩坑點(diǎn)之value字段-
看了網(wǎng)上很多demo都說(shuō)后臺(tái)獲取的數(shù)據(jù)對(duì)象必須有value關(guān)鍵字,因?yàn)閍utocomplete只識(shí)別value字段,這里有一個(gè)實(shí)現(xiàn)的小trick:
this.studentBasic= JSON.parse(JSON.stringify(this.list).replace(/studentID/g,"value"));
JSON.stringify()
方法是將一個(gè)JavaScript值(對(duì)象或者數(shù)組)轉(zhuǎn)換為一個(gè) JSON字符串,如果指定了replacer是一個(gè)函數(shù),則可以替換值,或者如果指定了replacer是一個(gè)數(shù)組,可選的僅包括指定的屬性。這樣我們就可以把自己的屬性都替換成value字段啦~cool
總結(jié)
以上所述是小編給大家介紹的Vue el-autocomplete遠(yuǎn)程搜索下拉框并實(shí)現(xiàn)自動(dòng)填充功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
徹底搞懂并解決vue-cli4中圖片顯示的問(wèn)題實(shí)現(xiàn)
這篇文章主要介紹了徹底搞懂并解決vue-cli4中圖片顯示的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08Vue-admin-template?報(bào)Uncaught?(in?promise)?error問(wèn)題及解決
這篇文章主要介紹了Vue-admin-template?報(bào)Uncaught?(in?promise)?error問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07Vue3項(xiàng)目中配置TypeScript和JavaScript的兼容
在Vue3開(kāi)發(fā)中,常見(jiàn)的使用JavaScript(JS)編寫(xiě)代碼,但也會(huì)有調(diào)整編寫(xiě)語(yǔ)言使用TypeScript(TS)的需求,因此,在Vue3項(xiàng)目設(shè)置中兼容TS和JS是刻不容緩的重要任務(wù),2023-08-08使用Vue實(shí)現(xiàn)Markdown文檔的展示和解析
在Vue項(xiàng)目中,Markdown文檔的使用越來(lái)越普遍,因此在Vue中如何進(jìn)行Markdown文檔展示與解析也成為了一個(gè)熱門(mén)話(huà)題,本文將介紹如何使用Vue實(shí)現(xiàn)Markdown文檔的展示和解析,文中通過(guò)代碼示例講解的非常詳細(xì),需要的朋友可以參考下2024-01-01淺談vue中改elementUI默認(rèn)樣式引發(fā)的static與assets的區(qū)別
下面小編就為大家分享一篇淺談vue中改elementUI默認(rèn)樣式引發(fā)的static 與assets的區(qū)別,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02vue項(xiàng)目watch內(nèi)的函數(shù)重復(fù)觸發(fā)問(wèn)題的解決
這篇文章主要介紹了vue項(xiàng)目watch內(nèi)的函數(shù)重復(fù)觸發(fā)問(wèn)題的兩種解決方案,幫助大家更好的理解和學(xué)習(xí)使用vue,感興趣的朋友可以了解下2021-04-04vue判斷內(nèi)容是否滑動(dòng)到底部的三種方式
這篇文章主要介紹了vue判斷內(nèi)容是否滑動(dòng)到底部的三種方式,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-04-04vue路由傳參方式的方式總結(jié)及獲取參數(shù)詳解
vue 路由傳參的使用場(chǎng)景一般都是應(yīng)用在父路由跳轉(zhuǎn)到子路由時(shí),攜帶參數(shù)跳轉(zhuǎn),下面這篇文章主要給大家介紹了關(guān)于vue路由傳參方式的方式總結(jié)及獲取參數(shù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07