javascript - element-ui 如何取得select元件的label值?
曾经蜡笔没有小新
曾经蜡笔没有小新 2017-06-12 09:29:43
0
3
1962


1、如圖所示: 下拉選取202, 元件的change事件列印出來的是value值(就是下面印出來的),但我現在只想取得202(這是賦值在label屬性中的)這個值,不想取得下面印出來的值,如何解決? 謝謝了,被這個問題煩住了。

曾经蜡笔没有小新
曾经蜡笔没有小新

全部回覆(3)
阿神

你的select,是數組物件(不重複的)形式循環渲染出來的。所以可以只需操作資料形式求得,
@change="changeValue"

用Array find方法用物件的屬性來找出陣列裡的物件即可

changeValue(value) {
    console.log(value);
      let obj = {};
      obj = this.options.find((item)=>{
          return item.value === value;
      });
      console.log(obj.label);
}
具体demo如下:
// html
<script src="//unpkg.com/vue/dist/vue.js"></script>
<script src="//unpkg.com/element-ui@1.3.5/lib/index.js"></script>
<p id="app">
<template>
  <el-select v-model="value" placeholder="请选择" @change="changeValue">
    <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
    </el-option>
  </el-select>
</template>
</p>
// js
var Main = {
    data() {
      return {
        options: [{
          value: '选项1',
          label: '黄金糕'
        }, {
          value: '选项2',
          label: '双皮奶'
        }, {
          value: '选项3',
          label: '蚵仔煎'
        }, {
          value: '选项4',
          label: '龙须面'
        }, {
          value: '选项5',
          label: '北京烤鸭'
        }],
        value: ''
      }
    }
  }
var Ctor = Vue.extend(Main)
new Ctor({
    methods:{
          changeValue(value) {
            console.log(value);
          let obj = {};
          obj = this.options.find((item)=>{
              return item.value === value;
          });
          console.log(obj.label);
        }
  }
}).$mount('#app')
@import url("//unpkg.com/element-ui@1.3.5/lib/theme-default/index.css");

可以拷貝到這個位址運作下即可

曾经蜡笔没有小新

標籤(ref="xxx" data="56")

this.$refs.xxx.getAttribute('data')

typecho

你把label和value反過來試一試,不謝~

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板