如何在 Vue 3 中使用 Vue Router 和 Vuex
在 Vue 3 中使用 Vue Router
1. 安装 Vue Router
在项目根目录下,通过 npm 或 yarn 安装 Vue Router 4(适用于 Vue 3):
npm install vue-router@4
# 或者使用 yarn
yarn add vue-router@4
2. 创建路由配置文件
在 src 目录下创建一个 router 文件夹,并在其中创建 index.js 文件,用于配置路由:
// src/router/index.js
import { createRouter, createWebHistory } from 'vue-router';
import Home from '../views/Home.vue'; // 假设 Home 组件在 views 文件夹下
import About from '../views/About.vue'; // 假设 About 组件在 views 文件夹下const routes = [{path: '/',name: 'Home',component: Home},{path: '/about',name: 'About',component: About}
];const router = createRouter({history: createWebHistory(),routes
});export default router;
3. 在主应用中使用路由
在 main.js 中引入并使用路由:
// src/main.js
import { createApp } from 'vue';
import App from './App.vue';
import router from './router';const app = createApp(App);
app.use(router);
app.mount('#app');
4. 在模板中使用路由
在 App.vue 中添加路由出口和导航链接:
<template><div><!-- 导航链接 --><router-link to="/">Home</router-link><router-link to="/about">About</router-link><!-- 路由出口,用于显示当前路由对应的组件 --><router-view></router-view></div>
</template><script setup>
// 这里可以添加其他逻辑
</script><style scoped>
/* 样式 */
</style>
5. 路由导航守卫(可选)
可以使用路由导航守卫来控制路由的访问权限等,例如在 router/index.js 中添加全局前置守卫:
// src/router/index.js
import { createRouter, createWebHistory } from 'vue-router';
import Home from '../views/Home.vue';
import About from '../views/About.vue';const routes = [{path: '/',name: 'Home',component: Home},{path: '/about',name: 'About',component: About}
];const router = createRouter({history: createWebHistory(),routes
});// 全局前置守卫
router.beforeEach((to, from, next) => {// 可以在这里添加权限验证等逻辑console.log('Before each navigation');next();
});export default router;
在 Vue 3 中使用 Vuex(Vuex 4 适用于 Vue 3)
1. 安装 Vuex
在项目根目录下,通过 npm 或 yarn 安装 Vuex 4:
npm install vuex@4
# 或者使用 yarn
yarn add vuex@4
2. 创建 store
在 src 目录下创建一个 store 文件夹,并在其中创建 index.js 文件,用于创建和配置 store:
// src/store/index.js
import { createStore } from 'vuex';const store = createStore({state() {return {count: 0};},mutations: {increment(state) {state.count++;},decrement(state) {state.count--;}},actions: {incrementAsync(context) {setTimeout(() => {context.commit('increment');}, 1000);}},getters: {doubleCount(state) {return state.count * 2;}}
});export default store;
3. 在主应用中使用 store
在 main.js 中引入并使用 store:
// src/main.js
import { createApp } from 'vue';
import App from './App.vue';
import router from './router';
import store from './store';const app = createApp(App);
app.use(router);
app.use(store);
app.mount('#app');
4. 在组件中使用 store
在组件中可以通过不同方式使用 store 中的状态、mutations、actions 和 getters:
<template><div><p>Count: {{ count }}</p><p>Double Count: {{ doubleCount }}</p><button @click="increment">Increment</button><button @click="decrement">Decrement</button><button @click="incrementAsync">Increment Async</button></div>
</template><script setup>
import { useStore } from 'vuex';const store = useStore();const count = store.state.count;
const doubleCount = store.getters.doubleCount;const increment = () => {store.commit('increment');
};const decrement = () => {store.commit('decrement');
};const incrementAsync = () => {store.dispatch('incrementAsync');
};
</script><style scoped>
/* 样式 */
</style>
通过以上步骤,你就可以在 Vue 3 项目中成功使用 Vue Router 和 Vuex 了。在实际开发中,你可以根据项目需求进一步扩展和优化路由配置和 store 逻辑。
相关文章:
如何在 Vue 3 中使用 Vue Router 和 Vuex
在 Vue 3 中使用 Vue Router 1. 安装 Vue Router 在项目根目录下,通过 npm 或 yarn 安装 Vue Router 4(适用于 Vue 3): npm install vue-router4 # 或者使用 yarn yarn add vue-router42. 创建路由配置文件 在 src 目录下创建…...
Fiori APP配置中的Semantic object 小bug
在配置自开发程序的Fiori Tile时,需要填入Semantic Object。正常来说,是需要通过事务代码/N/UI2/SEMOBJ来提前新建的。 但是在S4 2022中,似乎存在一个bug,即无需新建也能输入自定义的Semantic Object。 如下,当我们任…...
【触想智能】工业显示器和普通显示器的区别以及工业显示器的主要应用领域分析
在现代工业中,工业显示器被广泛应用于各种场景,从监控系统到生产控制,它们在实时数据显示、操作界面和信息传递方面发挥着重要作用。与普通显示器相比,工业显示器在耐用性、可靠性和适应特殊环境的能力上有着显著的差异。 触想工业…...
BPMN.js 与 DeepSeek 集成:打造个性化 Web 培训项目的秘诀
在数字化时代,Web培训项目的需求日益增长,特别是对于程序员群体,他们寻求高效、灵活的方式来提升自己的技能。本文将深入探讨如何评估BPMN.js与DeepSeek集成方案,以满足开发Web培训项目的需求。 BPMN.js 的优势 BPMN.js是一个专…...
第二月:学习 NumPy、Pandas 和 Matplotlib 是数据分析和科学计算的基础
以下是一个为期 **1 个月(30 天)**的详细学习计划,精确到每天的学习内容和练习作业,帮助你系统地掌握 NumPy、Pandas 和 Matplotlib 的核心功能。 第 1 周:NumPy 基础 Day 1:NumPy 简介与数组创建 学习内…...
安全测试|SSRF请求伪造
前言 SSRF漏洞是一种在未能获取服务器权限时,利用服务器漏洞,由攻击者构造请求,服务器端发起请求的安全漏洞,攻击者可以利用该漏洞诱使服务器端应用程序向攻击者选择的任意域发出HTTP请求。 很多Web应用都提供了从其他的服务器上…...
Flink提交pyflink任务
1.官方文档: flink1.14:https://nightlies.apache.org/flink/flink-docs-release-1.14/docs/deployment/cli/#submitting-pyflink-jobs flink1.18:https://nightlies.apache.org/flink/flink-docs-release-1.18/docs/deployment/cli/#submitting-pyflink-jobs 2.提…...
对称算法模式之CTR
Note 计数器模式,通过加密递增计数器生成密钥流,后密钥流与明文分组异或得密文分组可并行性进行加密或者解密,性能较高明文可以是任意长度,不需要填充可以直接加密或解密指定块,块与块间不具有依赖关系 参数说明 任…...
Map 和 Set
目录 一、搜索 概念: 模型: 二、Map 编辑 1.Map 实例化: 2. Map的常见方法: 3.Map的常见方法演示: 1. put(K key, V value):添加键值对 3. containsKey(Object key):检查键是否存在 4.…...
STOMP协议
引用:https://blog.csdn.net/print_helloword/article/details/142597122 什么是STOMP协议 STOMP (simple text oriented messaging protocol): 一种简单的,基于文本的消息传输协议,,,最初是为了解决在消息队列中&am…...
手动埋点的demo
上代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>埋点示例</title> </head><b…...
大模型开发实战篇5:多模态--文生图模型API
大模型文生图是一种基于人工智能大模型的技术,能够将自然语言文本描述转化为对应的图像。目前非常火的AI大模型赛道,有很多公司在此赛道竞争。详情可看这篇文章。 今天我们来看下如何调用WebAPI来实现文生图功能。我们一般都会将OpenAI的接口࿰…...
【大模型】DeepSeek 高级提示词技巧使用详解
目录 一、前言 二、DeepSeek 通用提示词技巧 2.1 DeepSeek 通用提示词技巧总结 三、DeepSeek 进阶使用技巧 3.1 DeepSeek一个特定角色的人设 3.1.1 为DeepSeek设置角色操作案例一 3.1.2 为DeepSeek设置角色操作案例二 3.2 DeepSeek开放人设升级 3.2.1 特殊的人设&#…...
【第14章:神经符号集成与可解释AI—14.2 可解释AI技术:LIME、SHAP等的实现与应用案例】
在这里插入图片描述 凌晨三点的ICU病房,值班医生李主任盯着AI辅助诊断系统的红色警报——这套准确率高达95%的深度学习系统,突然建议对一位肾衰竭患者进行肝移植手术。正当医疗组陷入混乱时,李主任打开了系统的"解释模式",屏幕上立即跳出SHAP分析图:模型误将CT…...
Python中使用Minio实现图像或视频文件的存储
目录 一、Minio的基本介绍1.Minio是什么2.Minio的优势 二、使用步骤1.启动Minio2.创建桶3.在Python中使用Minio3.1安装并导入minio包3.2创建mino_utils工具类 三、操作演示1.引入minio_utils工具类2.上传视频文件3.获取视频文件 总结 一、Minio的基本介绍 1.Minio是什么 Mini…...
Kubernetes-master 组件
以下是Kubernetes Master Machine的组件。 etcd 它存储集群中每个节点可以使用的配置信息。它是一个高可用性键值存储,可以在多个节点之间分布。只有Kubernetes API服务器可以访问它,因为它可能具有一些敏感信息。这是一个分布式键值存储,所…...
人形机器人 - 仿生机器人核心技术与大小脑
以下是针对仿生机器人核心技术的结构化总结,涵盖通用核心技术与**“大脑-小脑”专用架构**两大方向: 一、机器人通用核心技术 这些技术是仿生机器人实现功能的基础,与生物体的“身体能力”对应: 1. 感知与交互技术 多模态传感器融合 视觉:3D视觉(如RGB-D相机)、动态目…...
OpenAI 快速入门
文章来源:OpenAI开发者平台 | OpenAI开发文档|OpenAI中文官方文档|ChatGPT中文版|ChatGPT教程 开发人员快速入门 了解如何发出您的第一个 API 请求。 OpenAI API 为最先进的 AI 模型提供了一个简单的接口,用于自然语言处理、图像生成、语义搜索和语音识…...
nginx 实战配置
一、配置一个默认80端口的,静态页面,路径是path1。 http://192.168.0.111/path1 , /path1路径指向linux的/data/index1.html vi /data/nginx-1.24.0/conf/nginx.conf 文件添加以下配置 location /path1 { alias /data/…...
WebMvcConfigurer 介绍
WebMvcConfigurer 介绍 1. 什么是WebMvcConfigurer 介绍2. WebMvcConfigurer接口常用的方法3. 使用WebMvcConfigurer实现跨域4. 使用WebMvcConfigurer配置拦截器5. 使用WebMvcConfigurer配置静态资源5.1 配置外部目录(本地文件系统)详细解释 6. 使用 Web…...
SAP ABAP实战:用BAPI_PR_CHANGE批量更新采购申请,别再一条条改了
SAP ABAP高效开发:BAPI_PR_CHANGE批量处理采购申请的工程化实践 采购申请(Purchase Requisition)作为企业采购流程的起点,其数据维护效率直接影响采购部门的运作效能。当面对数百甚至上千条需要同步更新文本、状态或关键字段的采购…...
5分钟掌握:AI换脸神器roop-unleashed完全实战指南
5分钟掌握:AI换脸神器roop-unleashed完全实战指南 【免费下载链接】roop-unleashed Evolved Fork of roop with Web Server and lots of additions 项目地址: https://gitcode.com/gh_mirrors/ro/roop-unleashed 你是否曾经梦想过,只需一张照片就…...
Cockpit Tools:一站式管理多平台AI编程助手账号与配额
1. 项目概述:一个AI开发者的“驾驶舱”如果你和我一样,日常开发重度依赖 GitHub Copilot、Cursor、Antigravity 这些 AI 编程助手,那你肯定也遇到过类似的烦恼:手头有好几个账号,有的是个人订阅,有的是团队…...
计算机视觉怎么选:2026年技术选型生存指南——在学术界与工业界的撕裂地带,找到你的生态位
一、开篇:一个被低估的结构性事实 如果你站在2026年的时间节点上问"计算机视觉怎么选",你真正在问的是:在一场每年膨胀近200亿美元、但人才供给严重错配的技术革命中,我应该把有限的时间押注在哪里? 这不是…...
Spring Boot项目里,除了velocity-engine-core,你还需要Velocity-Tools吗?一个工具包的选择指南
Spring Boot项目中Velocity工具包的深度选型指南:何时需要Velocity-Tools? 在Java生态中,模板引擎的选择往往让开发者陷入"功能过剩"与"能力不足"的两难境地。Velocity作为老牌模板引擎,其轻量级设计哲学至今…...
EBERLE S-41/051413016000印刷电路板
EBERLE S-41/051413016000 通常属于其工业自动化系统中的印刷电路板(PCB)组件 根据此类专用电路板的通用特性,推测其特点如下:定制化设计:推测是针对特定控制任务(如信号转换、电源管理或接口扩展ÿ…...
分布式代理池终极指南:如何将 haipproxy 与 Scrapy 完美集成
分布式代理池终极指南:如何将 haipproxy 与 Scrapy 完美集成 【免费下载链接】haipproxy :sparkling_heart: High available distributed ip proxy pool, powerd by Scrapy and Redis 项目地址: https://gitcode.com/gh_mirrors/ha/haipproxy haipproxy 是一…...
PEG/COOH-BPQDs功能化黑磷量子点的差异分析
中英文名称: PEG-BPQDs,PEG修饰黑磷量子点 COOH-BPQDs,羧基功能化黑磷量子点 一、PEG-BPQDs,PEG修饰黑磷量子点 PEG-BPQDs是指在黑磷量子点(Black Phosphorus Quantum Dots,BPQDs)表面引入聚乙二…...
保姆级教程:基于RK3588S的8K视频播放器实战(从硬件选型到FFmpeg编译)
基于RK3588S的8K视频播放器全栈开发指南 当8K分辨率逐渐从概念走向消费级市场,如何利用高性能硬件构建流畅的播放体验成为开发者面临的新挑战。RK3588S作为Rockchip旗舰级处理器,凭借其8K60fps的视频解码能力和丰富的多媒体接口,为嵌入式视频…...
告别重复劳动!用Python的PyAutoGUI库打造你的专属自动化脚本(附完整代码)
用Python解放双手:PyAutoGUI实战指南 每天重复点击相同的按钮、填写相同的表格、执行相同的操作——这些机械性工作正在吞噬你的时间和创造力。作为一名Python开发者,你完全可以用PyAutoGUI这个神奇的库把这些枯燥任务交给计算机自动完成。本文将带你从零…...
