Vue扩展下拉表格组件:el-combo-grid

组件文件:el-combo-grid.vue

<template> 

 <div >    <el-input :value="value" @input="changeValue" @focus="onfocus" @blur="onblur" ref="inputValue">    <div class="el-picker-panel" :style="pStyle" v-show="visible" ref="elcombogrid">      <div class="table-container">        <el-table v-loading="listLoading"  :data="list" @row-click="rowClick" stripe  size="mini" element-loading-text="Loading" fit border highlight-current-row>          <el-table-column v-if="showIndex" label="序号"    type="index"  align="center" width="50">          <el-table-column v-for="itemin columns"                          :type="item.type"                          :key="item.key"                          :label="item.label"                          :prop="item.key"                          :align="item.align"                          :width="item.width"                          :header-align="item.headerAlign">            <template slot-scope="scope">            <span>{{ scope.row[item.key] }}        <cus-pagination v-show="pagination" :total="total" :page.sync="listQuery.page" :limit.sync="listQuery.limit" @pagination="getList"/></div></div></div></template>

<script>import requestfrom '@/utils/request';  export default {name:"el-combo-grid",      props:{value:{type:String},        requestUrl:{type:String},        columns:{type:Array},        panelStyle:{type:String},        itemValue:{type:String},        showIndex:{type:Boolean},        pagination:{type:Boolean}},      data(){return{visible:false,          pStyle:'width:500px',          list:[],          total:0,          listLoading:true,          listQuery: {page:1,            limit:5,            keyword:null          },          keyword:''        }},    mounted() {if(this.visible){// document.addEventListener('click',function (e) {//  if(this.$refs.elcombogrid.name!=e.target.prototype.name){//      this.visible = false;//    }// })        }},      methods:{changeValue(val){this.$emit('input',val)//向上级传送数据          this.keyword = valthis.getList()},        onfocus(el){this.pStyle =this.panelStyle+';position:absolute;z-index:999999'          this.visible =true          this.keyword =  el.target.value          this.getList()},        onblur(el){// if(this.visible && !this.isopen) {//  this.visible = false//  this.isopen = false// }        },        getList(){if(this.pagination){this.listQuery.keyword=this.keyword          }else {if(this.keyword){this.listQuery ={keyword:this.keyword              }}else {this.listLoading =false              return //如果不分页,无keyword不查询数据(避免大数据量)            }}this.listLoading =true;          this.queryTableData(this.listQuery).then(response => {this.list = response.data.list;            this.total = response.data.total;            this.listLoading =false;          })},        queryTableData(query){return request({url:this.requestUrl,              method:'post',              data: query});        },        rowClick:function(row, column, event){this.$emit('row-select-event',row, column, event)this.$emit('input',row[this.itemValue])this.visible =false        }}}</script>

使用实例:

<el-combo-grid v-model="form.studentName"

                :requestUrl="'/api/edu/student/listPage'" 

                :pagination="true"  //如果=true,requestUrl必须是分页插件,false直接返回data.list

                :columns="students_columns"// 下拉表格的列表

                :show-index="true" //下拉表格是否显示序号列

                :item-value="'name'"//当前控件取值的列名

                :panel-style="'width:550px'"//下拉面板的宽度

                @row-select-event="studentSelect"//下拉表格选择事件

>

</el-combo-grid>


定义在data中的下拉表格的列表

students_columns: [

{

label:'编号',

    key:'code',

    width:180,

    align:'left',

    headerAlign:'center'

  },

  {

label:'名称',

    key:'name',

    width:100,

    align:'left',

    headerAlign:'center'

  },

  {

label:'联系人名',

    key:'linkName',

    width:100,

    align:'left',

    headerAlign:'center'

  },

  {

label:'联系电话',

    key:'linkPhone',

    align:'left',

    headerAlign:'center'

  }]

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351