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

网络网站建设百度seo是啥

网络网站建设,百度seo是啥,最新的网站建设软件有哪些,浙江疫情最新消息风险等级预期效果:(借助iview-ui的在线体验页面示意一下) 项目中只有一部分页面需要缓存,且存在多级路由的页面。每打开一个菜单,就会新增一个 Tab标签,只要 Tab标签不关闭,对应的页面就会被缓存&#x…

预期效果:(借助iview-ui的在线体验页面示意一下)

  1. 项目中只有一部分页面需要缓存,且存在多级路由的页面。
  2. 每打开一个菜单,就会新增一个 Tab标签,只要 Tab标签不关闭,对应的页面就会被缓存,Tab标签关闭时,页面才会被销毁。

在这里插入图片描述

以下是我自己琢磨出来的方案,可能有所欠缺,多多包涵,可以先翻到最后先大致了解一下相关逻辑。

代码实现

1. router.js

import Vue from 'vue'
import VueRouter from 'vue-router'
import store from '@/store'Vue.use(VueRouter)const routes = [{path: '/',redirect: '/login'},{path: '/login',name: 'Login',component: () => import('xxx/Login')},{path: '/myProfix', // 自定义的顶层路由前缀component: () => import('xxx/Main'),name: 'Main',redirect: { name: 'Home' },children: [{path: 'home',name: 'Home',component: () => import('xxx/Home'),meta: { keepAlive: true } // 需要缓存的页面路由在 meta中添加 keepAlive属性},{path: 'about',name: 'About',component: () => import('xxx/About')},// 多级路由{path: 'father',name: 'Father',component: () => import('xxx/Father'),redirect: { name: 'Son0' },children: [{path: 'son0',name: 'Son0',component: () => import('xxx/Son0'),meta: { keepAlive: true }},{path: 'son1',name: 'Son1',component: () => import('xxx/Son1')},]}]}
]const router = new VueRouter({base: process.env.BASE_URL,routes
})router.beforeEach((to, from, next) => {// 当前路由如支持缓存,将当前路由对应的页面组件名添加到 store中if (to.meta?.keepAlive) {// 支持多级路由,多级路由存顶级父级路由的组件名(这个顶级父路由是指顶层路由 /myProfix的下一级,示例中的路由 /myProfix下只有2 层,实际可以有 2层以上)store.dispatch('updateKeepAliveRouteComponents', { operation: 'add', value: to.matched[1]?.name || to.name })}next()
})export default router

2. store.js

import Vue from 'vue'
import Vuex from 'vuex'Vue.use(Vuex)export default new Vuex.Store({state: {keepAliveRouteComponents: [] // 需要缓存的路由对应的组件名称(此处组件名称与路由名称设置成一样,方便关闭 Tab标签时做匹配处理)},actions: {// 更新 keepAliveRouteComponentsupdateKeepAliveRouteComponents: ({ commit }, data) => {commit('UPDATE_KEEP_ALIVE_ROUTE_COMPONENTS', data)}},mutations: {// 关闭 Tab标签CLOSE_TAB (state, payload) {// ...此处省略关闭 Tab标签的逻辑// 删除 keepAliveRouteComponents中对应的组件名,以清除对应路由组件的缓存const curRouteName = ... // 根据实际情况获取到关闭 Tab标签对应的页面路由的 namethis.commit('UPDATE_KEEP_ALIVE_ROUTE_COMPONENTS', { operation: 'delete', value: curRouteName })},// 更新 keepAliveRouteComponentsUPDATE_KEEP_ALIVE_ROUTE_COMPONENTS (state, data) {const { operation, value } = dataif (operation === 'add' && !state.keepAliveRouteComponents.includes(value)) {state.keepAliveRouteComponents.push(value)}if (operation === 'delete') {const valueIndex = state.keepAliveRouteComponents.indexOf(value)if (valueIndex !== -1) {state.keepAliveRouteComponents.splice(valueIndex, 1)}}},// 退出登录LOGOUT (state) {// ...// 清空 keepAliveRouteComponents,清除所有缓存的页面组件——其实也可以不清空,因为退出到 Login页面时, Main组件会被销毁state.keepAliveRouteComponents = []},}
})

3. App.vue

<template><div id="app"><router-view /></div>
</template>

4. Main.vue

<template><div class="main"><Navigation /><div class="main-view">// include属性与 store记录的 keepAliveRouteComponents绑定<keep-alive :include="keepAliveRouteComponents"><router-view /></keep-alive></div></div>
</template><script>
import { mapState } from 'vuex'
import Navigation from '@system/components/Navigation'export default {components: {Navigation},computed: {...mapState(['keepAliveRouteComponents']),}
}
</script>

5. Home.vue

<template><div class="home"></div>
</template><script>
export default {name: 'Home'  // 组件名称与路由名称设置成一样
}
</script>

6. Father.vue

<template><div class="father"><keep-alive :include="['Son0']"><router-view /></keep-alive></div>
</template><script>
export default {name: 'Father' // 组件名称与路由名称设置成一样
}
</script>

7. Son0.vue

<template><div class="son0"></div>
</template><script>
export default {name: 'Son0' // 组件名称与路由名称设置成一样
}
</script>

逻辑总结

  1. 需要缓存的页面路由添加meta属性{ keepAlive: true }
  2. 页面路由对应的组件名称与路由名称设置成一样,方便 Tab标签关闭时做匹配(这一步不是必须的,可以换成别的方法,只要 Tab标签关闭时,能有相关数据识别到对应的页面的组件名称即可)
  3. store中保存需要缓存的页面组件的名称列表keepAliveRouteComponents
  4. <Main>组件中 组件的include属性与keepAliveRouteComponents绑定
  5. 路由全局前置守卫中判断即将进入的路由keepAlive属性为true时,在keepAliveRouteComponents列表中加入当前路由的name,如果是多级路由即加入当前路由的顶级父级路由(/myProfix的下一级)的name(——可以统一通过$route.matched[1]来获取需要的name,为什么取matched[1],因为当前还有一层顶级的路由/myProfixmatched[0](此处记录路由的name,是基于将页面路由对应的组件名称与路由名称设置成一样的前提条件下)
  6. Tab标签关闭时,删除keepAliveRouteComponents中对应的组件名,以清除对应路由组件的缓存
  7. 多级路由的情况,内部子路由<router-view />包裹<keep-alive>,并根据具体子路由是否缓存添加include属性(——如果这个多级路由只有一个子路由,也可以不设置)
  8. 系统登出时,清空keepAliveRouteComponents(——其实清不清空无所谓,因为跳转到login页面时,整个<Main>组件都会被销毁)
http://www.ds6.com.cn/news/69544.html

相关文章:

  • 日本男女直接做的视频网站福州网站排名提升
  • 佛山网站建设设计公司天津百度网站快速优化
  • 正日商务做网站多少钱网络商城应该如何推广
  • 眉山北京网站建设互联网营销师证书是国家认可的吗
  • 网站设计实例百度搜索引擎推广
  • 研发网站要多久爱用建站
  • 帮人做网站推选的公司网站关键词排名优化客服
  • 上海专业做网站推广的公司做推广哪个平台效果好
  • 政府网站模板贴吧网站搜索引擎优化诊断
  • 淮安谁家做网站阜平网站seo
  • 如何自己开网站软文外链代发
  • 河南有名的做网站公司有哪些宜兴百度推广公司
  • 南昌市网站建设推广今日新闻消息
  • 北京如何做网站网页广告设计与制作需要学什么
  • 建筑网站首页大图阿里云域名注册流程
  • 重庆网站制作企业怎么网上推广自己的产品
  • 网站空间在那里买广告营销案例分析
  • 化妆品 营销型网站网站功能
  • 电子商务网站建设与管理期末考试题真正永久免费的建站系统有哪些
  • 新网站怎么做才能让搜狗收录西安seo优化工作室
  • 做网站编程语言2022年传销最新消息
  • 自己做的网站打开空白营销策划方案怎么做
  • 程序员帮忙做放贷网站来宾seo
  • 深圳手机网站制作公司排名慧达seo免登录发布
  • mstsc做网站百度网站是什么
  • wordpress占用id长沙靠谱关键词优化公司电话
  • html5 动态效果 手机网站爱站网工具
  • 开做网站的公司 条件网络运营推广合作
  • 网站开发棋牌查关键词排名工具app
  • 网站登录接口怎么做个人网站源码免费下载