0

0

vue3实现单页面多标签页

WBOY

WBOY

发布时间:2023-05-24 12:39:07

|

2353人浏览过

|

来源于php中文网

原创

在现在的互联网时代,用户的使用习惯不断变化着。与此同时,技术也在不断更新。在前端技术领域中,vue.js作为目前最为流行的前端框架之一,其三版本vue3于2020年9月份正式发布。vue3相比于vue2的更新迭代,功能和性能都得到了大幅的提升,其中最为值得一提的就是其支持多标签页。本文就来探究一下vue3实现单页面多标签页功能的实践过程。

一、前置知识

在深入介绍Vue3实现多标签页功能之前,需要对Vue3的几个基本概念有所了解:

1.路由(route)

路由是前端中非常重要的一个概念,它负责管理着浏览器的URL和页面之间的关系。在Vue中,我们可以通过Vue Router来实现路由的跳转。

2.组件(Component)

Vue3是以组件化开发为基础的框架,将一个大的应用程序拆分成一个一个的组件,每个组件都可以重复使用,提高了代码的复用率和维护性。

3.状态管理(State Management)

状态管理指的是将应用程序中的状态集中存储、管理和协调。在Vue中,我们使用Vuex来实现状态管理。

立即学习前端免费学习笔记(深入)”;

二、实现过程

下面将介绍如何使用Vue3和Vue Router来实现单页面多标签页的功能。具体实现可分为以下步骤:

1.安装Vue Router

Vue Router是Vue.js官方的路由管理库,可以方便地实现单页面应用程序的路由跳转和管理。通过npm安装Vue Router:

npm install vue-router --save

2.配置路由

在Vue3中,配置路由相比Vue2有所变化。我们需要在createApp方法中配置路由:

//导入Vue Router 
import { createRouter, createWebHashHistory } from 'vue-router' 

//创建路由 
const router = createRouter({   history: createWebHashHistory(),   routes: routes }) 

//创建Vue App 
const app = createApp(App) 

//挂载路由 
app.use(router).mount('#app') 

其中,createWebHashHistory()是指定使用哈希值来实现路由跳转,routes是路由的配置项。我们在routes中定义每个标签页的路由,如下所示:

Shoping购物网源码
Shoping购物网源码

该系统采用多层模式开发,这个网站主要展示女装的经营,更易于网站的扩展和后期的维护,同时也根据常用的SQL注入手段做出相应的防御以提高网站的安全性,本网站实现了购物车,产品订单管理,产品展示,等等,后台实现了动态权限的管理,客户管理,订单管理以及商品管理等等,前台页面设计精致,后台便于操作等。实现了无限子类的添加,实现了动态权限的管理,支持一下一个人做的辛苦

下载
const routes = [   { path: '/', component: Home, name: 'home', meta: { title: '主页' } },   { path: '/about', component: About, name: 'about', meta: { title: '关于' } },   { path: '/contact', component: Contact, name: 'contact', meta: { title: '联系我们' } } ] 

在这里路由中,我们定义了三个标签页,分别是主页(home)、关于(about)和联系我们(contact)。

3.创建标签页组件

接下来,我们需要创建标签页组件。在Vue3中,组件的定义相比Vue2有所变化。我们需要使用defineComponent方法来定义组件:

import { defineComponent } from 'vue' 

export default defineComponent({   name: 'Home',   setup() {       return {}   },   render() {       return (           
这是主页
) } })

结合上文路由中定义的标签页,我们可以在render函数中渲染出对应的组件。

4.增加标签页

下面,我们需要为应用程序增加标签页功能。我们可以使用一个数组来存储打开的标签页,每个数组元素表示一个标签页的信息:

tabs: [    { title: '主页', name: 'home', path: '/', isCurrent: true },    { title: '关于', name: 'about', path: '/about', isCurrent: false },    { title: '联系我们', name: 'contact', path: '/contact', isCurrent: false } ]

其中,title表示标签页的标题,name表示标签页的名称,path表示标签页对应的路由路径,isCurrent表示当前标签页是否被选中。

接下来,我们需要实现标签页的打开功能。当点击菜单中的某个选项时,我们需要先判断对应的路由是否已经存在于标签页数组中。如果已经存在,就将当前标签页设为选中状态,否则就新增一个标签页:

//打开标签页 
openTab(tab) {  
   let routerName = this.$router.currentRoute.value.name   
   let t = this.tabs.find(x => x.name === tab.name)  
   if (!t) {       //不存在,新增标签页        
        this.tabs.push({ name: tab.name, title: tab.meta.title, path: tab.path, isCurrent: true })      
   } else {       //已存在,设为当前标签页      
        this.tabs.forEach(x => x.isCurrent = false)      
        t.isCurrent = true      
        this.$router.push(t.path)  
   }  
} 

5.关闭标签页

最后,我们还需要实现标签页的关闭功能。当点击标签页上的关闭按钮时,我们需要将该标签页从数组中删除,同时将当前标签页设为上一个标签页:

//关闭标签页 
closeTab(tab) {      
   let i = this.tabs.findIndex(x => x.name === tab.name)      
   this.tabs.splice(i, 1)      

   let currentTab = this.tabs.find(x => x.isCurrent === true)      
   if (currentTab) {          
      this.$router.push(currentTab.path)      
   }  else {          
      this.$router.push('/')      
   }  
}

三、总结

通过本文的介绍,我们了解了Vue3实现单页面多标签页功能的基本思路和具体实现过程。Vue3相比Vue2在使用上有所变化,需要根据实际需求做出相应的调整,但其支持多标签页的优点仍然不言而喻。对于那些需要在Web应用程序中实现多页面功能的开发者来说,Vue3的出现为我们提供了一种良好的解决方案。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
vue.js为什么报错
vue.js为什么报错

vue.js报错的原因:1、语法错误;2、组件使用不当;3、数据绑定问题;4、生命周期钩子使用不当;5、插件或依赖问题;6、路由配置错误;7、异步操作处理不当等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

120

2024.03.11

vue.js插槽有哪些用
vue.js插槽有哪些用

vue.js插槽的作用:1、提高组件的可重用性;2、实现组件的灵活布局;3、实现组件间的数据传递和交互;4、促进组件的解耦和模块化。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.03.11

vue.js怎么带参数跳转
vue.js怎么带参数跳转

vue.js带参数跳转的方法:1、定义路由;2、在组件中使用路由参数;3、进行带参数的跳转。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

90

2024.03.11

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

510

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5279

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号