el-table中点击跳转到详情页的两种方法

跳转的两种写法:

1.使用keep-alive使组件缓存,防止刷新时参数丢失

keep-alive 组件用于缓存和保持组件的状态,而不是路由参数。它可以在组件切换时保留组件的状态,从而避免重新渲染和加载数据。 keep-alive 主要用于提高页面性能和用户体验,而不涉及路由参数的传递和保留。这里使用 <keep-alive> 组件是为了在刷新页面时保持之前传递的参数,确保页面能够正确地显示之前的状态, 其实使用params更合适

html 复制代码
<el-table
          size="mini"
          :data="tableData"
          border
          style="width: 100%"
          :max-height="maxHeight"
        >
          <el-table-column prop="stationName" label="站点名称">
            <template slot-scope="scope">
              <keep-alive>
                <span
                  class="goDetail"
                  v-hasPermi="['station:detail']"
                  @click="go2Detail(scope.row)"
                >
                  {{ scope.row.stationName }}
                </span>
              </keep-alive>
            </template>
          </el-table-column>
<el-table>
javascript 复制代码
methods: {
// 跳转到详情页面
    go2Detail(row) {
      this.$router.push({
        path: "/site/siteDetail",
        query: {
          row
        }
      });
    },
 }

2.使用router-link , 使用 <router-link> 进行页面跳转时,刷新页面不会丢失携带的参数。这是因为 <router-link> 在进行路由导航时,会将参数作为路由的一部分,并在刷新页面时将这些参数保留下来。

html 复制代码
<el-table-column label="标准名称" align="center" :show-overflow-tooltip="false">
	<template slot-scope="scope">
		<router-link :to="'/water/standard/limit/' + scope.row.id" class="link-type">
		    <span>{{ scope.row.standardName }}</span>
		</router-link>
	</template>
</el-table-column>

需要在router/index.js中配置路由

javascript 复制代码
  {
    path: '/water',
    component: Layout,
    hidden: true,
    children: [{
      path: 'standard/limit/:standardId',
      component: (resolve) => require(['@/views/water/standard/limit'], resolve),
      name: 'Limit',
      meta: {
        title: '标准详情',
        icon: ''
      }
    }]
  },
相关推荐
悲且狂14 分钟前
Vue环境搭建:vue+idea
前端·vue.js·intellij-idea
大个个个个个儿26 分钟前
vue3腾讯云直播 前端拉流(前端页面展示直播)
前端·javascript·腾讯云
Cutey91637 分钟前
实现可配置的滚动效果:JavaScript与CSS双方案
javascript·面试
LoveCan39 分钟前
ant-design-vue自动计算a-table每一列的宽度的实现
前端·vue.js
喝西瓜汁的兔叽Yan39 分钟前
【常用功能】下载文件和复制到剪切板
前端·javascript
hepherd42 分钟前
Vue学习笔记 - 逻辑复用 - 组合式函数
前端·vue.js
1024小神42 分钟前
tauri2 程序如何拿到启动参数?例如-toen
前端·javascript
喝西瓜汁的兔叽Yan44 分钟前
探索 Vue 3 中 vue-router 的 router.resolve () API
前端·vue.js
Ankkaya1 小时前
基于 vue3,实现短信模板编辑
前端·vue.js
码觉客1 小时前
介绍一下基于 PDF.js 较新版本(接近或涵盖 v5.0 概念,虽然实际稳定版本可能是 v4.x)获取批注列表的方法
前端·javascript