Heim >Web-Frontend >js-Tutorial >mint-ui realisiert die gemeinsame Nutzung von Verknüpfungsfällen auf drei Ebenen

mint-ui realisiert die gemeinsame Nutzung von Verknüpfungsfällen auf drei Ebenen

php中世界最好的语言
php中世界最好的语言Original
2018-04-20 10:20:212249Durchsuche

Dieses Mal werde ich eine Fallstudie über die Realisierung einer Drei-Ebenen-Verknüpfung mit Mint-UI teilen. Was sind die Vorsichtsmaßnahmen für die Realisierung einer Drei-Ebenen-Verknüpfung? , lass uns einen Blick darauf werfen.

Das Projekt ist ein mobiles Projekt, das auf vue2 basiert. Der spezifische Inhalt ist wie folgt

Tatsächliche Wirkung

Dreistufige Adressverknüpfung mint-ui picker.png

Zuerst müssen Sie Daten herunterladen, die chinesische Provinzen, Städte, Bezirke und Kreise enthalten

wie folgt:
(Diese Adresse enthält Verknüpfungsdaten der zweiten Ebene, Verknüpfungsdaten der dritten Ebene, Verknüpfungsdaten der vierten Ebene usw., finden Sie, was Sie brauchen)
(Eine bessere Daten der chinesischen Region, Es wird empfohlen, dies zu verwenden)

3. Der spezifische Code

verwendet hauptsächlich die Picker-Komponente von mint-ui zur offiziellen Website

Ⅰ und HTML-Komponente

<p>
 <mt-picker :slots="myAddressSlots" @change="onMyAddressChange"></mt-picker>
 <p>地址3级联动:{{myAddressProvince}} {{myAddressCity}} {{myAddresscounty}}</p>
</p>

Ⅱ, Komponentenmethode

<script>
 import { Picker } from 'mint-ui';
 import myaddress from '../../../static/address3.json' //引入省市区数据
 export default {
 name: '',
 components: {
  'mt-picker': Picker
 },
 props: {},
 data () {
  return {
  myAddressSlots: [
   {
   flex: 1,
   defaultIndex: 1, 
   values: Object.keys(myaddress), //省份数组
   className: 'slot1',
   textAlign: 'center'
   }, {
   pider: true,
   content: '-',
   className: 'slot2'
   }, {
   flex: 1,
   values: [],
   className: 'slot3',
   textAlign: 'center'
   },
   {
   pider: true,
   content: '-',
   className: 'slot4'
   },
   {
   flex: 1,
   values: [],
   className: 'slot5',
   textAlign: 'center'
   }
  ],
  myAddressProvince:'省',
  myAddressCity:'市',
  myAddresscounty:'区/县',
  }
 },
 created() {
 },
 methods: {
  onMyAddressChange(picker, values) {
  if(myaddress[values[0]]){ //这个判断类似于v-if的效果(可以不加,但是vue会报错,很不爽)
   picker.setSlotValues(1,Object.keys(myaddress[values[0]])); // Object.keys()会返回一个数组,当前省的数组
   picker.setSlotValues(2,myaddress[values[0]][values[1]]); // 区/县数据就是一个数组
   this.myAddressProvince = values[0];
   this.myAddressCity = values[1];
   this.myAddresscounty = values[2];
  }
  },
 },
 mounted(){
  this.$nextTick(() => { //vue里面全部加载好了再执行的函数 (类似于setTimeout)
  this.myAddressSlots[0].defaultIndex = 0 
  // 这里的值需要和 data里面 defaultIndex 的值不一样才能够初始化
  //因为我没有看过源码(我猜测是因为数据没有改变,不会触发更新)
  });
 }
 }
</script>

Referenzartikel vue mint-ui realisiert eine 4-Ebenen-Verknüpfung von Provinz und Gemeindestraßen (Vier-Ebenen-Verknüpfung des Mint-UI-Pickers)

Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln zum PHP-Chinesen Webseite!

Empfohlene Lektüre:

Was sind die Verwendungsmöglichkeiten von Swiper in Vue?

Angular HMR-Funktionsimplementierungsmethode (mit Code)

Grafik-Tutorial für native schwebende Schaltflächenkomponenten reagieren

Das obige ist der detaillierte Inhalt vonmint-ui realisiert die gemeinsame Nutzung von Verknüpfungsfällen auf drei Ebenen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn