Maison >interface Web >Voir.js >Développement de composants Vue : méthode de mise en œuvre du composant de sélection de ville

Développement de composants Vue : méthode de mise en œuvre du composant de sélection de ville

王林
王林original
2023-11-24 08:29:051817parcourir

Développement de composants Vue : méthode de mise en œuvre du composant de sélection de ville

Développement du composant Vue : méthode de mise en œuvre du composant de sélection de ville

Dans le développement de Vue, le composant de sélection de ville est un composant très courant et pratique. Il est généralement utilisé pour des opérations interactives lorsque les utilisateurs sélectionnent une ville ou une région. Cet article présentera une méthode d'implémentation de composant de sélecteur de ville basée sur Vue et fournira des exemples de code spécifiques.

  1. Analyse des exigences
    Avant de commencer à écrire du code, nous devons d'abord clarifier les exigences du composant. Le sélecteur de ville doit avoir les fonctions suivantes :
  2. Afficher une liste de provinces optionnelles
  3. Afficher dynamiquement la liste des villes correspondantes en fonction de la province sélectionnée
  4. Afficher dynamiquement la liste des régions correspondantes en fonction de la ville sélectionnée
  5. Obtenir le résultat final de l'utilisateur sélection Villes et régions
  6. Conception de la structure des composants
    Selon les besoins, nous pouvons diviser le composant sélecteur de ville en trois sous-composants : ProvinceSelector (sélecteur de province), CitySelector (sélecteur de ville) et AreaSelector (sélecteur de région). Parmi eux, les composants ProvinceSelector et CitySelector peuvent communiquer en passant des accessoires et des événements. La structure de l'ensemble du composant est la suivante :
<template>
  <div class="city-selector">
    <ProvinceSelector @provinceChange="handleProvinceChange" />
    <CitySelector :province="selectedProvince" @cityChange="handleCityChange" />
    <AreaSelector :city="selectedCity" @areaChange="handleAreaChange" />
    <div class="selected-result">
      <p>已选城市:{{ selectedCity }}</p>
      <p>已选区域:{{ selectedArea }}</p>
    </div>
  </div>
</template>

<script>
import ProvinceSelector from './ProvinceSelector.vue'
import CitySelector from './CitySelector.vue'
import AreaSelector from './AreaSelector.vue'

export default {
  components: {
    ProvinceSelector,
    CitySelector,
    AreaSelector
  },
  data() {
    return {
      selectedProvince: '',
      selectedCity: '',
      selectedArea: ''
    }
  },
  methods: {
    handleProvinceChange(province) {
      this.selectedProvince = province
      this.selectedCity = ''
      this.selectedArea = ''
    },
    handleCityChange(city) {
      this.selectedCity = city
      this.selectedArea = ''
    },
    handleAreaChange(area) {
      this.selectedArea = area
    }
  }
}
</script>
  1. Implémentation du sous-composant
    Ensuite, nous écrivons respectivement le sélecteur de province, le sélecteur de ville et le sélecteur de région.

ProvinceSelector.vue :

<template>
  <div class="province-selector">
    <select v-model="selectedProvince" @change="handleChange">
      <option v-for="province in provinces" :key="province" :value="province">{{ province }}</option>
    </select>
  </div>
</template>

<script>
export default {
  data() {
    return {
      selectedProvince: ''
    }
  },
  computed: {
    provinces() {
      // 从后台或静态数据获取省份列表
      return ['北京', '上海', '广东', '江苏']
    }
  },
  methods: {
    handleChange() {
      this.$emit('provinceChange', this.selectedProvince)
    }
  }
}
</script>

CitySelector.vue :

<template>
  <div class="city-selector">
    <select v-model="selectedCity" @change="handleChange">
      <option v-for="city in cities" :key="city" :value="city">{{ city }}</option>
    </select>
  </div>
</template>

<script>
export default {
  props: {
    province: {
      type: String,
      default: ''
    }
  },
  data() {
    return {
      selectedCity: ''
    }
  },
  computed: {
    cities() {
      // 根据选择的省份从后台或静态数据获取城市列表
      if (this.province === '北京') {
        return ['北京市', '朝阳区', '海淀区']
      } else if (this.province === '上海') {
        return ['上海市', '黄浦区', '徐汇区']
      } else if (this.province === '广东') {
        return ['广州市', '深圳市', '珠海市']
      } else if (this.province === '江苏') {
        return ['南京市', '苏州市', '无锡市']
      } else {
        return []
      }
    }
  },
  watch: {
    province(newValue) {
      this.selectedCity = ''
    }
  },
  methods: {
    handleChange() {
      this.$emit('cityChange', this.selectedCity)
    }
  }
}
</script>

AreaSelector.vue :

<template>
  <div class="area-selector">
    <select v-model="selectedArea" @change="handleChange">
      <option v-for="area in areas" :key="area" :value="area">{{ area }}</option>
    </select>
  </div>
</template>

<script>
export default {
  props: {
    city: {
      type: String,
      default: ''
    }
  },
  data() {
    return {
      selectedArea: ''
    }
  },
  computed: {
    areas() {
      // 根据选择的城市从后台或静态数据获取区域列表
      if (this.city === '北京市') {
        return ['东城区', '西城区', '朝阳区']
      } else if (this.city === '上海市') {
        return ['黄浦区', '徐汇区', '长宁区']
      } else if (this.city === '广州市') {
        return ['越秀区', '海珠区', '天河区']
      } else if (this.city === '南京市') {
        return ['玄武区', '秦淮区', '鼓楼区']
      } else {
        return []
      }
    }
  },
  watch: {
    city(newValue) {
      this.selectedArea = ''
    }
  },
  methods: {
    handleChange() {
      this.$emit('areaChange', this.selectedArea)
    }
  }
}
</script>
  1. Utiliser les composants
    Après avoir terminé l'écriture du composant, introduisez-le là où vous devez utiliser le sélecteur de ville :
<template>
  <div>
    <CitySelector />
  </div>
</template>

<script>
import CitySelector from './CitySelector.vue'

export default {
  components: {
    CitySelector
  }
}
</script>

Ce qui précède est la méthode d'implémentation d'un composant de sélection de ville basé sur Vue. En divisant et en implémentant les fonctions de chaque sous-composant, nous pouvons combiner et appeler de manière flexible ces sous-composants pour implémenter un sélecteur de ville complet. J'espère que cet article vous aidera à comprendre et à apprendre le développement de composants Vue.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn