当前位置:首页 > 技术文章 > 正文内容

Vue3开发极简入门(11):query传参(vue query传对象)

zonemu3个月前 (07-12)技术文章37

列表页传参Staff.vue:

<template>
    <div class="staff">
        <main class="container">
            <aside class="sidebar">
                <nav>
                    <ul>
                        <li v-for="staff in staffList" :key="staff.id">
                            <!-- <router-link :to="`/staff/info?id=${staff.id}&name=${staff.name}&age=${staff.age}`" active-class="activeLink">{{ staff.name }}</router-link> -->
                            <router-link :to="{
                                path: '/staff/info',
                                query: {
                                    id: staff.id,
                                    name: staff.name,
                                    age: staff.age
                                }
                            }" active-class="activeLink">
                                {{ staff.name }}
                            </router-link>
                        </li>
                    </ul>
                </nav>
            </aside>
            <section class="content">
                <router-view />
            </section>
        </main>
    </div>
</template>
<script lang='ts' setup name='Staff'>
import { reactive } from 'vue';
// 数据准备
const staffList = reactive([
    { id: "1", name: "张三", age: 22 },
    { id: "2", name: "李四", age: 23 },
    { id: "3", name: "王五", age: 24 }
])
</script>
<style scoped>
.staff {
    background-color: darkslategrey;
}

.container {
    display: flex;
    margin-top: 10px;
}

.sidebar {
    width: 50px;
    color: white;
    box-sizing: border-box;
}

.sidebar nav ul {
    list-style-type: square;
    padding: 0;
}

.sidebar nav ul li {
    margin: 15px 0;
    color: gold;
}

.content {
    flex: 1;
    width: 600px;
    box-sizing: border-box;
    overflow-y: auto;
    background-color: #ecf0f1;
}

.activeLink {
    color: white;
}
</style>

有两种跳转传参的写法如下。

URL式:

<router-link 
  :to="`/staff/info?id=${staff.id}&name=${staff.name}&age=${staff.age}`">
  {{ staff.name }}
<router-link>

这种写法太丑,传参多的话,后面跟一大串。这种写法适合传1个参数,例如id这种。

对象式:

<router-link 
  :to="{
    path: '/staff/info',
    query: {
      id: staff.id,
      name: staff.name,
      age: staff.age
    }
  }">{{ staff.name }}</router-link>

之前在路由文件src/router/index.ts里面设置了name,这里可以用path,也可以用name。

详情页取参StaffInfo.vue:

<template>
    <div class="staffInfo">
        <ul>
            <li>主键:{{ query.id }}</li>
            <li>姓名:{{ query.name }}</li>
            <li>年龄:{{ query.age }}</li>
        </ul>
    </div>
</template>
<script lang='ts' setup name='StaffInfo'>
import { toRefs } from 'vue';
import { useRoute } from 'vue-router';
const route = useRoute()
const { query } = toRefs(route)
</script>
<style scoped>
.staffInfo {
    background-color: moccasin;
    color: black;
}

ul li {
    list-style-type: none;
    margin-top: 10px;
}
</style>

代码简单,不赘述,注意复习之前讲的hook函数、toRefs。

相关文章

前端React面试基础系列(React基础篇)

本文阅读8分钟,喜欢的小伙伴可以持续关系小编哦1. 什么是受控组件和非受控组件?受控组件像表单元素在用户输入时,像<input> <select>等元素需要绑定一个 chang...

(在线编辑DWG)网页CAD二开实现焊接符号绘制

前言在工程制图和制造领域,焊接符号(Welding Symbols)是用于表示焊缝类型、尺寸、位置以及工艺要求的标准化图形语言。广泛应用于机械设计、钢结构、船舶制造、压力容器等行业中,帮助技术人员理解...

html5你能把太阳系动态做出来,但是你能把月亮也做出来吗?

需要源码请评论后加前端学习群470593776课题:HTML5加原生js打造一个炫酷动态的太阳系简介:首先对于太阳系各大星球的运转关系,速度等资料,不然弄出来也是被喷的下场, 还有对于逻辑思维,算法的...

手把手教你如何在浏览器不崩溃的情况下过滤上百万行数据

最近我分配到了一个非常有趣的任务:在前端显示 1GB 文件和 200 万行数据,并实现过滤,在这篇文章中,我将分享我是如何完成这个任务的。背景我曾经创建了一个简单的 React 应用程序。这个应用程序...

JavaScript 数组的常用方法(javascript数组的常用方法)

在我们前端来说数组作为一个常用的类型,今天我们讲一下在实际使用中经常用到的方法和使用场景。concat() 多数组组合concat() 可以用来连接两个或多个数组,返回要给新的数组并且不会影响之前的数...

WordPress 内置的数组处理相关函数大全

我们使用 WordPress 开发的时候,有很大一部分的工作和数组处理有关,WordPress 本身也内置了一些非常方便的数组处理函数,今天给大家罗列一下,也方便自己以后写代码的时候查询。wp_par...