vue-router3基本使用

vuex基本使用

vue2 对应的 vuex、vue-router 都为3.

项目创建与框架安装如下

vue create hellorouter3

npm install vue-router@3

npm i vuex@3

npm install

npm run serve

请添加图片描述

处理新建About组件报错

根路径下创建.eslintrc.js文件,其内容如下:

module.exports = {'parser': '@babel/eslint-parser',  //支持ES6语法rules: {"*": "off"},
};

/vue.config.js 添加 lintOnSave:false

const {defineConfig} = require('@vue/cli-service')
module.exports = defineConfig({transpileDependencies: true,lintOnSave: false,
})

vue-router基本使用

  1. 新建About组件其路径为:src/pages/About.vue
<template><div></div>
</template><script>
export default {name: "About"
}
</script><style scoped></style>
  1. 将HelloWorld.vue 移动到 src/pages 路径下

  2. 注册vuerouter框架并进行路由的集中配置管理

    新建 src/router/index.js ,其内容如下:

import Vue from 'vue'
import VueRouter from "vue-router"
import HelloWorld from "@/pages/HelloWorld";
import About from "@/pages/About";Vue.use(VueRouter)
const routes = [{path: "/",component: HelloWorld},{path: '/about',component: About}
]
const router = new VueRouter({routes,mode: 'hash'
})
export default router;
  1. 修改main.js 注册路由,将路由与当前vue实例进行绑定
import Vue from 'vue'
import App from './App.vue'Vue.config.productionTip = false
import router from './router'new Vue({router,render: h => h(App),
}).$mount('#app')
  1. App.vue 添加路由跳转连接和组件容器
<template><div id="app"><router-link to="/">Home</router-link>|<router-link to="/about">About</router-link><router-view/></div>
</template>

请添加图片描述

动态路由

更近一步,可以进行路由传参

params传递数据

  1. 修改router/index.js文件, About组件声明通过路径id进行动态传递数据; About组件通过props参数接收数据。
import Vue from 'vue'
import VueRouter from "vue-router"
import HelloWorld from "@/pages/HelloWorld";
import About from "@/pages/About";Vue.use(VueRouter)
const routes = [{path: "/",component: HelloWorld},{path: '/about/:id', //声明允许通过路径拼接的方式,传递id eg. to="/about/123"component: About,props: true,  //允许About组件通过声明props的方式接收数据,否则需要使用this.$route.params.id进行id属性的接收name: 'about'}
]
const router = new VueRouter({routes,mode: 'hash',base: '/'// 当你将应用部署到一个子目录时,需要设置 base 参数以确保路由链接和资源路径正确解析。
})
export default router;
  1. 调整About组件,接收并展示id
<template><div>{{ id }}</div>
</template><script>
export default {name: "About",props: ['id'],
}
</script><style scoped></style>
  1. 调整调用处App.vue 传递id
<template><div id="app"><router-link to="/">Home</router-link>|<router-link :to="{name: 'about', params: {id: 456}}">About</router-link>|<router-link to="/about/123">About</router-link><!--    <HelloWorld msg="Welcome to Your Vue.js App"/>--><router-view/></div>
</template>

请添加图片描述

编程传递数据

通过js代码,进行动态数据传递

  1. 调整App.vue 调用this.$router.push进行页面跳转
<template><div id="app"><router-link to="/">Home</router-link>|<router-link :to="{name: 'about', params: {id: 456,name:'gggg'}}">About</router-link>||<button @click="showAbout2">About</button><router-view/></div>
</template><script>
// import HelloWorld from './components/HelloWorld.vue'export default {name: 'App',components: {// HelloWorld},methods: {showAbout2() {this.$router.push({name: 'about2', query: {id: 122222, name: 'goood'}})}}
}
</script>
  1. 修改router/index.js, 定义About2组件路由配置
import Vue from 'vue'
import VueRouter from "vue-router"
import HelloWorld from "@/pages/HelloWorld";
import About from "@/pages/About";
import About2 from "@/pages/About2";Vue.use(VueRouter)
const routes = [{path: "/",component: HelloWorld},{path: '/about',component: About,// props: true,name: 'about'},{path: '/about2',component: About2,// props: true,name: 'about2'}
]
const router = new VueRouter({routes,mode: 'hash',base: '/'// 当你将应用部署到一个子目录时,需要设置 base 参数以确保路由链接和资源路径正确解析。
})
export default router;
  1. 通过this.$route接收参数
<template><div>{{ id }} --- {{ name }}</div>
</template><script>
export default {name: "About2",data() {return {id: this.$route.query.id,name: this.$route.query.name}}
}
</script><style scoped></style>

路由拦截

全局范围添加路由拦截

  1. router/index.js 添加路由拦截
router.beforeEach((to, from, next) => {console.error('to:' + to.fullPath)  //"fullPath":"/"console.error('from:' + from.fullPath) //"fullPath":"/"if (to.meta.requireAuth) {//模拟权限验证(需要手动向浏览器localstorage添加数据)if (localStorage.getItem('token')) {next()} else {next({path: '/'})}} else {next()}
})
  1. 路由配置添加需要验证flag(meta.requireAuth)
    {path: '/about',component: About,// props: true,name: 'about',meta: {requireAuth: true  //}},

组件范围内添加

<template><div>{{ id }} --- {{ name }}</div>
</template><script>
export default {name: "About",// props: ['id', 'name'],data() {return {id: this.$route.params.id,name: this.$route.params.name}},beforeRouteEnter(to, from, next) {// 在进入路由之前调用// console.log('Before Route Enter', to, from);if (localStorage.getItem('token')) {next();} else {next('/')}},watch: {}
}
</script><style scoped></style>

嵌套路由.

这个东西多用于再次分类的页面

请添加图片描述参考地址

其实现方式与一级路由基本一致

  1. 定义简单组件
<template><div>{{ id }}</div>
</template><script>
export default {name: "AboutId",props: ['id'],
}
</script><style scoped></style>

同理创建AboutName组件
2. router/index.js 进行组件注册,这里要放入children下

    {path: '/about',component: About,// props: true,name: 'about',children: [{path: '/id',component: AboutId,name: 'aboutId',props: true,},{path: '/name',component: AboutName,name: 'aboutName',props: true,}]},
  1. About组件内部放入路由容器和路由跳转关系
<template><div><button @click="toID">toID</button>|<button @click="toName">toName</button><router-view/></div></template><script>
export default {name: "About",// props: ['id', 'name'],data() {return {id: this.$route.params.id,name: this.$route.params.name}},methods: {toID() {this.$router.push({name: 'aboutId', params: {id: 333333}})},toName() {this.$router.push({name: 'aboutName', params: {name: 'good'}})}},watch: {}
}
</script><style scoped></style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/455604.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

程序员:数字时代的先锋

随着科技的不断进步&#xff0c;程序员这一职业群体逐渐成为社会中不可或缺的一部分。他们以智慧和汗水为世界带来更多的便捷与创新。今天&#xff0c;我们将庆祝1024程序员节&#xff0c;这是一个向全球程序员们表达敬意和感激的节日。让我们一同走进程序员的内心世界&#xf…

Unity 实现音频(mp3)可控制进度条

目录 前言 一、拼UI 二、上代码 前言 效果如图&#xff1a;&#xff08;因为是GIF格式&#xff0c;录不上音频&#xff09; 一、拼UI 1.新建空物体添加AudioSource&#xff0c;给AudioSource添加音频文件&#xff0c;取消勾选PlayOnAwake&#xff0c;勾选上Loop 2.创建Slid…

VMware虚拟机中centos磁盘扩容(非VG分区挂载方案)

目录 1、虚拟机磁盘扩容2、查看磁盘分区3、编辑磁盘分区4、调整文件系统大小 搭建dify的时候发现虚拟机的磁盘空间不够了&#xff1b;搜索了很多教程都是用的vg分区去扩展的&#xff1b;没有part类型直接扩容的教程&#xff1b;然后自己摸索了下&#xff1b;特此记录分享 1、虚…

docker-compose-lnmp-wordpress

使用 docker-compose 在 CentOS 7 上编写并部署 LNMP (Linux, Nginx, MySQL, PHP) 环境的 YAML 文章目录 部署步骤&#xff1a;1. 安装 Docker 和 Docker Compose1.1安装 Docker&#xff1a;1.2安装 Docker Compose&#xff1a; 2.创建目录结构3.编写docker-compose.yml4.ngin…

K8S调度不平衡问题分析过程和解决方案

不平衡问题排查 问题描述&#xff1a; 1、业务部署大量pod(据反馈&#xff0c;基本为任务型进程)过程中&#xff0c;k8s node内存使用率表现不均衡&#xff0c;范围从80%到百分之几&#xff1b; 2、单个node内存使用率超过95%&#xff0c;仍未发生pod驱逐&#xff0c;存在node…

LabVIEW提高开发效率技巧----离线调试

离线调试是LabVIEW开发中一项重要的技巧&#xff0c;通过使用Simulate Signal Express VI生成虚拟数据&#xff0c;开发者能够有效减少对实际硬件的依赖&#xff0c;加速开发过程。这种方法不仅可以提高开发效率&#xff0c;还能降低成本&#xff0c;增强系统的灵活性。 ​ 离…

不同企业规模,外贸财务系统如何灵活应对

ZohoBooks外贸财务系统适用于不同规模企业。小型企业注重成本和易用性&#xff0c;中型企业追求性价比&#xff0c;大型企业看重全面性、数据安全和集成性。企业选择时需考虑实际需求和成本&#xff0c;建议先试用再决定。 一、小型外贸企业 小型外贸企业通常业务规模相对较小…

使用Airtest自动化某云音乐爬取歌曲名称

简介 本文将介绍如何使用Airtest自动化工具来模拟用户操作&#xff0c;从某云音乐中爬取与特定关键词相关的歌曲名称。我们将以搜索“文字”相关的歌曲为例&#xff0c;并将结果保存到本地文件。 准备工作 安装Airtest并配置好Android设备或模拟器。确保你的设备上已安装某云…

项目管理新趋势!2024年,Jira与禅道你更倾向谁?

一、 项目管理软件新趋势概述 2024 年&#xff0c;项目管理软件呈现出诸多新趋势&#xff0c;这些趋势对于项目管理的重要性日益凸显。 在数字化转型方面&#xff0c;项目管理软件成为企业实现数字化转型的关键工具。越来越多的企业认识到&#xff0c;通过项目管理软件可以实…

【T+】畅捷通T+软件更新补丁提示当前系统中没有安装T+产品

【问题描述】 在更新畅捷通T软件补丁的时候&#xff0c; 提示&#xff1a;当前系统中没有安装T产品。但是本机电脑上还能正常打开软件操作使用。 【解决方法】 首先查看控制面板程序中没有T产品&#xff0c;即下图没有T产品信息。 原因是因为控制面板注册表中没有T产品信息。…

机器学习-树结构2-随机森林

上一篇的链接&#xff1a; 机器学习 - 树结构1 - 随机森林-CSDN博客 随机森林的改进方向1&#xff1a; 现有的随机森林中不同决策树中特征的选取是随机的&#xff0c;即先用哪个特征对样本进行分类&#xff0c;再用哪个特征对样本进行分类&#xff0c;特征的选取是随机的&…

[Python学习日记-54] 软件开发目录设计规范

[Python学习日记-54] 软件开发目录设计规范 简介 为什么要设计好目录结构&#xff1f; 目录组织方式 关于 README 的内容 关于 setup.py 和 requirements.txt 关于配置文件的使用方法 简介 我们在浏览一些开源项目或者是一些安装后的软件的时候会发现&#xff0c;不同的两…

解决:IntelliJ IDEA 项目中代码文件不能运行的问题(即:J 标文件的问题)

1、问题描述&#xff1a; 其一、需求为&#xff1a; 想要通过 IntelliJ IDEA 软件打开原 Eclipse 项目文件或新 Java 项目&#xff0c;能正常运行 .java 文件中的代码; 其二、问题描述为&#xff1a; A、通过 IntelliJ IDEA 打开 java 项目&#xff0c;并在打开具体的 .jav…

记nvm管理node

前言 解决来回切换node版本适应不同项目 一、nvm是什么&#xff1f; nvm是用于管理多个 nodejs 的版本控制工具 二、使用步骤 1.卸载nodeJs 若是本地原先有nodeJs版本的话需要先卸载&#xff0c;若是没有则跳过这一步&#xff0c;可以通过命令行来确定是否存在node node…

【C++11】右值引用和移动语义

1 右值引用和移动语义 C98的C语法中就有引用的语法&#xff0c;而C11中新增了的右值引用语法特性&#xff0c;C11之后我们之前学习的引用就叫做左值引用。无论左值引用还是右值引用&#xff0c;都是给对象取别名。 1.1 左值和右值 左值是⼀个表示数据的表达式(如变量名或解引用…

HbuilderX 连接 Genymotion 模拟器

最近在琢磨 uni-app 开发 app 应用&#xff0c;并且想要基于模拟器调试&#xff1b;但模拟器安装好以后&#xff0c;Hbuilder 始终识别不了&#xff08;识别成功了也运行不了代码&#xff09; 模拟器&#xff1a;Genymotion &#xff1b;这款模拟器用于开发调试是比较流畅的。当…

如何禁止上班期间浏览无关网站?

禁止员工在上班期间浏览无关网页主要是为了提升工作效率和生产力&#xff0c;确保员工能够专注于工作任务。同时&#xff0c;这种做法有助于降低网络安全风险&#xff0c;防止恶意软件和钓鱼攻击&#xff0c;减少数据泄露和法律风险&#xff0c;维护公司的专业形象&#xff0c;…

【系统配置】命令行修改统信UOS的grub启动延时

往期好文&#xff1a;【命令操作】Linux中多种关机和重启的命令介绍 | 统信 | 麒麟 | 方德 Hello&#xff0c;大家好啊&#xff01;今天给大家带来一篇关于如何通过命令行配置统信UOS系统的启动延时的文章。在某些场景中&#xff0c;调整系统的启动延时可以帮助用户在系统启动过…

实践OpenVINO™ GenAI

前言 随着 ChatGPT 等聊天机器人的风暴席卷全球&#xff0c;生成式预训练 Transformers &#xff08;GPT&#xff09; 在开发者中正在成为家喻户晓的新名字。生成式 AI&#xff08;GenAI&#xff09; 的发展&#xff0c;尤其是大语言模型和聊天机器人的进步很快、变化不断&…

短剧AI突围战,百度跑偏了

“ 百度短剧的Agent对话功能并不属于颠覆性创新&#xff0c;只是新插件&#xff0c;对短剧行业市场格局影响不大&#xff0c;最多只能算用户痒点。 ” 转载&#xff1a;科技新知 原创 作者丨晓伊 编辑丨蕨影 你是否有过这样的体验&#xff1f; 刷短剧时&#xff0c;因剧情曲…