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

Vue 路由设置

为了防止遗忘,记录一下用Vue写前端配置路由时的过程,方便后续再需要用到时回忆。

一、举个例子

假如需要实现这样的界面逻辑:

        在HomePage中有一组选项卡按钮用于导航到子页面,而子页面Page1中有一个按钮,其响应事件是跳转到到一个全新的页面(不属于HomePage)。

二、实现过程

        按照例子中的需求,HomePage和Page3都是占满整个窗口的页面,也就是说它们应该是同级的,所以直接在App.vue放置一个<RouterView />作为HomePage和Page3的路由出口,代码如下:

// App.vue<script setup>
import { RouterView } from 'vue-router'
</script><template><RouterView />
</template>

        接下来在src目录下创建一个叫pages的文件夹,专门用来存放界面模板:

        在pages文件夹下新建HomePage,放置了两个按钮,分别用于触发链接到子页面1和子页面2:

<script>import { useRouter } from 'vue-router';export default {setup() {const router = useRouter();const handleButton1 = () => {router.push("/page1");};const handleButton2 = () => {router.push("/page2");};return {handleButton1, handleButton2};},};</script><template><header><h1>标题</h1></header><div><span><button @click="handleButton1">button1</button><button @click="handleButton2">button2</button></span></div><hr><RouterView />
</template><style scoped></style>

        在pages文件夹下新建Page1。不同于HomePage,此处使用了window.open函数来跳转到新页面,参数“_blank”可以帮助我们以新链接打开界面:

<script>export default {setup() {const handleButton = () => {window.open("/Page3", "_blank");};return {handleButton};},};</script><template><header><h2>Page1</h2></header><div><button @click="handleButton">button</button></div><hr><RouterView />
</template><style scoped></style>

        在pages文件夹下新建Page2:

<script setup></script><template><header><h2>Page2</h2></header><RouterView />
</template><style scoped></style>

        在pages文件夹下新建Page3: 

<script setup>
</script><template><header><h2>Page3</h2></header><RouterView />
</template><style scoped></style>

        完成以上操作后,我们已经创建了四个界面模板,接下来在main.js中导入这四个界面模板,并配置它们的路由关系:

// main.jsimport { createApp } from 'vue'
import App from './App.vue'
import {createRouter, createWebHistory} from 'vue-router'
import HomePage from './pages/HomePage.vue'
import Page1 from './pages/Page1.vue'
import Page2 from './pages/Page2.vue'
import Page3 from './pages/Page3.vue'// 创建路由器
const router = createRouter({history: createWebHistory(),routes: [{path: "/", name: 'home', component: HomePage, redirect: "/Page1", // redirect表示默认路由到/Page1children: [{path: "Page1",name: '1',component: Page1,},{path: "Page2", name: '2', component: Page2,},]},{path: '/Page3', name: '3', component: Page3,}]
})const app = createApp(App)
app.use(router)
app.mount('#app')

        按照上面的配置,我们把Page1和Page2设置为了HomePage的子路由,这样的话Page1和Page2只会在HomePage.vue下的<RouterView />路由出口显示。

        而因为我们把Page3设置成了和HomePage是同一等级的路由,所以Page3会在App.vue下的<RouterView />路由出口显示,从而达到了让Page3占满整个窗口显示的需求。

三、运行效果

        点击button1和button2可以分别链接到HomePage下的子页面Page1和Page2:

         点击Page1中的button可以跳转到占满整个窗口的Page3:

http://www.lryc.cn/news/455013.html

相关文章:

  • 力扣110:判断二叉树是否为平衡二叉树
  • Chromium 中JavaScript Fetch API接口c++代码实现(一)
  • ARM(5)内存管理单元MMU
  • 文件上传漏洞原理
  • Web安全 - 安全防御工具和体系构建
  • 服务器数据恢复—raid磁盘故障导致数据库文件损坏的数据恢复案例
  • requests 中data=xxx、json=xxx、params=xxx 分别什么时候用
  • 毕设 大数据抖音短视频数据分析与可视化(源码)
  • 【SQL】深入理解SQL:从基础概念到常用命令
  • 一文看懂计算机中的大小端(Endianess)
  • 如何给父母安排体检?
  • C++之模版进阶篇
  • Vue3 中的 `replace` 属性:优化路由导航的利器
  • vite学习教程06、vite.config.js配置
  • 【大数据】Flink CDC 实时同步mysql数据
  • JavaEE: 深入解析HTTP协议的奥秘(1)
  • OpenStack Yoga版安装笔记(十六)Openstack网络理解
  • PEFT库和transformers库在NLP大模型中的使用和常用方法详解
  • 静止坐标系和旋转坐标系变换的线性化,锁相环线性化通用推导
  • AI学习指南深度学习篇-学习率衰减的变体及扩展应用
  • 成都睿明智科技有限公司真实可靠吗?
  • 力扣6~10题
  • IntelliJ IDEA 2024.2 新特性概览
  • C++基础(12)——初识list
  • 系统架构设计师论文《论NoSQL数据库技术及其应用》精选试读
  • 产品经理产出的原型设计 - 需求文档应该怎么制作?
  • phenylalanine ammonia-lyase苯丙氨酸解氨酶PAL功能验证-文献精读61
  • 柯桥生活口语学习之在化妆品店可以用到的韩语句子
  • Ubuntu 安装 Docker Compose
  • C++面试速通宝典——7