1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
| <template>
| <div class="app-container">
|
| <div class="filter-container">
| <el-checkbox-group v-model="checkboxVal">
| <el-checkbox label="apple">apple</el-checkbox>
| <el-checkbox label="banana">banana</el-checkbox>
| <el-checkbox label="orange">orange</el-checkbox>
| </el-checkbox-group>
| </div>
|
| <el-table :data="tableData" :key="key" border fit highlight-current-row style="width: 100%">
| <el-table-column prop="name" label="fruitName" width="180"/>
| <el-table-column v-for="fruit in formThead" :key="fruit" :label="fruit">
| <template slot-scope="scope">
| {{ scope.row[fruit] }}
| </template>
| </el-table-column>
| </el-table>
|
| </div>
| </template>
|
| <script>
| const defaultFormThead = ["apple", "banana"];
|
| export default {
| data() {
| return {
| tableData: [
| {
| name: "fruit-1",
| apple: "apple-10",
| banana: "banana-10",
| orange: "orange-10"
| },
| {
| name: "fruit-2",
| apple: "apple-20",
| banana: "banana-20",
| orange: "orange-20"
| }
| ],
| key: 1, // table key
| formTheadOptions: ["apple", "banana", "orange"],
| checkboxVal: defaultFormThead, // checkboxVal
| formThead: defaultFormThead // 默认表头 Default header
| };
| },
| watch: {
| checkboxVal(valArr) {
| this.formThead = this.formTheadOptions.filter(i => valArr.indexOf(i) >= 0);
| this.key = this.key + 1;// 为了保证table 每次都会重渲 In order to ensure the table will be re-rendered each time
| }
| }
| };
| </script>
|
|