成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

vue中怎么實現(xiàn)省市區(qū)三聯(lián)動下拉選擇組件

這篇文章給大家分享的是有關(guān)vue中怎么實現(xiàn)省市區(qū)三聯(lián)動下拉選擇組件的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)公司主營廣東網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都app開發(fā),廣東h5微信小程序開發(fā)搭建,廣東網(wǎng)站營銷推廣歡迎廣東等地區(qū)企業(yè)咨詢

首先來看一下最終的效果(沒有寫太多的樣式...)

vue中怎么實現(xiàn)省市區(qū)三聯(lián)動下拉選擇組件

組件所需要的省市區(qū)的JSON數(shù)據(jù)(已經(jīng)封裝為commonjs模塊了):    provinces.js

這個數(shù)據(jù)中有這樣幾個字段:

code: 當(dāng)前省市區(qū)的編碼

sheng: 當(dāng)前所在的省

name: 省市區(qū)的名字

level: 級別,省 level = 1, 市 level=2, 區(qū)/縣城 level = 3

di: 縣,市級別的區(qū)分

如何使用?

這里采用了 v-model暴露接口, 所以我們下拉選擇的值,你只需要在 v-model綁定的屬性中去拿即可

我們使用的字段是  cityInfo用于接收組件的數(shù)據(jù), 組件為了返回足夠的數(shù)據(jù), 它是一個對象

使用代碼示例  : 

App.vue

<template>
 <div id="app">
 <h6>vue 省市區(qū)三聯(lián)動 demo</h6>
 <city-select v-model="cityInfo"></city-select>
 <h7>v-model的值是 <code>{{ cityInfo }}</code></h7>
 <h7>從v-model得知,你選擇了 <i>{{ cityName }}</i></h7>
 </div>
</template>
<script>
 import CitySelect from './components/CitySelect.vue'
 export default {
 data() {
 return {
 cityInfo: '',
 }
 },
 components: {
 CitySelect
 },
 computed: {
 cityName() {
 const names = [];
 this.cityInfo.province && names.push(this.cityInfo.province.name + ' ')
 this.cityInfo.city && names.push(this.cityInfo.city.name + ' ')
 this.cityInfo.block && names.push(this.cityInfo.block.name + ' ')
 return names.join('')
 }
 }
 }
</script>
<style lang="stylus">
 h7
 padding 10px
 border 1px dotted
 h7 i
 color #f00
 border 1px dotted #ccc
</style>

cityName是我們需要展示的數(shù)據(jù),作為一個計算屬性而存在,因為這個值是不斷變化的,從cityInfo中抽取出來的數(shù)據(jù)

下面我們來看一下組件的實現(xiàn)代碼

CitySelect.vue

<template>
 <div class="city-select">
 <select v-model="selectedProvince" name="province">
 <option v-for="(item, index) in provinces"
 v-if="item.level === 1"
 :value="item">
 {{ item.name }}
 </option>
 </select>
 <select v-model="selectedCity" name="city">
 <option
 v-for="(item, index) in cities"
 :value="item">
 {{ item.name }}
 </option>
 </select>
 <select v-model="selectedBlock" name="block">
 <option
 v-for="(item, index) in blocks"
 :value="item">
 {{ item.name }}
 </option>
 </select>
 </div>
</template>
<script>
/**
 * 省 市 區(qū)/縣城 三聯(lián)動選擇器
*/
import provinces from './provinces.js'
import Vue from 'vue'
export default {
 name: 'app',
 created() {
 // 數(shù)據(jù)初始化,默認選中北京市,默認選中第一個;北京市數(shù)據(jù)為總數(shù)據(jù)的前18個
 let beijing = this.provinces.slice(0, 19)
 this.cities = beijing.filter(item => {
 if (item.level === 2) {
 return true
 }
 })
 this.selectedCity = this.cities[0]
 this.blocks = beijing.filter(item => {
 if (item.level === 3) {
 return true
 }
 })
 this.selectedBlock = this.blocks[0]
 },
 watch: {
 selectedProvince(newVal, oldVal) {
 // 港澳臺數(shù)據(jù)只有一級,特殊處理
 if (newVal.sheng === '71' || newVal.sheng === '81' || newVal.sheng === '82') {
 this.cities = [newVal]
 this.blocks = [newVal]
 } else {
 this.cities = this.provinces.filter(item => {
  if (item.level === 2 && item.sheng && newVal.sheng === item.sheng) {
  return true
  }
 })
 }
 var _this = this
 // 此時在渲染DOM,渲染結(jié)束之后再選中第一個
 Vue.nextTick(() => {
 _this.selectedCity = _this.cities[0]
 _this.$emit('input', _this.info)
 })
 },
 selectedBlock() {
 var _this = this
 Vue.nextTick(() => {
 _this.$emit('input', _this.info)
 })
 },
 selectedCity(newVal) {
 // 選擇了一個市,要選擇區(qū)了 di是城市的代表,sheng
 if (newVal.sheng === '71' || newVal.sheng === '81' || newVal.sheng === '82') {
 this.blocks = [newVal]
 this.cities = [newVal]
 } else {
 this.blocks = this.provinces.filter(item => {
  if (item.level === 3 && item.sheng && item.sheng == newVal.sheng && item.di === newVal.di && item.name !== '市轄區(qū)') {
  return true
  }
 })
 }
 var _this = this
 Vue.nextTick(() => {
 _this.selectedBlock = _this.blocks[0]
 // 觸發(fā)與 v-model相關(guān)的 input事件
 _this.$emit('input', _this.info)
 })
 }
 },
 computed: {
 info() {
 return {
 province: this.selectedProvince,
 city: this.selectedCity,
 block: this.selectedBlock
 }
 }
 },
 data() {
 return {
 selectedProvince: provinces[0],
 selectedCity: 0,
 selectedBlock: 0,
 cities: 0,
 provinces,
 blocks: 0
 }
 }
}
</script>
<style lang="stylus" scoped>
 .city-select select
 outline 0
</style>

組件關(guān)鍵點說明:

HTML模板采用三個 select下拉控件,分別具有v-model由于綁定選擇的數(shù)據(jù),使用v-for遍歷省市區(qū)數(shù)據(jù)

data中的數(shù)據(jù),分別是選中的省市區(qū)的值(對象形式); 以及當(dāng)前這個省的城市,這個城市的區(qū),見名知意

在create鉤子函數(shù)中我們進行了數(shù)據(jù)的初始化,默認我們顯示北京相關(guān)的信息,改變v-model對應(yīng)的屬性值

實現(xiàn)三聯(lián)動的重點:

我們使用watch監(jiān)測當(dāng)前省市區(qū)的改變(v-model中綁定的數(shù)據(jù)),一旦省 有變化,就需要拉取這個省相關(guān)的數(shù)據(jù),并且默認選中第一條數(shù)據(jù);  市,區(qū)的變化類似。

在這里我們采用了 ES5中的filter來進行數(shù)據(jù)的過濾,我們只要把數(shù)據(jù)過濾出來了,vue自動幫我們重新渲染,所以我們只需要把重點放在數(shù)據(jù)的篩選上就可以了

v-model接口的暴露:

要將數(shù)據(jù)綁定到v-model所綁定的屬性上,需要通過觸發(fā) input事件,參見 v-model的實現(xiàn)原理這篇文章

Vue.nextTick(() => {
 _this.$emit('input', _this.info)
 })

也就是這行代碼實現(xiàn)了組件內(nèi)部數(shù)據(jù)暴露的效果: v-model所綁定的cityInfo拿到了組件內(nèi)部的值

這里的 nextTick類似于setTimeout實現(xiàn)的效果,可以在執(zhí)行完其他任務(wù)(例如渲染DOM)之后再執(zhí)行相應(yīng)的回調(diào),我們使用它,可以保證我們的下一步操作是在DOM渲染完畢之后再執(zhí)行的,保證邏輯的正確性

感謝各位的閱讀!關(guān)于“vue中怎么實現(xiàn)省市區(qū)三聯(lián)動下拉選擇組件”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

分享標題:vue中怎么實現(xiàn)省市區(qū)三聯(lián)動下拉選擇組件
轉(zhuǎn)載源于:http://jinyejixie.com/article6/pgijig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、網(wǎng)站維護企業(yè)建站、小程序開發(fā)、標簽優(yōu)化、品牌網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護公司
金华市| 长丰县| 永善县| 四子王旗| 安国市| 稷山县| 车险| 名山县| 湖南省| 平潭县| 顺义区| 宾川县| 清流县| 高陵县| 陈巴尔虎旗| 鸡东县| 麟游县| 武川县| 安阳县| 玉林市| 科尔| 上林县| 甘德县| 上虞市| 钟祥市| 贵港市| 鄂州市| 海丰县| 三穗县| 宾阳县| 双牌县| 樟树市| 弋阳县| 霸州市| 石柱| 隆子县| 云龙县| 宜良县| 玉山县| 新乐市| 宜章县|