Heim > Web-Frontend > js-Tutorial > mint-ui implementiert die Implementierung der Auswahl einer dreistufigen Verknüpfung

mint-ui implementiert die Implementierung der Auswahl einer dreistufigen Verknüpfung

php中世界最好的语言
Freigeben: 2018-04-08 10:46:40
Original
2193 Leute haben es durchsucht

Dieses Mal werde ich Ihnen die Implementierung von mint-ui zur Auswahl der dreistufigen Verknüpfung vorstellen. Was sind die Vorsichtsmaßnahmen für die Auswahl der dreistufigen Verknüpfung durch mint-ui? Schauen Sie mal rein.

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 Landkreise 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>
Nach dem Login kopieren
Ⅱ, 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>
Nach dem Login kopieren
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:

Detaillierte Erklärung der Verwendung von Mint-UI in Vue

Tipps zur Verwendung des Swiper-Plugins -in in vue

Welche JS-Codespezifikationen hat Google veröffentlicht

Das obige ist der detaillierte Inhalt vonmint-ui implementiert die Implementierung der Auswahl einer dreistufigen Verknüpfung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage