zoukankan      html  css  js  c++  java
  • 纯小白入手 vue3.0 CLI

    vue3.0 CLI 真小白一步一步入手全教程系列:https://www.cnblogs.com/ndos/category/1295752.html

    尽量把纷繁的知识,肢解重组成为可以堆砌的知识。

    学会工具并不难,思考如何运用这些工具,才是编程或者工作中最难的部分。

    我的 github 地址 - vue3.0Study - 阶段学习成果都会建立分支。

    ==========================

    动态路由

    在路由某部分里加入[ : ],就成为动态路由如:/user/:id/,那么路由导航,并不是  /user/id/ 而是 /user/666/。

    显然这个 id 能被获取,在组件中使用。通过 this.$route.params 获取。 this 是当前组件,$route 是路由对象,params 是一个对象字面量 { id:666 }。

    $route 通过 Vue.use(Router) 和 new Vue({ router, store, render: h => h(App) }).$mount('#app') 全局依赖注入,在所有组件中都可以使用它。

    1、router.js 中 path: '/about' 路由 改为 path: '/about/:id'。

    2、About.vue 中 <top-nav title="军事" :class="{ active: isActive }"/> 添加红色部分。

    3、About.vue 中 data 或者 computed 属性中添加 isActive: function () { return this.$route.params.id === "666"; }

    4、App.vue 中 <router-link to="/about/666">VUE</router-link>

    5、About.vue 中 <style lang="less"> .active { background: red; } </style>

    保存点击【VUE】导航按钮,即可见到效果:

    如何取得 $route 中参数的值,便是很大的进步。这个参数可以用在任何地方,可以用来做任何事情。

    比如传递数据,根据路由参数动态从服务器获取组件内容等

    在进行下一个内容学习之前,commit 一下。

    嵌套路由(子路由) 

    在页面,通常存在多级导航。vue 官方网站便是多级导航的例子:顶部为一级导航栏,左侧为二级导航栏。

    导航通常对应 <router-link> 而 <router-link> 与 <router-view/> 对应。

    并非只有 App.vue 中才能存在 <router-view/>, 任何组件都可以。

    下面把 HelloWorld.vue 变为 About.vue 的子路由:

    1、<HelloWorld msg="vue 官方相关资料的链接"/> 替换为  <router-view/>

    2、router.js 中关于 About.vue 组件的路由 替换为

        {
          path: '/about/:id',
          name: 'about',
          // route level code-splitting
          // this generates a separate chunk (about.[hash].js) for this route
          // which is lazy-loaded when the route is visited.
          component: () => import(/* webpackChunkName: "about" */ './views/About.vue'),
          children: [
            {
              path: '1',
              component: HelloWorld,
              props: (router) => ({
                msg: router.query.msg
              })
            }
          ]
        }

    在浏览器地址栏输入 http://localhost:8081/#/about/666/1?msg='welcome to nDos blog' 查看效果。

    编程式导航与路由命名

    在 vue 初始化的工程中,路由配置时,组件都已做好命名。这便是路由命名。

    编程式导航,尽量使用命名的路由,如下:

    router.push({ name: 'about', params: { userId: 123 }})

    因为使用 path 属性进行编程式导航,params 无效。

    这样使用路由跳转,使得单页面编程的路由跳转更加灵活。比如某个跳转按钮,可以绑定函数,进行条件跳转。

    关于这两个的内容并不多,参照官网教程学习。

    命名视图

    在一个组件中,如果有多个组件出口,比如:在某个页面,需要同时展示很多个组件时。

    只有一个 <router-view/> 显然不能满足需求。

    多个 <router-view/> 同时存在的时候,就必须要加以区分,用的是 name 属性:<router-view name="a"/>

    在 router.js 中的 components 属性中,添加多个组件即可 ( 到这里才明白为什么 components 为什么是复数形式的写法  )。

    路由参数

    在介绍动态路由的时候,已经看到路由参数的应用,这个东西也不复杂,参照官方教程学习。

    ==========================

    关于路由的初级知识到这里介绍完。

    下面会开始学习工作中常用的路由知识。

  • 相关阅读:
    Ubuntu 15.04 下apt-get安装JDK
    Ubuntu下apt-get安装Java,Tomcat
    虚拟化技术比较 PV HVM
    Java8 Lambda表达式教程
    SpringMVC实现上传和下载
    web.xml中的url-pattern映射规则
    java文件读写操作大全
    Java创建文件
    JAVA文件中获取路径及WEB应用程序获取路径方法
    session.flush()与session.clear()的区别及使用环境
  • 原文地址:https://www.cnblogs.com/ndos/p/9667310.html
Copyright © 2011-2022 走看看