封装vue element-ui下拉框组件

65 篇文章 1 订阅

原文:https://www.jianshu.com/p/aaf0acba97a0  

 

公用组件sltopn.vue

 

<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: 'sltopn',
    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地址
      urlName:{
        type:String
      },//跨域请求标志
      metName:{
        type:String
      },//方法名
      dtName:{
        type:String
      },//条件参数
      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);
        })*/

      let parames = {
        "moduleName": eval(this.urlName),
        "functionName": this.url,
        "methodName": this.metName,
        "data": { // 查询条件
          dictTypeCode: this.dtName
        }
      };
      this.http(JSON.stringify(parames))
        .then((res)=>{
          alert(JSON.stringify(res.data.dictList))
          this.options=this._dataTransform(res.data.dictList);
        }).catch(error => {
        console.log(error);
      })

    }
  }
</script>

页面使用

引入组件

 import sltopn from '@/components/select/sltopn.vue' 

注册组件

components: {sltopn }

//使用

<sltopn :url="'productbiz.service.commontable.PrdDictService'" :metName="'queryDict'"  :dtName="'fundType'" :urlName="'this.P'"  v-model="isShow" :fileType="{'value':'dictValue','label':'dictName'}"></sltopn>

 

效果

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值