element的el-table表格自定义表头,<template #header> slot=“header“内,表格在触发事件,this的数据更改后会重置成原来的数据问题

element的el-table表格自定义表头,<template #header> slot="header"内,表格在触发事件,this的数据更改后会重置成原来的数据问题

<template header>
<div @clikc="checkTab('all')" >全部</div>
<div @clikc="checkTab('hot')" >热门</div>
</template>

这里的checkTab方法做的操作是更改一个状态为传入的值,但是点击热门后还是 all,所以把template header加一个# 后就不会刷新成原来的了,如下

<template #header>
<div @clikc="checkTab('all')" >全部</div>
<div @clikc="checkTab('hot')" >热门</div>
</template>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将以下vue+element ui代码转换纯html+element ui代码:<template> <el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick"> <el-tab-pane label="User" name="first"> <el-table :data="filterTableData" style="width: 100%"> <el-table-column label="Date" prop="date" /> <el-table-column label="Name" prop="name" /> <el-table-column align="right"> <template #header> <el-input v-model="search" size="small" placeholder="Type to search" /> </template> <template #default="scope"> <el-button size="small" @click="handleEdit(scope.$index, scope.row)" >Edit</el-button > <el-button size="small" type="danger" @click="handleDelete(scope.$index, scope.row)" >Delete</el-button > </template> </el-table-column> </el-table> </el-tab-pane> <el-tab-pane label="Config" name="second"> <el-table :data="filterTableData" style="width: 100%"> <el-table-column label="Date" prop="date" /> <el-table-column label="Name" prop="name" /> <el-table-column align="right"> <template #header> <el-input v-model="search" size="small" placeholder="Type to search" /> </template> <template #default="scope"> <el-button size="small" @click="handleEdit(scope.$index, scope.row)" >Edit</el-button > <el-button size="small" type="danger" @click="handleDelete(scope.$index, scope.row)" >Delete</el-button > </template> </el-table-column> </el-table></el-tab-pane> <el-tab-pane label="Role" name="third"> <el-table :data="filterTableData" style="width: 100%"> <el-table-column label="Date" prop="date" /> <el-table-column label="Name" prop="name" /> <el-table-column align="right"> <template #header> <el-input v-model="search" size="small" placeholder="Type to search" /> </template> <template #default="scope"> <el-button size="small" @click="handleEdit(scope.$index, scope.row)" >Edit</el-button > <el-button size="small" type="danger" @click="handleDelete(scope.$index, scope.row)" >Delete</el-button > </template> </el-table-column> </el-table></el-tab-pane> <el-tab-pane label="Task" name="fourth"> <el-table :data="filterTableData" style="width: 100%"> <el-table-column label="Date" prop="date" /> <el-table-column label="Name" prop="name" /> <el-table-column align="right"> <template #header> <el-input v-model="search" size="small" placeholder="Type to search" /> </template> <template #default="scope"> <el-button size="small" @click="handleEdit(scope.$index, scope.row)" >Edit</el-button > <el-button size="small" type="danger" @click="handleDelete(scope.$index, scope.row)" >Delete</el-button > </template> </el-table-column> </el-table></el-tab-pane> </el-tabs> </template> <script lang="ts" setup> import { computed, ref } from 'vue' interface User { date: string name: string address: string } const search = ref('') const filterTableData = computed(() => tableData.filter( (data) => !search.value || data.name.toLowerCase().includes(search.value.toLowerCase()) ) ) const handleEdit = (index: number, row: User) => { console.log(index, row) } const handleDelete = (index: number, row: User) => { console.log(index, row) } const tableData: User[] = [ { date: '2016-05-03', name: 'Tom', address: 'No. 189, Grove St, Los Angeles', }, { date: '2016-05-02', name: 'John', address: 'No. 189, Grove St, Los Angeles', }, { date: '2016-05-04', name: 'Morgan', address: 'No. 189, Grove St, Los Angeles', }, { date: '2016-05-01', name: 'Jessy', address: 'No. 189, Grove St, Los Angeles', }, ] </script> <style> .demo-tabs > .el-tabs__content { padding: 32px; color: #6b778c; font-size: 32px; font-weight: 600; } </style>
06-10
以下是转换后的纯HTML+Element UI代码: ```html <div class="demo-tabs el-tabs"> <div class="el-tabs__header"> <div class="el-tabs__nav-wrap"> <div role="tab" aria-controls="pane-first" :aria-selected="activeName==='first' ? 'true' : 'false'" class="el-tabs__item" :class="{ 'is-active': activeName==='first' }" @click="activeName='first'">User</div> <div role="tab" aria-controls="pane-second" :aria-selected="activeName==='second' ? 'true' : 'false'" class="el-tabs__item" :class="{ 'is-active': activeName==='second' }" @click="activeName='second'">Config</div> <div role="tab" aria-controls="pane-third" :aria-selected="activeName==='third' ? 'true' : 'false'" class="el-tabs__item" :class="{ 'is-active': activeName==='third' }" @click="activeName='third'">Role</div> <div role="tab" aria-controls="pane-fourth" :aria-selected="activeName==='fourth' ? 'true' : 'false'" class="el-tabs__item" :class="{ 'is-active': activeName==='fourth' }" @click="activeName='fourth'">Task</div> </div> </div> <div class="el-tabs__content"> <div role="tabpanel" aria-hidden="false" id="pane-first" class="el-tab-pane" :class="{ 'is-active': activeName==='first' }"> <table class="el-table" style="width: 100%"> <thead class="el-table__header"> <tr> <th class="el-table_1_column_1">Date</th> <th class="el-table_1_column_2">Name</th> <th class="el-table_1_column_3">Operation</th> </tr> </thead> <tbody class="el-table__body"> <tr v-for="(item, index) in filterTableData" :key="index"> <td>{{ item.date }}</td> <td>{{ item.name }}</td> <td class="el-table_1_column_3"> <button class="el-button el-button--small" @click="handleEdit(index, item)">Edit</button> <button class="el-button el-button--small el-button--danger" @click="handleDelete(index, item)">Delete</button> </td> </tr> </tbody> </table> </div> <div role="tabpanel" aria-hidden="true" id="pane-second" class="el-tab-pane" :class="{ 'is-active': activeName==='second' }"> <table class="el-table" style="width: 100%"> <thead class="el-table__header"> <tr> <th class="el-table_2_column_1">Date</th> <th class="el-table_2_column_2">Name</th> <th class="el-table_2_column_3">Operation</th> </tr> </thead> <tbody class="el-table__body"> <tr v-for="(item, index) in filterTableData" :key="index"> <td>{{ item.date }}</td> <td>{{ item.name }}</td> <td class="el-table_2_column_3"> <button class="el-button el-button--small" @click="handleEdit(index, item)">Edit</button> <button class="el-button el-button--small el-button--danger" @click="handleDelete(index, item)">Delete</button> </td> </tr> </tbody> </table> </div> <div role="tabpanel" aria-hidden="true" id="pane-third" class="el-tab-pane" :class="{ 'is-active': activeName==='third' }"> <table class="el-table" style="width: 100%"> <thead class="el-table__header"> <tr> <th class="el-table_3_column_1">Date</th> <th class="el-table_3_column_2">Name</th> <th class="el-table_3_column_3">Operation</th> </tr> </thead> <tbody class="el-table__body"> <tr v-for="(item, index) in filterTableData" :key="index"> <td>{{ item.date }}</td> <td>{{ item.name }}</td> <td class="el-table_3_column_3"> <button class="el-button el-button--small" @click="handleEdit(index, item)">Edit</button> <button class="el-button el-button--small el-button--danger" @click="handleDelete(index, item)">Delete</button> </td> </tr> </tbody> </table> </div> <div role="tabpanel" aria-hidden="true" id="pane-fourth" class="el-tab-pane" :class="{ 'is-active': activeName==='fourth' }"> <table class="el-table" style="width: 100%"> <thead class="el-table__header"> <tr> <th class="el-table_4_column_1">Date</th> <th class="el-table_4_column_2">Name</th> <th class="el-table_4_column_3">Operation</th> </tr> </thead> <tbody class="el-table__body"> <tr v-for="(item, index) in filterTableData" :key="index"> <td>{{ item.date }}</td> <td>{{ item.name }}</td> <td class="el-table_4_column_3"> <button class="el-button el-button--small" @click="handleEdit(index, item)">Edit</button> <button class="el-button el-button--small el-button--danger" @click="handleDelete(index, item)">Delete</button> </td> </tr> </tbody> </table> </div> </div> </div> ``` 需要注意的是,Element UI的CSS样式需要在HTML文件中引入。此外,上述代码中的`activeName`、`search`、`filterTableData`、`handleEdit`和`handleDelete`需要在JavaScript中定义和实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值