VueRouter-命名视图
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>66-VueRouter-命名视图</title> <style> *{ margin: 0; padding: 0; } .onepage, .twopage{ width: 200px; height: 200px; } .onepage{ background: pink; } .twopage{ background: skyblue; } .nj-active{ background: skyblue; } </style> <script src="js/vue.js"></script> <!--1.导入Vue Router--> <script src="js/vue-router.js"></script> </head> <body> <!-- 1.什么是命名视图? 命名视图和前面讲解的具名插槽很像, 都是让不同的出口显示不同的内容 命名视图就是当路由地址被匹配的时候同时指定多个出口, 并且每个出口中显示的内容不同 --> <!--这里就是MVVM中的View--> <div id="app"> <!-- 路由出口 --> <!-- 路由匹配到的组件将渲染在这里 --> <!--和匿名插槽一样, 如果指定了多个router-view, 那么当路由地址被匹配之后, 多个router-view中显示的内容是一样的--> <!--<router-view></router-view> <router-view></router-view>--> <!--和具名插槽一样, 如果想同时显示多个不同的组件, 那么可以给出口指定名称 1.在路由规则中给组件起名称 2.在出口中指定显示哪个名称的组件--> <router-view name="name1"></router-view> <router-view name="name2"></router-view> </div> <template id="one"> <div> <p>我是第一个界面</p> </div> </template> <template id="two"> <div> <p>我是第二个界面</p> </div> </template> <script> // 1.定义组件 const one = { template: "#one", }; const two = { template: "#two" }; // 2.定义切换的规则(定义路由规则) const routes = [ // 数组中的每一个对象就是一条规则 { path: '/', components: { name1: one, name2: two } }, ]; // 3.根据自定义的切换规则创建路由对象 const router = new VueRouter({ routes: routes, linkActiveClass: "nj-active" }); // 这里就是MVVM中的View Model let vue = new Vue({ el: '#app', // 4.将创建好的路由对象绑定到Vue实例上 router: router, // 这里就是MVVM中的Model data: { }, // 专门用于存储监听事件回调函数 methods: { }, // 专门用于定义计算属性的 computed: { }, // 专门用于定义局部组件的 components: { one: one, two: two } }); // console.log(vue.$route); </script> </body> </html>
<< 上一篇
下一篇 >>