Skip to content

Latest commit

 

History

History
163 lines (106 loc) · 4.3 KB

README.md

File metadata and controls

163 lines (106 loc) · 4.3 KB

Vue vue-router webpack gulp 学习


1.安装

npm install

2.跟着文档学吧

文档地址

路由替换区域:

<router-view></router-view>

子路由:

    router.map({
        '/index':{
        component:Index,
        subRoutes:{
            '/':{
                component:{
                    template:'<p>这是默认的嵌套子路由</p>'
                    }
                }
            }
        }
    })

3.路由对象

路由对象暴露了以下几个属性:

  1. $route.path,字符串,当前路由对象的路径,如:"/foo/bar"
  2. $route.params,对象,包含路由中动态片段和全匹配片段的键值对
  3. $route.query,对象,包含路由中查询参数的键值对,例:/foo?user=1会得到$route.query.user=1
  4. $route.router,路由规则所属的路由器及其所属的组件
  5. $route.matched,数组:包含当前匹配路径中所包含的所有片段所对应的配置参数对象
  6. $route.name,当前路径的名字

另外在路由设置对象中自定义的其他字段也会最终拷贝到路由对象上

可以直接在组件的模板中使用$route,如

    <div>
        <p>当前路径: {{$route.path}}</p>
        <p>当前路由参数: {{$route.params | json}}</p>
    </div>

路由匹配,我理解是restful

    route.map({
        '/user/:username':{
            component:{
                template:"<p>用户名是{{$route.params.username}}</p>"
            }
        }
    })

具名路径

给一条路径加上一个名字能够让我们更方便地进行路径的跳转

4.路由选项

hashbang

默认值true,会以#!开头

history

默认false,true情况下利用H5的利用 history.pushState()history.replaceState() 来管理浏览历史记录

abstract

默认 false,利用一个不依赖于浏览器的浏览历史虚拟管理后端,虚拟模式在测试或者实际的url并不重要的时候,非常有用,如Electron 或者 Cordova 应用。在非浏览器模式下,路由器同样会退化为抽象模式。

root

默认null,只在H5 history模式下可用

linkActiveClass

默认值:v-link-active 配置当v-link元素匹配的路径时候需要添加到元素上的class

saveScrollPosition

默认值:false 只在h5 history模式下可用,当用户点击后退按钮的时候,借助H5 history中的popstate事件对应的state来重置页面的滚动位置.

transitionOnLoad

默认值:false 初次加载时候是否对<route-view></route-view>处理场景切换效果.

suppressTransitionError

默认值:false,在切换钩子函数中发生异常不吞掉

5.<router-view>

用于渲染匹配的组件,可以传递props,v-transitiontransition-mode完整支持,v-ref支持,被渲染的对象会注册到父级组件的this.$对象上. 但是不支持wait-for,需要使用切换钩子函数 active控制切换的时机.

6.v-link

用来让用户在不同路径之间跳转的指令,接受一个表达式,并在点击该元素时去调用router.go.

  • replace,触发router.replace(),不会留下历史记录
  • append,'/a'点击跳转'/a/b'
  • v-link会自动<a>的href属性,并且可以包含mustache标签

7.切换钩子函数

transition

transition.from

//一个代表当前路径的路由对象。

transition.to

//一个代表将要切换到的路径的路由对象。

transition.next()

//调用此函数处理切换过程的下一步。

transition.abort([reason])

//调用此函数来终止或者拒绝此次切换。

transition.redirect(path)

//取消当前切换并重定向到另一个路由。
  1. data 参数 transition,activate被断定resolve,可以传递参数

  2. activivate resolve->transition(next) reject(reason)->transition.abort(reason)

  3. deactivate resolve->transition(next) reject(reason)->transition.abort(reason)

  4. canActivate

    可选择性返回 Promise :

    • resolve(true) -> transition.next()
    • resolve(false) -> transition.abort()
    • reject(reason) -> transition.abort(reason)

    可选择性返回 Boolean 值:

    • true -> transition.next()
    • false -> transition.abort()
  5. canDeactivate

    同上

  6. canReuse 返回布尔类型,默认true