今回は、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 サイトのその他の関連記事に注目してください。
推奨読書:
以上がmint-uiは3段階連携の選択実装を実現しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。