基于vue的Element-ui定义自己的select组件

基于vue的Element-ui定义自己的select组件

<template>
  <div>
    <el-select v-model="svalue" placeholder="请选择" 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()">默认按钮</el-button> -->
    <!-- <input type="text" :value="value"> -->
  </div>
</template>

<script>
  export default {
    name: 'XdhSelect',
    data() {
      return {
        options:[],
        svalue: ''
      }
    },
    methods: {
        // clickme(){
        //     alert(this.svalue);
        // },
        //转换下拉框下的字段
       _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
       },//导入的url地址
       value: {
          type: String
       },//接受外部v-model传入的值
       fileType:{
          type:Object
       }//定义请求回来的json数据格式
    },
    mounted(){
        //初始话下拉框的值
        this.svalue=this.value;
        //远程请求回来的数据
        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为请求连接,fileType为返回的数据格式

猜你喜欢

转载自my.oschina.net/u/3012119/blog/2987355