element-ui 在 el-table 标题中添加小图标


效果如下:

element-ui 在 el-table 标题中添加小图标

html代码:

<div class="table-box cus-table-box">
    <el-table :data="ruleForm.tableData" border style="width: 100%">
        <el-table-column prop="operation" label="操作" :render-header="renderHeader">
            <template slot-scope="scope">
                <el-button class="default-btn" size="mini" type="success" plain  @click="handleClick(scope.$index,ruleForm.tableData)" :class="{'defaultActive':scope.row.operation == '1'}">{{scope.row.operation == "1" ? "默认":"设为默认"}}</el-button>
                 <i class="el-icon-delete delete-btn" @click="deleteRow(scope.$index, ruleForm.tableData)"></i>
            </template>
        </el-table-column>
        <el-table-column prop="contacts" label="客户联系人" :render-header="renderHeaderO">
            <template slot-scope="scope">
                <el-input size="mini" v-model="scope.row.contacts" placeholder="请输入内容"></el-input>
            </template>
        </el-table-column>
        <el-table-column prop="phonenum" label="客户电话" :render-header="renderHeaderO">
            <template slot-scope="scope">
                <el-input size="mini" v-model="scope.row.phonenum" placeholder="请输入内容"></el-input>
            </template>
        </el-table-column>
        <el-table-column prop="post" label="职务" :render-header="renderHeaderO">
            <template slot-scope="scope">
                <el-input size="mini" v-model="scope.row.post" placeholder="请输入内容"></el-input>
            </template>
        </el-table-column>
    </el-table>
</div>

 

js代码:

//在头部标题上添加“新增”图标
renderHeader(h,{column}){
    return h(
        'div',
        [
            h('span',column.label),
            h('i',{
                class:'add-btn-icon el-icon-plus',
                on:{
                  click:this.addTableColumn //点击执行函数
                }
            })                        
        ]
    )
},
//在头部标题上添加小图标
renderHeaderO(h,{column}){
    return h(
        'div',
        [
            h('span',column.label),
            h('i',{
                class:'eidt-btn-icon el-icon-edit-outline'
            })                        
        ]
    )
},
//添加
addTableColumn(){
    var newRow = {
        operation:"0",
        contacts:"",
        phonenum:"",
        post:""
    };
    this.ruleForm.tableData.push(newRow)
},
//设置默认
handleClick(index,tableData){
    for(var i = 0;i < this.ruleForm.tableData.length;i++){
        if(index == i){
             this.ruleForm.tableData[i].operation = "1";
        }
        else{
            this.ruleForm.tableData[i].operation = "0";
        }
    }
},
//点击删除
deleteRow(index, rows){
    rows.splice(index, 1);
}

 

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/282360.html

(0)
上一篇 2022年8月26日 17:22
下一篇 2022年8月26日 17:23

相关推荐

发表回复

登录后才能评论

WordPress 数据库错误: [Duplicate entry '82-4d3f5343d1f1b32d21fd4fb47d88d6b2' for key 'task_id_source_url_key']
insert into wp_autoblog_queue(task_id,source_url,source_url_key,create_date_time,not_check_stoped,post_interval) values(82,'https://www.idc.net/help/os/linux/page/6438/','4d3f5343d1f1b32d21fd4fb47d88d6b2',1735090740,0,0)