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

wordpress 新浪图床win10优化大师免费版

wordpress 新浪图床,win10优化大师免费版,建设个网站从哪里盈利,17网站一起做网店睡衣批发目录 一、路由传参概述 二、动态路由参数(params) 2.1 基础用法 2.2 传递参数 2.3 获取参数 2.4 可选参数 2.5 多个参数与正则约束 2.6 多 params 的详细用法 多个可选参数的使用 路由配置 获取可选参数 三、查询参数(Query&#x…

目录

一、路由传参概述

二、动态路由参数(params)

2.1 基础用法

2.2 传递参数

2.3 获取参数

2.4 可选参数

2.5 多个参数与正则约束

2.6 多 params 的详细用法

 多个可选参数的使用

 路由配置

获取可选参数

三、查询参数(Query)

3.1 特点与应用场景

3.2 传递参数

3.3 获取参数

3.4 保留当前查询参数

四、命名视图传参

五、props 解耦(推荐方式)

六、状态管理(Pinia/Vuex)

6.1 使用 Pinia 示例

七、路由元信息(meta)

八、不同传参方式对比

九、最佳实践

十、常见问题与解决方案


Vue 3 路由传参使用指南

一、路由传参概述

在 Vue 3 应用中,路由传参是实现页面间数据传递的核心功能。Vue Router 4 提供了多种传参方式,适用于不同的场景。这个指南将介绍如何在 Vue 3 中使用路由传递参数。


二、动态路由参数(params)

2.1 基础用法

动态路由参数通过在路由路径中定义 :参数名 来传递。参数将成为 URL 的一部分,适用于 SEO 或书签场景。

路由配置:

const routes = [{ path: '/user/:id', name: 'UserDetail', component: UserDetail },{ path: '/post/:id/:action?', name: 'Post', component: Post } // 可选参数
];
2.2 传递参数

通过路由链接或编程式导航传递参数。

<!-- 通过路由链接 -->
<router-link :to="{ name: 'UserDetail', params: { id: 123 } }">用户详情</router-link><!-- 通过编程式导航 -->
this.$router.push({ name: 'UserDetail', params: { id: 123 } });
2.3 获取参数

在目标组件中使用 useRoute 来获取路由参数。

<script setup>
import { useRoute } from 'vue-router';
const route = useRoute();
console.log(route.params.id); // 输出: 123
</script>
2.4 可选参数

通过在参数后添加 ? 标记,使其成为可选参数。

{ path: '/user/:id?', component: User }
2.5 多个参数与正则约束

可以使用正则表达式来约束参数格式,例如:

{ path: '/article/:id(\\d+)/:action(edit|view)', component: Article }
2.6 多 params 的详细用法

可以传递多个动态参数,并根据需求获取:

路由配置:

const routes = [{ path: '/product/:category/:id', name: 'ProductDetail', component: ProductDetail },{ path: '/order/:orderId/:status?', name: 'OrderInfo', component: OrderInfo },{ path: '/blog/:year/:month/:day/:postId', name: 'BlogArticle', component: BlogArticle }
];

参数传递:

<router-link :to="{ name: 'ProductDetail', params: { category: 'electronics', id: 456 } }">电子产品详情</router-link>

获取参数:

<script setup>
import { useRoute } from 'vue-router';
const route = useRoute();
console.log(route.params.category); // electronics
console.log(route.params.id);       // 456
</script>

结合 props 解耦:

{ path: '/product/:category/:id', name: 'Product', component: ProductComponent, props: (route) => ({ category: route.params.category, id: Number(route.params.id) }) 
}

 多个可选参数的使用

在 Vue 3 中,处理多个可选参数的情况需要在路由配置中通过适当的方式来设置。多个可选参数可以通过在路由路径中给每个参数后添加 ? 来标记为可选。多个参数之间通过斜杠 / 分隔。

 路由配置

多个可选参数通过在路径中添加 ? 来实现,例如:

const routes = [{ path: '/user/:id?/:name?', name: 'UserDetail', component: UserDetail },{ path: '/product/:category?/:id?', name: 'ProductDetail', component: ProductDetail }
];

传递可选参数

router-linkrouter.push 中传递多个可选参数:

<router-link :to="{ name: 'UserDetail', params: { id: '123' } }">用户详情</router-link>
<router-link :to="{ name: 'UserDetail', params: { id: '123', name: 'John' } }">用户详情</router-link>
获取可选参数

通过 useRoute() 获取传递的多个可选参数:

<script setup>
import { useRoute } from 'vue-router';
const route = useRoute();
const userId = route.params.id || 'defaultId';  // 提供默认值
const userName = route.params.name || 'defaultName';  // 提供默认值
console.log(userId);   // 输出: "123" 或 "defaultId"
console.log(userName); // 输出: "John" 或 "defaultName"
</script>

三、查询参数(Query)

查询参数通过 URL 的查询字符串传递,适合传递可选参数、过滤条件等。

3.1 特点与应用场景

查询参数不会影响路由匹配,适合频繁变化的参数。

3.2 传递参数

通过路由链接:

<router-link :to="{ name: 'UserList', query: { page: 2, size: 10 } }">第二页</router-link>

通过编程式导航:

this.$router.push({ name: 'UserList', query: { page: 2, size: 10 } });
3.3 获取参数
<script setup>
import { useRoute } from 'vue-router';
const route = useRoute();
console.log(route.query.page);  // 2
console.log(route.query.size);  // 10
</script>
3.4 保留当前查询参数

通过 router.push 修改部分查询参数,并保持其他参数:

const route = useRoute();
router.push({ name: 'UserList', query: { ...route.query, page: 2 } });

四、命名视图传参

在路由配置中,可以为多个视图传递不同的参数。

路由配置:

const routes = [{ path: '/user/:id', components: { default: UserProfile, sidebar: UserSidebar }, props: { default: true, sidebar: { admin: true } }}
];

组件接收参数:

<!-- UserProfile.vue -->
<script setup>
const props = defineProps({ id: String });
</script><!-- UserSidebar.vue -->
<script setup>
const props = defineProps({ admin: Boolean });
</script>

五、props 解耦(推荐方式)

使用 props 选项将路由参数解耦为组件的普通 props,提高组件的复用性。

路由配置:

const routes = [{ path: '/user/:id', name: 'User', component: UserComponent, props: true },{ path: '/search', name: 'Search', component: SearchComponent, props: (route) => ({ query: route.query.q, page: Number(route.query.page) || 1 })}
];

组件接收参数:

<script setup>
const props = defineProps({ id: String, query: String, page: Number });
</script>

六、状态管理(Pinia/Vuex)

对于复杂或跨页面的数据传递,推荐使用状态管理库。

6.1 使用 Pinia 示例

定义 Store:

// store/user.js
import { defineStore } from 'pinia';export const useUserStore = defineStore('user', {state: () => ({ userId: null, userInfo: {} }),actions: {setUserId(id) { this.userId = id; },fetchUserInfo() { return fetch(`/api/users/${this.userId}`).then(res => res.json()); }}
});

使用 Store:

<script setup>
import { useUserStore } from '@/stores/user';
import { useRouter } from 'vue-router';const router = useRouter();
const userStore = useUserStore();const goToUser = (id) => {userStore.setUserId(id);router.push({ name: 'UserDetail' });
};
</script>

七、路由元信息(meta)

路由配置中可以添加元信息(meta),例如权限控制、页面标题等。

路由配置:

const routes = [{ path: '/dashboard', name: 'Dashboard', component: Dashboard, meta: { requiresAuth: true, title: '控制面板' }}
];

获取元信息:

<script setup>
import { useRoute } from 'vue-router';
const route = useRoute();
console.log(route.meta.title); // "控制面板"
</script>

全局导航守卫中使用:

router.beforeEach((to, from) => {if (to.meta.requiresAuth && !isAuthenticated()) {return { name: 'Login' };}
});

八、不同传参方式对比

方式适用场景URL 可见类型组件解耦
动态路由参数必需参数、SEO 友好字符串
查询参数可选参数、过滤条件字符串
props组件解耦、复用自定义
状态管理复杂数据、跨页面共享任意
路由元信息静态配置、导航守卫任意

九、最佳实践

  1. 优先使用 props 解耦:将路由参数转换为组件 props,提高组件复用性。

  2. 复杂数据用状态管理:跨页面或全局数据使用 Pinia/Vuex 管理。

  3. 合理选择参数类型:路径参数用于标识资源,查询参数用于过滤、排序等。

  4. 避免过度依赖 URL 传参:对于敏感数据,考虑使用状态管理或 API 获取。

  5. 参数类型转换:路由参数默认是字符串类型,必要时手动转换。


十、常见问题与解决方案

  1. 动态路由参数变化时组件不刷新:使用 watch 监听路由变化。

  2. 刷新页面后数据丢失:使用本地存储、Cookie 或重新获取数据。

  3. 路由参数过多导致 URL 过长:考虑使用状态管理或 POST 请求。

http://www.dtcms.com/wzjs/449811.html

相关文章:

  • 为自己做的网站申请域名鹤壁seo公司
  • 怎么邀约客户做网站重庆森林经典台词梁朝伟
  • 做个人网站需要多少钱站长之家源码
  • 公司网站建设素材百度收录入口在哪里
  • 中山 网站建设 骏域陕西新闻今日头条
  • 广州易网外贸网站建设宁波seo网络推广公司排名
  • 电子商务系统的组成安卓优化大师
  • 不用域名也可以做网站有了域名怎么建网站
  • 做网站没有做退钱企业培训课程
  • 家装设计效果图专业网站西安百度竞价托管代运营
  • 安康市网站开发qq代刷网站推广免费
  • 东营网站建设哪家好百度深圳总部
  • 加强协会网站建设意义注册网站在哪里注册
  • 微信怎么推广最有效湖南seo推广软件
  • 网站开发公司的职责促销策略
  • 银川网站建设哪家好yahoo搜索引擎提交入口
  • wordpress edubasewindows优化大师是病毒吗
  • 由前台有后台的网站怎么做抖音指数查询
  • 微网站开发平台seo模拟点击工具
  • 织梦网站建设后优化步骤抖音seo是什么
  • 金融公司网站建设温州百度推广公司电话
  • 企业官网模板站seo网络运营
  • 北京市基础建设质量监督局网站效果最好的推广软件
  • 公司推广网站怎么做深圳关键词推广整站优化
  • 网站开发实习过程绍兴seo
  • x3型虚拟主机 wordpress网站应该如何进行优化
  • seo网站规划百度网盘搜索神器
  • 学院做网站的意义百度指数排行榜
  • 湖南省建设厅官方网站官网橙子建站怎么收费
  • 南川网站建设公司互联网广告营销方案