elementUI el-table 懒加载实现修改删除刷新子节点信息

elementUI el-table 懒加载实现修改删除刷新子节点信息,第1张

data()中定义一个map对象存放节点信息

load()方法中点击加载子节点时保存信息到maps

删除和修改的函数中传入fu父级id查找到保存在map对象中的节点信息触发一次load()从而达到更新子节点信息的效果

一:首先 创建 el-table

<el-table

ref="BaseTable"//设置 ref属性

:highlight-current-row="true"//高光选中

:current-row-key="NowRowIndex"//行号

:row-class-name="tableRowClassName"//装载 EL-TABLE前执行的 方法 会遍历每一行 每一个单元格

@row-click="BaseRowClick">//添加行点击事件

二:添加 分页 组件 细节在于 :current-page.sync="currentPage" 不写这句 无效

<el-pagination

:current-page.sync="currentPage"

layout="prev, pager, next"

@current-change="current_change"//选中页 改变事件

:total="total"//总行数

:page-count="AllPageCount"//总页数

:page-size="pagesize"//每页显示的行数

background >

</el-pagination>

三:current_change()选中页 改变事件 记录当前选中的行号

current_change:function(currentPage){

this.currentPage = currentPage

this.LastPageCount = currentPage

this.SetCreenRow(this.BaseInfoList[this.SelectDataIndex])

}

四:tableRowClassName()方法,给EL-TABLE设置行号

tableRowClassName ({row, rowIndex}) {

row.row_index = rowIndex

}

五:行点击事件

BaseRowClick(row, column, event){

this.NowRowIndex = row.row_index//记录点击行的行号

this.NowSelectNum = row.SuppliesNum//记录行数据中的一个唯一键 以便 绑定 记录的选中行

//记录点击行时的 纵轴滚动条位置

let vmEl = this. el

const scrollParent = vmEl.querySelector('.el-table__body-wrapper')

this.Nowscroll = scrollParent.scrollTop

}

六:刷新列表的方法 内 绑定 之前 选中的 页码 行 及 滚动条位置

//选中 之前记录的 分页页码

this.current_change(this.LastPageCount)

//设置 滚动条到之前记录的位置 细节在于必须加 setTimeout 否则无效

setTimeout(() =>{

this.$refs.BaseTable.bodyWrapper.scrollTop = this.Nowscroll

}, 13)

题主是否想询问“vueel-table没有响应试更新措施”采取措施如下:

1、数据没有更新,组件也无法自动更新,请检查数据是否已经更新,并且是否正确地重新绑定到组件的数据属性中。

2、浏览器缓存问题,浏览器缓存了旧的组件数据,会导致组件没有正确更新,请尝试清除浏览器缓存,或者在代码中添加时间戳等方式来确保浏览器不会缓存旧数据。

3、清除浏览器缓存或者在代码中添加时间戳等方式来确保浏览器不会缓存旧数据。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11685245.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存