本人写前端Vue 一年多了 。说来遗憾 ,接手的Vue项目居然没有用到路由跳转。特殊的项目需求(奇葩)打开项目不管页面怎么跳转 url不变 。老总决定。以此为前提。我的前台大哥,考虑了许久 (可以做但是会有很大的局限性)。就是组件的注册和销毁来实现。(类似于div插入标签)
一年后的今天。老总想实现跳到当前某个项目的页面。走不回来了,所以又要改回 路由跳转。长时间的不使用接触 ,对路由跳转遗忘的很厉害。
router/index.js 配置
import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import ind from '@/components/ind'
import home from '../components/home'
import basic from '../components/basic'
Vue.use(Router)
export default new Router({
routes: [
{
path: '/',
name: 'HelloWorld',
component: HelloWorld,
},
{
path: '/ind',
name: 'ind',
component: ind,
children: [{
path: '/ind/home',
name: 'home',
component: home
},{
path: '/ind/basic',
name: 'basic',
component: basic
}]
}
],
})
ind.vue
声明式:<router-link :to="...">
编程式:router.push(...)
长时间使用组件 突然不需要再当前也面引用 import 组件还有点不适应
标签 功能上 相当于a标签
<template>
<div>
自定义模板
<div style='backgroundColor : red;' @click='handFn'>返回</div>
<router-link :to="{name:'home',query:{kkk:'5555'}}">home页</router-link>
<router-link :to="{name:'basic',params:{kkk:'666'}}">basic页</router-link>
<router-view></router-view>
</div>
</template>
<script>
export default{
name:'ind',
methods:{
handFn (){
this.$router.push("/")
}
}
}
</script>
<style>
</style>