安装
1  | cnpm i element-ui -S  | 
引入element-ui
在 main.js 中写入以下内容(完整引入):
1  | import Vue from 'vue';  | 
ElementUI表格合并单元格
摘抄自博客,仅用于学习。
| 序号 | 工单类型 | taskKey | templateUrl | 操作 | 
|---|---|---|---|---|
| 1 | 事件单 | shijian_01 | /shijian_01 | 编辑 删除 | 
| shijian_02 | /shijian_02 | 编辑 删除 | ||
| shijian_03 | /shijian_03 | 编辑 删除 | ||
| 2 | 问题单 | shijian_04 | /shijian_04 | 编辑 删除 | 
| shijian_05 | /shijian_05 | 编辑 删除 | ||
| shijian_06 | /shijian_06 | 编辑 删除 | 
代码附上:
1  | <template>  | 
详细说明:
1  | :span-method="objectSpanMethod"  | 
这个是官方给定的绑定属性和对应的方法,objectSpanMethod 传入了 { row, column, rowIndex, columnIndex }
row: 当前行
column: 当前列
rowIndex:当前行号
columnIndex :当前列号
该函数可以返回一个包含两个元素的数组,第一个元素代表rowspan,第二个元素代表colspan。 也可以返回一个键名为rowspan和colspan的对象。
1  | this.spanArr 数组 ,返回的是相对应的行合并行数  | 
这个示例打印出的this.spanArr为 [3, 0, 0, 3, 0, 0],比如,第一个元素为3,表示第一行应该向下合并3行(即第一行的rowspan为3),第二个元素的rowspan为0,就让它“消失”。
1  | rowspan()这个函数就是用来返回 this.spanArr 数组的,定义每一行的 rowspan  | 
rowspan()函数,if( index === 0),第一行,直接先给数组push进一个1,表示自己先占一行,this.position是数组元素的位置(此时是从数组元素的第一个开始,所以this.position为0), this.position为0意思表示的就是数组的第一个元素。
当到了index为2的时候,if(this.listData[index].type === this.listData[index-1].type ),让第二行与第一行作比较,
如果第二行与第一行相等的话,this.position就+1,当有n行第一行相同,this.position就为n,表示向下合并n行;第二行自己就this.spanArr.push(0),表示第二行“消失”,因为第一行和第二行合并了啊。
如果第二行与第一行不相等的话,那么this.spanArr.push(1);就让第二行自己独占一行;this.position = index意思就是把指针拿到index这行来,表示设置数组this.spanArr[this.position]的元素值,然后定义从此行开始向下合并几行(可能这句话我表述的不是很清楚你可以根据我这个示例研究下,当index为3时,this.position为3,当index为4时,第四行与第三行需要合并,那么在数组的this.position元素就要+1了,也就是this.spanArr[this.position] += 1)
还有最后一句话
1  | const _col = _row>0 ? 1 : 0;  | 
定义的这一个单元格列的合并,我们项目只合并行,不合并列;
_row:代表合并行的行数,_row的值要么是1,或者更大的自然正整数,要么是0。
1代表:独占一行
更大的自然数:代表合并了若干行
0:代表“消失”的哪那一个单元格,后面的单元格向前推一格
注意:如果配合分页一起渲染数据,要在rowspan函数中,先将this.spanArr清空数组。不添加,点分页加载数据会导致表格错乱。
1  | rowspan() {  | 
slot的使用
slots
| 事件名称 | 说明 | 
|---|---|
| title | 标题内容 | 
| content | 内容 | 
1  | <el-page-header @back="goBack" content="管理">  | 
解决引用Element UI 导致弹出多个message消息提示的问题
改造elementui的穿梭框,让他直接点击选项就穿梭到另一个框
element-ui change事件传值
1  | @change="handleSelect($event)"  | 
vue使用elementUI表单的获取select,checkbox的value值
1  | <el-checkbox  | 
checkbox的获取可以通过label来获得,将原来的label写在
即
事件传多参数
1  | <ul class="ul-list txt-left">  | 
Element ui el-row el-col里面高度不一致的问题
1  | <el-row type="flex">  | 
用饿了吗el-row,el-col布局页面的时候会因为el-col的内容高度不统一,造成布局混乱,解决方案就是在el-row中添加type=”flex”。
注意:里面的内容要有设定的高度,不然加上flex也无效。