🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
需求是这样的,在一个页面里我们有2个以上`<router-view>`区域,我们通过配置路由的js文件,来操作这些区域的内容。例如我们在`src/App.vue`里加上两个`<router-view>`标签。我们用vue-cli建立了新的项目,并打开了src目录下的App.vue文件,在`<router-view>`下面新写了两行`<router-view>`标签,并加入了些CSS样式。 ~~~ <router-view ></router-view> <router-view name="left" style="float:left;width:50%;background-color:#ccc;height:300px;"></router-view> <router-view name="right" style="float:right;width:50%;background-color:#c0c;height:300px;"></router-view> ~~~ 现在的页面中有了三个<router-view>标签,也就是说我们需要在路由里配置这三个区域,配置主要是在components字段里进行 ~~~ import Vue from 'vue' import Router from 'vue-router' import Hello from '@/components/Hello' import Hi1 from '@/components/Hi1' import Hi2 from '@/components/Hi2' Vue.use(Router) export default new Router({ routes: [ { path: '/', components: { default:Hello, left:Hi1, right:Hi2 } },{ path: '/Hi', components: { default:Hello, left:Hi2, right:Hi1 } } ] }) ~~~ 上边的代码我们编写了两个路径,一个是默认的‘/’,另一个是’/Hi’.在两个路径下的components里面,我们对三个区域都定义了显示内容。 定义好后,我们需要在component文件夹下,新建Hi1.vue和Hi2.vue页面就可以了。 Hi1.vue ~~~ <template> <div> <h2>{{ msg }}</h2> </div> </template> <script> export default { name: 'hi1', data () { return { msg: 'I am Hi1 page.' } } } </script> ~~~ Hi2.vue ~~~ <template> <div> <h2>{{ msg }}</h2> </div> </template> <script> export default { name: 'hi2', data () { return { msg: 'I am Hi2 page.' } } } </script> ~~~