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

马洪旭 做的网站大学在线工具

马洪旭 做的网站大学,在线工具,短视频营销平台有哪些,郑州建设招标办网站写在最前 需求:有个表格列出了一些行数据,每个行数据点击后会加载出对应的详细数据,想要在点击了某一行后,能够将该点击反应到URL中,这样我复制这个URL发给其他人,他们打开时也能看到同样的行数据。 url会根…

写在最前

需求:有个表格列出了一些行数据,每个行数据点击后会加载出对应的详细数据,想要在点击了某一行后,能够将该点击反应到URL中,这样我复制这个URL发给其他人,他们打开时也能看到同样的行数据。

url会根据点击动态更新,大概是这样 xxx.com?param1=var1&param2=var2

主要版本:vue3,element-plus 2.3 (element-plus版本2.0就不行,已踩坑issue)

实现

URL参数的动态更新与访问加载

下面封装了更新URL参数获取URL参数的方法

// 更新URL参数
function updateURLWithParams(paramsObj: any) {// 入参检查if (typeof paramsObj !== 'object' || paramsObj === null) {console.error('Invalid input. params must be an object.');return;}// 获取当前URLconst url = new URL(window.location.href);// 创建基于当前URL的不含参数的URL对象const newUrl = new URL(url.origin + url.pathname);// 创建新的URLSearchParamsconst params = new URLSearchParams();// 添加搜索参数for (const key in paramsObj) {params.set(key, paramsObj[key]);}// 更新到新URL对象newUrl.search = params.toString();// 更新到浏览器history(地址栏改变)window.history.pushState('', '', newUrl.toString());
}// 获取URL参数
function getQueryParamsFromURL() {const urlObj = new URL(window.location.href);const queryParams = urlObj.searchParams;const params: { [key: string]: string } = {};for (const [key, value] of queryParams.entries()) {params[key] = value;}return params;
}

然后在监听点击行数据的方法中调用即可。

handleRowClick(row: any, event: any, column: any) {// 加载数据的code...// 更新参数到URL,这里假设把row的id放到参数里面updateURLWithParams({ "row_id": row.id});},

在初始化页面后,需要根据URL中参数加载出对应的行数据。对应的代码如下:

created() {// 从URL中拿到搜索参数const row_id = getQueryParamsFromURL()["row_id"];// 如果参数不为空,遍历表格数据找到对应的行if (!!row_id) {// tableData是el-table绑定的表格数据,tableRef是绑定的引用对象// <el-table :data="tableData" ref="tableRef">for (let index = 0; index < this.tableData.length; index++) {if (this.tableData[index].id==row_id) {// 设置表格当前行为参数中指定的行,如果表格设置了高亮,则同时会高亮当前行this.$refs.tableRef.setCurrentRow(this.tableData[index]);// 然后可以加载对应的行数据// coding...break;}}
}

至此已经实现了,点击行数据更新URL参数,访问带参的URL会选中指定的行并加载对应数据。

但是如果表格数据过多,有滚动条了,这时候还不能自动滚动到当前选中的行。

所以需要手动实现。

获取选中行的偏移高度并滚动到该处

el-table提供了滚动到指定位置的方法,但是需要输入坐标或者偏移量。

Table 表格 | Element Plus (element-plus.org)

 这里使用setScrollTop方法,所以我们需要获取当前已选中行的偏移高度并设置为滚动位置,代码如下:

// 获取偏移高度, tableRef是table的引用对象,index是行的索引
const offsetTop = this.$refs.tableRef.$el.getElementsByClassName('el-table__row')[index].offsetTop;
// 设置滚动位置
this.$refs.tableRef.setScrollTop(offsetTop);

结合上面找到并选中参数中指定行的代码,最终实现如下:

created() {// 从URL中拿到搜索参数const row_id = getQueryParamsFromURL()["row_id"];// 如果参数不为空,遍历表格数据找到对应的行if (!!row_id) {// tableData是el-table绑定的表格数据,tableRef是绑定的引用对象// <el-table :data="tableData" ref="tableRef">for (let index = 0; index < this.tableData.length; index++) {if (this.tableData[index].id==row_id) {// 设置表格当前行为参数中指定的行,如果表格设置了高亮,则同时会高亮当前行this.$refs.tableRef.setCurrentRow(this.tableData[index]);// 获取偏移高度, tableRef是table的引用对象,index是行的索引const offsetTop = this.$refs.tableRef.$el.getElementsByClassName('el-table__row') [index].offsetTop;// 设置滚动位置this.$refs.tableRef.setScrollTop(offsetTop);// 然后可以加载对应的行数据// coding...break;}}
}

总结

element-plus虽然很方便,但有时候不能直接满足需求,需要多查资料多摸索。另外本人不是专业前端,这里只是记录了一次有趣的解决问题的过程,如果有更优雅的解决方案,欢迎分享噢。

http://www.mnyf.cn/news/47201.html

相关文章:

  • 四川省建设厅建造师官方网站seo关键词排名系统
  • 潍坊住房公积金中心抖音seo推广
  • phpstudy做网站运营的坏处我要学电脑哪里有短期培训班
  • 网站登录如何做国外免费建站网站搭建
  • MAC怎么做网站如何自建网站?
  • 本网站正在建设升级中郑州网站seo技术
  • 连云港专业做网站推广网络广告
  • 做淘宝客网站需要多大的数据库上海网站关键词排名优化报价
  • 收录网站源码电商网站订烟平台官网
  • 大连网站建设设计公司哪家好头条新闻
  • 青海建筑网站建设公司网络营销策略分析报告
  • WordPress建b2c商城温州seo教程
  • 做cpc不做网站可以吗seo的方式有哪些
  • 郑州哪里做网站汉狮苏州首页排名关键词优化
  • 石家庄在哪个省seo01网站
  • 韩国购物网站百度总部投诉电话
  • 校园网上超市网站建设推广网站seo诊断优化方案
  • 网站按抓取手机软件贵阳福州seo网址优化公司
  • 长沙的企业网站建设seo托管
  • 网站主页面设计网页设计软件
  • python基础教程pdf杭州谷歌seo公司
  • 苏州网站小程序app开发公司专业全网优化
  • 石家庄新闻最新广州搜索排名优化
  • 静态单页网站wordpress网站创建的流程是什么
  • 陕西建设网站官网运营推广
  • 最优惠的赣州网站建设百度推广客服电话多少
  • 广州做外贸网站多少钱手机免费建站app
  • wordpress 屏蔽ftp厦门关键词优化平台
  • 网站制作怎么做让点击高资源优化排名网站
  • 做网站ui设计多少钱河北seo基础