ホームページ >ウェブフロントエンド >jsチュートリアル >mint-uiは3段階連携の選択実装を実現します

mint-uiは3段階連携の選択実装を実現します

php中世界最好的语言
php中世界最好的语言オリジナル
2018-04-08 10:46:402213ブラウズ

今回は、mint-ui で 3 レベル連携を選択するための実装についてお届けします。 mint-ui で 3 レベル連携を選択する場合の 注意点 について、実際のケースを見てみましょう。

参考までにプロジェクトはvue2ベースのモバイルプロジェクトです

1.実際の効果

アドレス3層連携mint-ui picker.png

2.まず、次のように中国の省、市、区、郡を含むデータをダウンロードします

:
(このアドレスには、第 2 レベルのリンケージ データ、第 3 レベルのリンケージ データ、第 4 レベルのリンケージ データなどが含まれます。必要なもの)
(中国のデータの場合はこれをお勧めします)

3. 特定のコード

は主に mint-ui のピッカー コンポーネントを使用します。 mint-ui の使用については、を参照してください。公式サイト

Ⅰ、htmlコンポーネント

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

Ⅱ、コンポーネントメソッド

<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>

省市街路の4段階連携を実現するvue mint-uiの記事を参照(mint-uiピッカーの4段階連携)

この記事の事例を読んだ後、あなたはその方法をマスターしたと思います。さらに興味深い情報については、php 中国語の Web サイトのその他の関連記事に注目してください。

推奨読書:

vue での mint-ui の使用の詳細な説明

vue でスワイパー プラグインを使用するためのヒント

Google がリリースした JS コードの仕様について

以上がmint-uiは3段階連携の選択実装を実現しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。