文章目录
一、方式一
二、方式二
三、方式三
总结
一、方式一
在画面A的table中,每条数据的右侧有一个操作按钮,点击查看按钮,跳转到画面B,并将参数传到画面B,将这条数据的详细内容显示在画面B上
画面A的代码
查看按钮
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" width="150px">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-search"
@click="handleView(scope.row)"
v-hasPermi="['goodsManage:storageInMaster:query']"
>查看
</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleConfirm(scope.row)"
v-hasPermi="['goodsManage:storageInMaster:edit']"
:disabled="scope.row.approveType == 1 ? true :false"
>审核
</el-button>
</template>
</el-table-column>
跳转及传参
handleView(row) {
this.$router.push({path: "/storagein/storagein-detail/detail/" + row.id});
},
router中路由的定义,所有的跳转都需要路由的文件中进行定义
{
path: '/storagein/storagein-detail',
component: Layout,
hidden: true,
permissions: ['goodsManage:storageInDetail:list'],
children: [
{
path: 'detail/:id(\\d+)',
component: () => import('@/views/goodsManage/storageInMaster/detail'),
name: 'Detail',
meta: {title: '国内低值货物入区明细', activeMenu: '/storageInMaster/detail'}
}
]
},
画面B的代码
created方法中通过this.$route.params方法获取了参数的参数,并根据参数将查询到的信息显示出来
created() {
this.queryParams.pid = this.$route.params && this.$route.params.id;
this.getMasterInfo();
this.getList();
},
二、方式二
在画面A的table中,每条数据的右侧有一个操作按钮,点击查看按钮,跳转到画面B,并将参数传到画面B,将这条数据的详细内容显示在画面B上
画面A的代码
查看按钮
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" fixed="right" width="150">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['goodsManage:gmCompanyGoodsStockChange:edit']"
v-if="false"
>修改
</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-search"
@click="handleView(scope.row)"
v-hasPermi="['goodsManage:gmCompanyGoodsStockChange:query']"
>查看
</el-button>
</template>
</el-table-column>
路由及传参
将参数写在query属性中。
/**查看详细情报 */
handleView(row) {
this.$router.push({
path: "/gmCompanyGoodsStockChange/gmCompanyGoodsStockChange-detail/detail",
query: {id: row.id, putrecNo: row.putrecNo}
})
},
router中路由的定义,所有的跳转都需要路由的文件中进行定义
{
path: '/gmCompanyGoodsStockChange/gmCompanyGoodsStockChange-detail/',
component: Layout,
hidden: true,
permissions: ['goodsManage:gmCompanyGoodsStockChange:list'],
children: [
{
path: 'detail',
component: () => import('@/views/goodsManage/gmCompanyGoodsStockChange/detail'),
name: 'Detail',
meta: {title: '库存调整详情', activeMenu: '/gmCompanyGoodsStockChange/detail'}
}
]
},
画面B的代码
created方法中通过this.$route.query方法获取了参数的参数,并根据参数将查询到的信息显示出来
created() {
console.log(this.$route.query);
this.queryParams.putrecNo = this.$route.query && this.$route.query.putrecNo;
this.queryParams.id = this.$route.query && this.$route.query.id;
this.selectInfo();
this.getList();
},
三、方式三
在画面A的table中,某个项目可以设置一个路由跳转,点击这个项目,跳转到画面B,并将参数传到画面B,将这条数据的详细内容显示在画面B上
画面A的代码
点击模板名称可以跳转到模板明细的画面
<el-table v-loading="loading" :data="templateList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center"/>
<el-table-column label="模板名称" align="center" prop="templateName">
<template slot-scope="scope">
<router-link :to="'/template/template-detail/detail/' + scope.row.id" class="link-type">
<span style="text-decoration: underline">{{scope.row.templateName}}</span>
</router-link>
</template>
</el-table-column>
<el-table-column label="仓库名称" align="center" prop="warehouseName"/>
<el-table-column label="货类名称" align="center" prop="goodsName"/>
<el-table-column label="是否基础模板" align="center" prop="isBasicsTemp" :formatter="formatTemp"/>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['settle:template:edit']"
>修改
</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['settle:template:remove']"
>删除
</el-button>
</template>
</el-table-column>
</el-table>
router中路由的定义,所有的跳转都需要路由的文件中进行定义
{
path: '/template/template-detail',
component: Layout,
hidden: true,
permissions: ['settle:bmsexpensetemplatedetail:list'],
children: [
{
path: 'detail/:id(\\d+)',
component: () => import('@/views/settle/template/detail'),
name: 'Detail',
meta: {title: '费率详情', activeMenu: '/template/detail'}
}
]
},
画面B的代码
created方法中通过this.$route.params方法获取了参数的参数,并根据参数将查询到的信息显示出来
created() {
//根据上一个画面传的id查询详细信息
this.queryParams.templateId = this.$route.params && this.$route.params.id;
this.getDetail();
//根据id查询费率明细信息
this.getList();
},
总结
rooter-link传参及使用的几种方式
1.路径:http://localhost:8081/#/test?name=1
<router-link :to="{path:'/test',query: {name: id}}">跳转</router-link>(id是参数)
使用:this.$route.query.id
2.路径:http://localhost:8081/#/test/1
<router-link :to="'/test/'+id">跳转</router-link>(id是参数)
使用:this.$route.params.id(这个id与路由的配置有关)
router.push中也有上面两种类似的写法