programing

Vue.js/Vuetify - 다른 선택 항목을 기준으로 선택 데이터 필터링

prostudy 2022. 3. 8. 22:15
반응형

Vue.js/Vuetify - 다른 선택 항목을 기준으로 선택 데이터 필터링

데이터를 필터링하여 다른 선택 항목을 기준으로 한 선택 항목을 채우려면 어떻게 해야 하는가?예를 들어, 나는 한 선택에서 주를 선택하고, 두 번째 선택에는 그 특정 주로부터 모든 도시가 적재된다.vue.js와 vuetify를 프레임워크로 사용하고 있다(v-select 구성 요소 포함).계산된 속성을 설정하려고 했지만, 첫 번째 선택에서 선택해도 두 번째 선택에서는 데이터가 로드되지 않는다.

HTML

Vue.use(Vuetify);

var app = new Vue({
  el: '#app',
  data() {
    return {
      items: {
        home_id: null,
      },
      support: {
        home_province: '',
      },
      options: {
        opt_province: [{
          text: 'British Columbia',
          value: 1
        }, {
          text: 'Ontario',
          value: 2
        }],
        opt_city: [{
          text: 'Vancouver',
          value: 1,
          dependency: 1
        }, {
          text: 'Surrey',
          value: 1,
          dependency: 1
        }, {
          text: 'London',
          value: 1,
          dependency: 2
        }, {
          text: 'Toronto',
          value: 1,
          dependency: 2
        }]
      }
    }
  },
  computed: {
    filteredData() {
      var city = this.options.opt_city;
      var province = this.support.home_province;
      for (var i = 0; i < city.length; i++) {
        if (city[i].dependency != province.value) {
          city.splice(i);
        }
      }
      return city;
    },
  }
})
<script src="https://unpkg.com/vue@2.4.1/dist/vue.js"></script>
<link href="https://unpkg.com/vuetify/dist/vuetify.min.css" rel="stylesheet" />
<script src="https://unpkg.com/vuetify/dist/vuetify.min.js"></script>
<link href='https://fonts.googleapis.com/css?family=Roboto:300,400,500,700|Material+Icons' rel="stylesheet" type="text/css">
<div id="app">
  <v-app>
    <v-card class="grey lighten-4 elevation-0">
      <v-card-text>
        <v-container fluid>
          <v-layout row wrap>
            <v-flex xs4>
              <v-flex>
                <v-subheader>Origin Province</v-subheader>
              </v-flex>
              <v-flex>
                <v-select :items="options.opt_province" v-model="support.home_province" label="Select" class="input-group--focused" single-line>
                </v-select>
              </v-flex>
            </v-flex>
            <v-flex xs4>
              <v-flex>
                <v-subheader>Origin City</v-subheader>
              </v-flex>
              <v-flex>
                <v-select :items="filteredData" v-model="items.home_id" label="Select" class="input-group--focused" single-line autocomplete>
                </v-select>
              </v-flex>
            </v-flex>
          </v-layout>
        </v-container>
      </v-card-text>
    </v-card>
  </v-app>
</div>

여기 jsfiddle 링크: https://jsfiddle.net/vcmiranda/tkkhwq6m/

고마워요.

당신이 하고 싶은 것은 도시 선택지를 여과하는 것이다.

변경하기filteredData에 대한 계산된 속성.

filteredData() {
  let options = this.options.opt_city
  return options.filter(o => o.dependency == this.support.home_province)
}

업데이트된 바이올린.

참조URL: https://stackoverflow.com/questions/45224973/vue-js-vuetify-filter-select-data-based-on-another-select-choice

반응형