当前位置: 首页 > news >正文

写作网站有哪些网站正在建设中 htmll

写作网站有哪些,网站正在建设中 htmll,html怎么设置网站吗,建网站服务el-table一键全选,分页的完美支持 问题背景尝试解决存在问题问题分析 解决方案改进思路如下具体代码实现如下 问题背景 现在有个需求,一个表格有若干条数据(假设数量大于20,每页10条,保证有2个以上分页即可)。 现在需要在表格上方…

el-table一键全选,分页的完美支持

  • 问题背景
      • 尝试解决
      • 存在问题
      • 问题分析
  • 解决方案
      • 改进思路如下
      • 具体代码实现如下

问题背景

现在有个需求,一个表格有若干条数据(假设数量大于20,每页10条,保证有2个以上分页即可)。
现在需要在表格上方加个全部选择的按钮,点击全部选择按钮时,可以把表格的复选框全部勾选,切换分页后依然是勾选状态,那么怎么实现呢?示意图如下:在这里插入图片描述

尝试解决

我们平时做表格的勾选时,一般都用selection-change方法。
假设我们有个接口getAllTableIds返回数据的全部id,那么我们尝试以下方法来实现上述需求:

<el-button type="primary" plain size="mini" @click="handleSelectAll">全部选中</el-button>
<el-tableref="tableRef":data="tableData"@selection-change="handleSelectionChange":row-key="row => row.id"
><el-table-column type="selection" reserve-selection label="序号" /><el-table-column label="编号" prop="code" />
</el-table>
export default {methods: {/** 多选框选中操作 */handleSelectionChange(selection) {this.ids = selection.map((item) => item.id);},// 全部选中handleSelectAll() {getAllTableIds().then(res => {this.ids = res.datathis.setSelectedCheckbox()})},// 设置按勾选框选中setSelectedCheckbox() {this.$nextTick(() => {if (this.ids.length > 0) {this.tableData.forEach((item) => {if ( this.ids.includes(item.id) ) {this.$refs.tableRef.toggleRowSelection(item, true);}});}})},}
}

存在问题

你这样写了之后,感觉还不错,点击全部选中按钮,也确实全都勾选了,就像上图一样,但是当你切换到第二页时,你就傻眼了,咋没勾选上呢?在这里插入图片描述

问题分析

上面我们的思路主要分为以下几个步骤:

  • 点击按钮,从接口处获取全部id列表,并保存到ids数组变量
  • 遍历当前页的数据,如果ids中存在该id,那么就把当前行设置为勾选状态
  • 切换分页时也调用setSelectedCheckbox方法
  • 傻眼了
    其实,逻辑都没有错,错的是没用对方法,就是上面提到的selection-change方法,如果你对该方法的函数handleSelectionChange打印一下,你会发现该方法执行了10次(因为每页10条数据)
    因为你在循环中执行勾选:
    this.$refs.tableRef.toggleRowSelection(item, true);
    
    就不断地触发handleSelectionChange方法,这也导致上面给ids赋值全部id的集合,也会变为当前页的集合,也就导致当你切换分页时,第二页不会勾选的原因。
    在这里插入图片描述

解决方案

el-table文档中还有这两种方法
在这里插入图片描述
既然循环勾选的时候会触发selection-change的方法,那么我们不用这个方法不就好了吗。
监听表格变化,可以用selectselect-all两种方法的结合;因为勾选状态无非就是勾选单行勾选当前页两种嘛!

改进思路如下

  • 点击按钮,从接口处获取全部id列表,并保存到ids数组变量
  • 遍历当前页的数据,如果ids中存在该id,那么就把当前行设置为勾选状态
  • 切换分页时也调用setSelectedCheckbox方法
  • 单行勾选变化
    • 选中:把该行id值push进ids数组,并去重(防止以外情况)
    • 取消勾选:把该行id值从ids数组中去除
  • 当前页勾选变化
    • 选中:把当前页的id值push进ids数组,并去重(防止以外情况)
    • 取消勾选:把当前页的id值从ids数组中去除

这样就不会影响ids的值了!

具体代码实现如下

<el-button type="primary" plain size="mini" @click="handleSelectAll">全部选中</el-button>
<el-tableref="tableRef":data="tableData"@select="handleSelectRow"@select-all="handleSelectAllRow":row-key="row => row.id"
><el-table-column type="selection" reserve-selection label="序号" /><el-table-column label="编号" prop="code" />
</el-table>
export default {methods: {/** 多选框选中操作 */handleSelectionChange(selection) {this.ids = selection.map((item) => item.id);},// 选择某行handleSelectRow(selection, row) {const id = row.idif(this.ids.includes(id)) {this.ids = this.ids.filter(item => item !== id)} else {this.ids.push(id)}},// 选择当前页handleSelectAllRow(selection) {// 如果全部勾选if(selection.length > 0) {const ids = selection.map((item) => item.id);this.ids = Array.from(new Set([...this.ids,...ids]))} else {// 如果当前页取消勾选const ids = this.tableData.map((item) => item.id);this.ids = this.ids.filter(item => !ids.includes(item))}},// 设置按勾选框选中setSelectedCheckbox() {this.$nextTick(() => {if (this.ids.length > 0) {this.tableData.forEach((item) => {if ( this.ids.includes(item.id) ) {this.$refs.tableRef.toggleRowSelection(item, true);}});}})},}
}

这样就能解决一键全选、且分页保留勾选状态的功能了!

别忘了,请求列表接口时也调用setSelectedCheckbox方法

如果有更好的解决办法,可在评论区讨论,谢谢。

http://www.yayakq.cn/news/367641/

相关文章:

  • 可以免费秒玩游戏的网站三合一网站建设平台
  • 网站优化销售话术wordpress如何设置网站地图
  • 多元网站建设帝国调用网站名称
  • 微商城网站建设案例简单flash网站模板
  • 系统开发北京网站建设wordpress+for+android
  • 珠海企业营销型网站建设公司名片网页设计代码
  • 有自己域名主机怎么做网站短视频运营推广
  • 网站建设要注意哪些事情烟台百度网站排名
  • 云海建设工程有限公司网站做网站是前端还是后端
  • 织梦生成网站地图无忧代理 在线
  • 自助建站营销招商软件技术大专出来都去干嘛了
  • 南昌优化网站推广深圳网络科技有限公司有哪些
  • 东莞网站营销网站建站模版
  • 静态网站入侵教程jsp 网站开发环境
  • 电子商务网站开发报价chatgpt中文在线
  • 天正电气网站建设在线设计平台行业
  • 风铃上做的网站发布时号码填写银川市做网站的公司
  • 制作微信网站模板江门市建设工程投标网站
  • 创建网站投资多少钱wordpress调用产品图片
  • vps建设网站需要条件游戏推广员一个月能赚多少
  • 新手学做免费网站谷歌seo优化公司
  • 网站建设方案书微商城论坛网站免费建设模板
  • 公司怎么制作网站成都购物网站设计
  • 什么是网站维护费心雨在线高端网站建设创新
  • 福州专业网站建设河南卓越建设工程有限公司网站
  • 上海精品网站建设网站站点结构图
  • 姜堰网站定制wordpress外链略缩图
  • 商会网站的建设化妆品网页设计模板图片
  • 视频网站建设方案书运行时间 wordpress
  • 网站加载页模板网站运营怎么自学