ant design vue 自定义表头筛选,并一键清空
vue
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
项目地址:https://gitcode.com/gh_mirrors/vu/vue
免费下载资源
·
html: 使用filterDropdown自定义筛选,重写输入框发生变化的方法
js:通过filterValue控制各个表头筛选框内容
<a-table :columns="columns" :dataSource="values" :scroll="{x:true}" width="100%" rowKey="id" bordered>
<div slot="filterDropdown" slot-scope="{ setSelectedKeys, selectedKeys, confirm, clearFilters, column }"
style="padding: 8px"
>
<a-input
v-ant-ref="c => (searchInput = c)"
:placeholder="`Search ${column.title}`"
:value="selectedKeys[0]"
style="width: 188px; margin-bottom: 8px; display: block;"
@change="(e) => inputHandle(e.target.value,selectedKeys,column.key,setSelectedKeys)"
/>
<a-button
type="primary"
icon="search"
size="small"
style="width: 90px; margin-right: 8px"
@click="() => handleSearch(selectedKeys, confirm, column.key)"
>
Search
</a-button>
<a-button size="small" style="width: 90px" @click="() => handleReset(clearFilters,column.key)">
Reset
</a-button>
</div>
<a-icon
slot="filterIcon"
slot-scope="filtered"
type="search"
:style="{ color: filtered ? '#108ee9' : undefined }"
/>
</table>
data() {
return {
values: [],
query: {
page: PAGE,
pageSize: PAGE_SIZE,
trademarkOrderNo: '',
name: ''
},
searchInput: null,
searchedColumn:'',
filteredInfo: null,
}
},
computed: {
columns(){
let thead = JSON.parse(JSON.stringify(common.index.indexThead));
let columns = common.createHeader(thead);
let filteredInfo= this.filteredInfo||{};
columns[0] = {
key:'trademarkOrderNo',
title: columns[0].title,
dataIndex: columns[0].dataIndex,
filteredValue: filteredInfo.trademarkOrderNo||[''],
scopedSlots: {
filterDropdown: 'filterDropdown',
filterIcon: 'filterIcon',
customRender: 'customRender',
}
}
columns[1] = {
key:'name',
title: columns[1].title,
dataIndex: columns[1].dataIndex,
filteredValue: filteredInfo.name||[''],
scopedSlots: {
filterDropdown: 'filterDropdown',
filterIcon: 'filterIcon',
customRender: 'customRender',
}
}
return columns
}
},
methods:{
inputHandle(e,selectedKeys,key,setSelectedKeys){
this.query[key]=e;
let params={...this.filteredInfo}
params[key]=[e];
this.filteredInfo = params;
if(e==''){
return setSelectedKeys([])
}else{
return setSelectedKeys([])
}
},
handleSearch(selectedKeys, confirm, key) {
confirm();
this.query[key]=selectedKeys[0];
let params={...this.filteredInfo}
params[key]=[selectedKeys[0]];
this.filteredInfo = params;
this.queryList();
},
handleReset(clearFilters,key) {
clearFilters();
this.query[key]='';
let params={...this.filteredInfo}
params[key]=[''];
this.filteredInfo = params;
this.queryList();
},
clearQuery() {
this.filteredInfo = null;
this.query = {
page: PAGE,
pageSize: PAGE_SIZE,
name: '',
trademarkName: ''
}
this.queryList();
},
queryList(){
...
}
}
GitHub 加速计划 / vu / vue
83
16
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:5 个月前 )
9e887079
[skip ci] 3 个月前
73486cb5
* chore: fix link broken
Signed-off-by: snoppy <michaleli@foxmail.com>
* Update packages/template-compiler/README.md [skip ci]
---------
Signed-off-by: snoppy <michaleli@foxmail.com>
Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 7 个月前
更多推荐
已为社区贡献3条内容
所有评论(0)