zoukankan      html  css  js  c++  java
  • Vue自定义指令和路由

    一、自定义指令

      除了默认设置的核心指令( v-model 和 v-show ), Vue 也允许注册自定义指令。

      下面我们注册一个全局指令 v-focus,该指令的功能是在页面加载时,元素获得焦点:

    <div id="app">
        <p>页面载入时,input 元素自动获取焦点:</p>
        <input v-focus>
    </div>
     
    <script>
    // 注册一个全局自定义指令 v-focus
    Vue.directive('focus', {
      // 当绑定元素插入到 DOM 中。
      inserted: function (el) {
        // 聚焦元素
        el.focus()
      }
    })
    // 创建根实例
    new Vue({
      el: '#app'
    })
    </script>

      用 directives 选项来注册局部指令,这样指令只能在这个实例中使用

    <div id="app">
      <p>页面载入时,input 元素自动获取焦点:</p>
      <input v-focus>
    </div>
     
    <script>
    // 创建根实例
    new Vue({
      el: '#app',
      directives: {
        // 注册一个局部的自定义指令 v-focus
        focus: {
          // 指令的定义
          inserted: function (el) {
            // 聚焦元素
            el.focus()
          }
        }
      }
    })
    </script>

    二、钩子

    1、钩子函数

      指令定义函数提供了几个钩子函数(可选):

      (1)bind: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作。

      (2)inserted: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。

      (3)update: 被绑定元素所在的模板更新时调用,而不论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新。

      (4)componentUpdated:被绑定元素所在模板完成一次更新周期时调用。

      (5)unbind:只调用一次, 指令与元素解绑时调用。

    2、钩子函数参数

      钩子函数的参数有:

      el: 指令所绑定的元素,可以用来直接操作 DOM 。

      binding: 一个对象,包含以下属性:

        name: 指令名,不包括 v- 前缀。

        value: 指令的绑定值, 例如: v-my-directive="1 + 1", value 的值是 2。

        oldValue: 指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。

        expression: 绑定值的字符串形式。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"

        arg: 传给指令的参数。例如 v-my-directive:foo, arg 的值是 "foo"

        modifiers: 一个包含修饰符的对象。 例如: v-my-directive.foo.bar, 修饰符对象 modifiers 的值是 { foo: true, bar: true }

        vnode: Vue 编译生成的虚拟节点。

        oldVnode: 上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。

      以下实例演示了这些参数的使用:

    <div id="app"  v-runoob:hello.a.b="message">
    </div>
     
    <script>
    Vue.directive('runoob', {
      bind: function (el, binding, vnode) {
        var s = JSON.stringify
        el.innerHTML =
          'name: '       + s(binding.name) + '<br>' +         //runoob
          'value: '      + s(binding.value) + '<br>' +        //测试
          'expression: ' + s(binding.expression) + '<br>' +   //message
          'argument: '   + s(binding.arg) + '<br>' +          //hello
          'modifiers: '  + s(binding.modifiers) + '<br>' +    //{a:true,b:true}
          'vnode keys: ' + Object.keys(vnode).join(', ')
      }
    })
    new Vue({
      el: '#app',
      data: {
        message: '测试'
      }
    })
    </script>

      有时候我们不需要其他钩子函数,我们可以简写函数,如下格式:

    Vue.directive('runoob', function (el, binding) {
      // 设置指令的背景颜色
      el.style.backgroundColor = binding.value.color
    })

      指令函数可接受所有合法的 JavaScript 表达式,以下实例传入了 JavaScript 对象:

    <div id="app">
        <div v-runoob="{ color: 'green', text: '测试' }"></div>
    </div>
    
    <script>
    Vue.directive('runoob', function (el, binding) {
        // 简写方式设置文本及背景颜色
        el.innerHTML = binding.value.text
        el.style.backgroundColor = binding.value.color
    })
    new Vue({
      el: '#app'
    })
    </script>

    三、路由

      Vue.js 路由允许我们通过不同的 URL 访问不同的内容。通过 Vue.js 可以实现多视图的单页Web应用(single page web application,SPA)。

      Vue.js 路由需要载入 vue-router 库

      中文文档地址:vue-router文档

    1、安装

    //直接下载 / CDN
    https://unpkg.com/vue-router/dist/vue-router.js
    
    //NPM
    //推荐使用淘宝镜像:
    cnpm install vue-router

    2、简单实例

      Vue.js + vue-router 可以很简单的实现单页应用。以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。代码如下所示:

    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
     
    <div id="app">
      <h1>Hello App!</h1>
      <p>
        <!-- 使用 router-link 组件来导航. -->
        <!-- 通过传入 `to` 属性指定链接. -->
        <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
        <router-link to="/foo">Go to Foo</router-link>
        <router-link to="/bar">Go to Bar</router-link>
      </p>
      <!-- 路由出口 -->
      <!-- 路由匹配到的组件将渲染在这里 -->
      <router-view></router-view>
    </div>
    <script>
    // 0. 如果使用模块化机制编程,导入Vue和VueRouter,要调用 Vue.use(VueRouter)
    
    // 1. 定义(路由)组件。 可以从其他文件 import 进来
    const Foo = { template: '<div>foo</div>' }
    const Bar = { template: '<div>bar</div>' }
    
    // 2. 定义路由:每个路由应该映射一个组件。 其中"component" 可以是通过 Vue.extend() 创建的组件构造器,
    或者,只是一个组件配置对象。
    const routes = [ { path: '/foo', component: Foo }, { path: '/bar', component: Bar } ] // 3. 创建 router 实例,然后传 `routes` 配置,你还可以传别的配置参数, 不过先这么简单着吧。 const router = new VueRouter({ routes // (缩写)相当于 routes: routes }) // 4. 创建和挂载根实例。记得要通过 router 配置参数注入路由,从而让整个应用都有路由功能 const app = new Vue({ router }).$mount('#app') // 现在,应用已经启动了! </script>
  • 相关阅读:
    智能视频分析
    基于libuv的TCP设计(三)
    视频质量诊断----画面抖动检测
    视频质量诊断----画面冻结检测
    视频质量诊断----PTZ云台运动检测
    视频质量诊断----模糊检测
    视频质量诊断----信号丢失检测
    视频质量诊断----遮挡检测
    视频质量诊断----条纹噪声检测
    视频质量诊断----雪花噪声检测
  • 原文地址:https://www.cnblogs.com/goloving/p/8519757.html
Copyright © 2011-2022 走看看