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

asp.net网站开发第一步厦门网站建设68

asp.net网站开发第一步,厦门网站建设68,备案ip 查询网站查询,百度怎样注册免费的网站iView Table 组件跨页选择功能实现文档 功能概述 实现基于 iView Table 组件的多选功能,支持以下特性: ✅ 跨页数据持久化选择✅ 当前页全选/取消全选✅ 自动同步选中状态显示✅ 分页切换状态保持✅ 高性能大数据量支持 实现方案 技术栈 iView UI 4…

iView Table 组件跨页选择功能实现文档

功能概述

实现基于 iView Table 组件的多选功能,支持以下特性:

  • ✅ 跨页数据持久化选择
  • ✅ 当前页全选/取消全选
  • ✅ 自动同步选中状态显示
  • ✅ 分页切换状态保持
  • ✅ 高性能大数据量支持

实现方案

技术栈

  • iView UI 4.x
  • Vue.js 2.x

核心思路

  1. 状态存储

    • 使用独立数组 selectedHospitals 存储选中项
    • 以唯一标识符 HOSPITAL_ID 作为数据标识
  2. 状态同步

    • 分页加载后同步表格选中状态
    • 使用 row-key 保证行识别稳定性
  3. 事件处理

    • 覆盖全部选择相关事件:
      • @on-select 单个选择
      • @on-select-all 全选当前页
      • @on-select-cancel 取消单个
      • @on-select-all-cancel 取消全选

代码示例

模板部分

<template><div class="container"><Tableborderref="selection"row-key="HOSPITAL_ID":columns="columns":data="currentPageData"@on-select="handleSelect"@on-select-all="handleSelectAll"@on-select-cancel="onSelectCancel"@on-select-all-cancel="onSelectAllCancel"/><Page:total="totalCount":current="currentPage"@on-change="handlePageChange"show-total/></div>
</template>

脚本部分

export default {data() {return {// 表格配置columns: [{ type: 'selection',width: 60,align: 'center',fixed: 'left'},// 其他数据列...],// 核心数据currentPageData: [],selectedHospitals: [],currentPage: 1,totalCount: 0}},methods: {// 数据获取方法async loadPageData(page = 1) {const res = await api.getHospitalList({page,pageSize: 10});this.currentPageData = res.data.items;this.totalCount = res.data.total;this.currentPage = page;this.$nextTick(this.syncSelectionStates);},// 状态同步方法syncSelectionStates() {this.currentPageData.forEach((row, index) => {const isSelected = this.selectedHospitals.some(item => item.id === row.HOSPITAL_ID);if (isSelected) {this.$refs.selection.toggleSelect(index);}});},// 事件处理handleSelect(_, row) {const targetIndex = this.selectedHospitals.findIndex(item => item.id === row.HOSPITAL_ID);if (targetIndex === -1) {this.selectedHospitals.push({id: row.HOSPITAL_ID,name: row.NAME,// 可扩展其他需要保存的字段});} else {this.selectedHospitals.splice(targetIndex, 1);}},handleSelectAll(selection) {if (selection.length === 0) {this.handleDeselectCurrentPage();} else {this.handleSelectCurrentPage(selection);}},handleSelectCurrentPage(selection) {const newSelections = selection.filter(row => !this.selectedHospitals.some(item => item.id === row.HOSPITAL_ID)).map(row => ({id: row.HOSPITAL_ID,name: row.NAME}));this.selectedHospitals.push(...newSelections);},handleDeselectCurrentPage() {const currentPageIds = new Set(this.currentPageData.map(row => row.HOSPITAL_ID));this.selectedHospitals = this.selectedHospitals.filter(item => !currentPageIds.has(item.id));}}
}

核心逻辑说明

关键配置

配置项说明
row-key必须设置为数据唯一标识字段
ref="selection"用于获取表格实例操作选中状态

状态同步流程

PageComponent Table StateStore UI 加载新数据 触发数据更新 获取已选数据 同步选中状态 更新勾选显示 PageComponent Table StateStore UI

性能优化策略

  1. 使用 Set 结构加速查找

    const idSet = new Set(currentPageIds);
    this.selectedHospitals.filter(item => !idSet.has(item.id));
    
  2. 批量操作减少 DOM 操作

    this.$nextTick(() => {this.syncSelectionStates();
    });
    
  3. 防重复处理

    selection.filter(row => !this.selectedHospitals.some(item => item.id === row.HOSPITAL_ID)
    )
    

注意事项

  1. 数据一致性

    • 确保接口返回数据包含 HOSPITAL_ID 字段
    • 分页大小(pageSize)需前后端统一
  2. 性能限制

    • 推荐在选中数据量 < 1000 时使用前端方案
    • 超过 1000 条建议改用服务端存储方案
  3. 特殊场景处理

    // 清空所有选择
    clearAllSelections() {this.selectedHospitals = [];this.$refs.selection.selectAll(false);
    }
    
  4. 版本兼容性

    • 需要 iView 4.3+ 版本支持完善的行选择功能

扩展功能建议

1. 选中项展示面板

<template><div class="selected-panel"><Tag v-for="item in selectedHospitals" :key="item.id"closable@on-close="handleRemoveTag(item.id)">{{ item.name }}</Tag></div>
</template>

2. 服务端全选方案

handleSelectAllPages() {this.$Modal.confirm({title: '全选确认',content: '将选择全部符合条件的记录(共'+this.totalCount+'条)',onOk: async () => {const res = await api.selectAllHospitalIds();this.selectedHospitals = res.data.map(id => ({id,name: '需二次加载名称' }));}});
}

3. 本地持久化存储

// 在 created 钩子中
const saved = localStorage.getItem('selectedHospitals');
if (saved) {this.selectedHospitals = JSON.parse(saved);
}// 添加 watch
watch: {selectedHospitals: {deep: true,handler(newVal) {localStorage.setItem('selectedHospitals', JSON.stringify(newVal));}}
}

常见问题

Q1: 切换分页后选中状态显示异常
✅ 解决方案:

  1. 检查是否设置 row-key
  2. 确认在数据更新后调用 syncSelectionStates

Q2: 全选操作性能较差
✅ 优化建议:

// 使用 Web Worker 处理大数据
const worker = new Worker('./selectionWorker.js');
worker.postMessage({ data: bigData });

Q3: 需要兼容多表格共存场景
✅ 改进方案:

// 使用 Symbol 作为存储键
const STORAGE_KEY = Symbol('hospital_selection');
this[STORAGE_KEY] = selectedData;


文章转载自:

http://OpjDAwMe.jxtbr.cn
http://D1WdITL5.jxtbr.cn
http://dGUE7tpA.jxtbr.cn
http://fp0Ubd74.jxtbr.cn
http://qQNvpDST.jxtbr.cn
http://752yo2Z9.jxtbr.cn
http://zmhUZyRc.jxtbr.cn
http://Tme86Mpy.jxtbr.cn
http://ObduZ9eJ.jxtbr.cn
http://1C9krIpn.jxtbr.cn
http://aH18KwIU.jxtbr.cn
http://nHXa9fSG.jxtbr.cn
http://bDrmclTE.jxtbr.cn
http://o5iFohZ5.jxtbr.cn
http://ZrErzcFC.jxtbr.cn
http://7XCku083.jxtbr.cn
http://0n7HELlM.jxtbr.cn
http://dkWmZNEi.jxtbr.cn
http://NDcY9Khw.jxtbr.cn
http://34NzmdDn.jxtbr.cn
http://2eH7me3T.jxtbr.cn
http://TeIuLxLt.jxtbr.cn
http://SRVEf46Z.jxtbr.cn
http://YQjnawQF.jxtbr.cn
http://4mRMe5kZ.jxtbr.cn
http://rFLgFBwf.jxtbr.cn
http://WZHAN6Od.jxtbr.cn
http://QcFjGAS3.jxtbr.cn
http://9C5mAFSu.jxtbr.cn
http://Ml1dEKkW.jxtbr.cn
http://www.dtcms.com/wzjs/718035.html

相关文章:

  • 微信棋牌游戏代理平台重庆整站优化的电话销售
  • 软件定制公司设计方案seo合作
  • 天猫网站网址wordpress 搜索栏
  • 北京网站制作很好 乐云践新谷歌seo技术
  • 网站建设技术服务费怎么入账河南最近的新闻
  • 骗子会利用钓鱼网站做啥域名解析ip138
  • 建设银行流水账网站查询wordpress略缩图alt
  • 微信小程序一站式开发一个人做导购网站
  • 商会建设网站说明seo整站优化托管
  • 怎样看一个网站是哪个公司做的网站域名要钱吗
  • 宁波免费做网站wordpress文章字体大小
  • 免费商城小程序源码wordpress优化速度
  • 分类门户网站开发团队网站建设项目验收单
  • 南京玄武区建设局网站wordpress寺院模板
  • 网站建设 会计分录如何在自己网站做解析api
  • 太平阳电脑网网站模板iis网站在点默认文档的时候报错.
  • 怎么能查到网站是哪个公司做的网站建设的实验心得体会
  • 做一个网站需要多长时间wordpress 播放器插件怎么用
  • 网站建设培训班多少钱网站建设客户开发方案
  • 网站如何加链接win7系统下动网站建设
  • 网站开发培训机构哪个好正保建筑工程网
  • 哪里做网站优化蚌埠网站制作公司哪家好
  • 设计网站能否用素材来制作广告好用的ppt模板网站免费
  • 在家用服务器做网站tint-k主题做企业网站
  • 鹿泉市建设局网站梅州在建工程
  • 网站的建设需要多少营销策划方案网站
  • 北京企业网站建设哪家服务好东莞网络优化公司
  • 苏州吴中区做网站公司企业网站内容管理
  • 有没有可以在网站上做试卷的wordpress指定id文章
  • 有哪些网站可以自己做加视频wordpress xiu主题5.2