基于vue2.0實(shí)現(xiàn)的級(jí)聯(lián)選擇器
基于Vue的級(jí)聯(lián)選擇器,可以單項(xiàng),二級(jí), 三級(jí)級(jí)聯(lián),多級(jí)級(jí)聯(lián)
web開(kāi)發(fā)中我們經(jīng)常會(huì)遇到級(jí)聯(lián)選擇器的問(wèn)題,尤其是在表單中,無(wú)外乎幾種情況:
- 單個(gè)級(jí)聯(lián) (下拉選擇框,單選)
- 單個(gè)級(jí)聯(lián) (多項(xiàng)選擇)
- 二級(jí)聯(lián)動(dòng) (省份和城市聯(lián)動(dòng))
- 三級(jí)聯(lián)動(dòng) (省市區(qū)聯(lián)動(dòng))
在jquery中有很多好用的插件,比如select2, 單選,多選的功能都具備。
本文探討一下在vue中的實(shí)現(xiàn)級(jí)聯(lián)選擇器,自己在項(xiàng)目中碰到過(guò)以下兩種情況的后端數(shù)據(jù),查閱資料后也證實(shí)了這兩種數(shù)據(jù)的合理性:
1 后端處理數(shù)據(jù)邏輯
這種情況是比較推薦的,大量的數(shù)據(jù)運(yùn)算放在后端來(lái)進(jìn)行,只需前后端商量好數(shù)據(jù)格式即可
一般的數(shù)據(jù)格式可能如下:
[{ value: 'beijing', label: '北京', children: [{ value: 'chaoyang', label: '朝陽(yáng)' }, { value: 'haidian', label: '海淀' }, { value: 'changping', label: '昌平' }, { value: 'shunyi', label: '順義' }] }, { value: 'shanghai', label: '上海', children: [{ value: 'baoshan', label: '寶山' }, { value: 'jiading', label: '嘉定' }, { value: 'songjiang', label: '松江' }, { value: 'pudong', label: '浦東' }] }]
特點(diǎn):數(shù)據(jù)之間層級(jí)嵌套,上下級(jí)的關(guān)系很清晰
2 前端處理數(shù)據(jù)邏輯
這種情況適合數(shù)據(jù)量較小的數(shù)據(jù),或者由于某種原因后端只能返給你這種數(shù)據(jù),那所有的數(shù)據(jù)處理就需要前端來(lái)操作,最終拼成的格式也與上述情況類似,只不過(guò)是多幾個(gè)或少幾個(gè)字段的問(wèn)題。
數(shù)據(jù)格式可能會(huì)是這樣:
[{ code: 420000, name: '湖北省', parentCode: 0 }, { code: 420100, name: '武漢市', parentCode: 420000 }, { code: 420101, name: '市轄區(qū)', parentCode: 420100 }, { code: 420102, name: '江岸區(qū)', parentCode: 420100 }, { code: 420103, name: '江漢區(qū)', parentCode: 420100 }, { code: 420104, name: '硚口區(qū)', parentCode: 420100 }, { code: 420105, name: '漢陽(yáng)區(qū)', parentCode: 420100 }, { code: 421000, name: '荊州市', parentCode: 420000 }, { code: 421001, name: '市轄區(qū)', parentCode: 421000 }, { code: 421002, name: '沙市區(qū)', parentCode: 421000 }, { code: 421003, name: '荊州區(qū)', parentCode: 421000 }, { code: 430000, name: '湖南省', parentCode: 0 }, { code: 430100, name: '長(zhǎng)沙市', parentCode: 430000 }, { code: 430101, name: '市轄區(qū)', parentCode: 430100 }, { code: 430102, name: '芙蓉區(qū)', parentCode: 430100 }, { code: 430103, name: '天心區(qū)', parentCode: 430100 }, { code: 430104, name: '岳麓區(qū)', parentCode: 430100 }]
特點(diǎn):數(shù)據(jù)格式是個(gè)平面表,每一條數(shù)據(jù)中都帶有與之相對(duì)應(yīng)的上下級(jí)關(guān)系。當(dāng)我們查看某個(gè)數(shù)據(jù)的上下級(jí)時(shí),都需要重新去遍歷一遍數(shù)據(jù)。
如何在組件中使用
<div class="hello"> <form-organization :organization="organization" v-model="seleted"></form-organization> </div> <script> import FormOrganization from '@/components/FormOrganization' export default { name: 'hello', data () { return { seleted: [], organization: [{ value: 'beijing', label: '北京' }, { value: 'shanghai', label: '上海' }, { value: 'shenzhen', label: '深圳' }, { value: 'hangzhou', label: '杭州' }, { value: 'zhengzhou', label: '鄭州' }, { value: 'guangzhou', label: '廣州' }, { value: 'xiamen', label: '廈門' }] } }, components: { FormOrganization } } </script>
API
props | type | description |
---|---|---|
origanization | Array | 級(jí)聯(lián)數(shù)據(jù)源,格式必須按照第一種數(shù)據(jù)中的格式顯示 |
value | Array | 選中中或默認(rèn)值,可以直接用v-model語(yǔ)法糖,具體可以查看例子 |
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue中禁止編輯的常見(jiàn)方法(以禁止編輯輸入框?yàn)槔?
在我們開(kāi)發(fā)項(xiàng)目的時(shí)候,有時(shí)候我們不希望用戶對(duì)我們的頁(yè)面進(jìn)行操作,尤其是輸入框之類的,這篇文章主要給大家介紹了Vue中禁止編輯的常見(jiàn)方法,文中介紹的方法主要以禁止編輯輸入框?yàn)槔?需要的朋友可以參考下2024-02-02使用vue實(shí)現(xiàn)計(jì)時(shí)器功能
這篇文章主要為大家詳細(xì)介紹了使用vue實(shí)現(xiàn)計(jì)時(shí)器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08Vuejs 組件——props數(shù)據(jù)傳遞的實(shí)例代碼
本篇文章主要介紹了Vuejs 組件——props數(shù)據(jù)傳遞的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04