基于vue的Element-ui定義自己的select組件

<template>
  <div>
    <el-select v-model="svalue" placeholder="請(qǐng)選擇" filterable>
      <el-option
        v-for="item in options"
        :key="item.value"
        :label="item.label"
        :value="item.value">
      </el-option>
    </el-select>
    <!-- <el-button @click="clickme()">默認(rèn)按鈕</el-button> -->
    <!-- <input type="text" :value="value"> -->
  </div>
</template>

<script>
  export default {
    name: 'XdhSelect',
    data() {
      return {
        options:[],
        svalue: ''
      }
    },
    methods: {
        // clickme(){
        //     alert(this.svalue);
        // },
        //轉(zhuǎn)換下拉框下的字段
       _dataTransform(data){
          let _data = [];
          for (let i = 0; i < data.length; i++) {
              _data[i] = {};
              _data[i].label = data[i][this.fileType.label];
              _data[i].value = data[i][this.fileType.value];
            }
            return _data;
       }
     },
     watch:{
        //判斷下拉框的值是否有改變
        svalue(val, oldVal) {
            // console.log('new: %s, old: %s', val, oldVal)
            if(val!=oldVal){
                this.$emit('input', this.svalue); 
            }
        }, 
    },
    props: {
       url:{
          type:String
       },//導(dǎo)入的url地址
       value: {
          type: String
       },//接受外部v-model傳入的值
       fileType:{
          type:Object
       }//定義請(qǐng)求回來的json數(shù)據(jù)格式
    },
    mounted(){
        //初始話下拉框的值
        this.svalue=this.value;
        //遠(yuǎn)程請(qǐng)求回來的數(shù)據(jù)
        this.$fetch(this.url)
            .then((response) => {
                this.options=this._dataTransform(response);
        })
    }
  }
</script>

組件用法

<xdh-select :url="'/api/option'" v-model="isShow" :fileType="{'value':'dasm','label':'dasmb'}"></xdh-select>

url為請(qǐng)求連接,fileType為返回的數(shù)據(jù)格式

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容