如何在 Vue.js 中使用 History 路由实现根据路径展示不同内容和保持公共部分不变?
如何在 javascript 中实现 history 路由
需求:根据访问路径的不同,呈现不同的 html 内容,同时保持公共部分不变。
解决方案:
可以使用 vue-router 来实现:
- 引入 jquery、vue 和 vue-router 库。
- 定义路由配置,指定路由路径和对应的子页面模板。
- 创建 vue-router 实例,并配置历史模式。
- 在 beforeeach 钩子函数中,通过 load 方法加载对应的子页面模板。
示例代码:
<!-- 主页 --> <div> 我是公共部分 <button id="menuA">切换到 A</button> <button id="menuB">切换到 B</button> </div> <div id="route-view"></div> <script> // 路由配置 const routes = [ { name: 'PageA', path: '/a', meta: { template: '/subpages/page-a.html', }, }, { name: 'PageB', path: '/b', meta: { template: '/subpages/page-b.html', }, }, ]; // 创建 Vue-Router 实例 const router = new VueRouter({ mode: 'history', routes }); // 在 beforeEach 钩子函数中加载子页面模板 router.beforeEach((to, from, next) => { $('#route-view').empty(); $('#route-view').load(to.meta.template); next(true); }); // 挂载到全局 window.$router = router; </script><script> // 按钮点击事件,跳转路由 $('#menuA').on('click', () => $router.push({ name: 'PageA' })); $('#menuB').on('click', () => $router.push({ name: 'PageB' })); </script>
效果:
访问不同的路由路径,即可看到不同的子页面内容,同时公共部分保持不变。
以上就是如何在 Vue.js 中使用 History 路由实现根据路径展示不同内容和保持公共部分不变?的详细内容,更多请关注其它相关文章!