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

基于vue2.0實(shí)現(xiàn)的級(jí)聯(lián)選擇器

 更新時(shí)間:2017年06月09日 15:09:39   作者:而立先生  
這篇文章主要介紹了基于vue2.0實(shí)現(xiàn)的級(jí)聯(lián)選擇器,基于Vue的級(jí)聯(lián)選擇器,可以單項(xiàng),二級(jí), 三級(jí)級(jí)聯(lián),多級(jí)級(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ú)外乎幾種情況:

  1. 單個(gè)級(jí)聯(lián) (下拉選擇框,單選)
  2. 單個(gè)級(jí)聯(lián) (多項(xiàng)選擇)
  3. 二級(jí)聯(lián)動(dòng) (省份和城市聯(lián)動(dòng))
  4. 三級(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ù)的合理性:

預(yù)覽地址

github地址

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)槔?

    Vue中禁止編輯的常見(jiàn)方法(以禁止編輯輸入框?yàn)槔?

    在我們開(kāi)發(fā)項(xiàng)目的時(shí)候,有時(shí)候我們不希望用戶對(duì)我們的頁(yè)面進(jìn)行操作,尤其是輸入框之類的,這篇文章主要給大家介紹了Vue中禁止編輯的常見(jiàn)方法,文中介紹的方法主要以禁止編輯輸入框?yàn)槔?需要的朋友可以參考下
    2024-02-02
  • Vue2.0中集成UEditor富文本編輯器的方法

    Vue2.0中集成UEditor富文本編輯器的方法

    本文給大家詳細(xì)講述了Vue2.0中集成UEditor富文本編輯器的方法以及相關(guān)注意事項(xiàng)做了講述,有興趣的朋友學(xué)習(xí)下。
    2018-03-03
  • vue中使用codemirror的實(shí)例詳解

    vue中使用codemirror的實(shí)例詳解

    這篇文章主要介紹了vue中使用codemirror的實(shí)例教程,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2018-11-11
  • Vue組件的Prop命名約定詳解

    Vue組件的Prop命名約定詳解

    這篇文章主要為大家介紹了Vue組件的Prop命名約定詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • vue封裝jquery修改自身及兄弟元素的方法

    vue封裝jquery修改自身及兄弟元素的方法

    本文主要介紹了vue封裝jquery修改自身及兄弟元素的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 使用vue實(shí)現(xiàn)計(jì)時(shí)器功能

    使用vue實(shí)現(xiàn)計(jì)時(shí)器功能

    這篇文章主要為大家詳細(xì)介紹了使用vue實(shí)現(xiàn)計(jì)時(shí)器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Vuejs 組件——props數(shù)據(jù)傳遞的實(shí)例代碼

    Vuejs 組件——props數(shù)據(jù)傳遞的實(shí)例代碼

    本篇文章主要介紹了Vuejs 組件——props數(shù)據(jù)傳遞的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • Vue3使用JSX的方法實(shí)例(筆記自用)

    Vue3使用JSX的方法實(shí)例(筆記自用)

    以前我們經(jīng)常在react中使用jsx,現(xiàn)在我們?cè)趘ue中也是用jsx,下面這篇文章主要給大家介紹了關(guān)于Vue3使用JSX的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏

    Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 探討Vue.js的組件和模板

    探討Vue.js的組件和模板

    指令是Vue.js中一個(gè)重要的特性, 主要提供了一種機(jī)制將數(shù)據(jù)的變化映射為DOM行為。下面通過(guò)本文給大家分享Vue.js的組件和模板,需要的朋友參考下吧
    2017-10-10

最新評(píng)論