zoukankan      html  css  js  c++  java
  • Vue 构造选项

    Directive指令:减少DOM操作的重复

    • Vue实例/组件用于数据绑定、事件监听、DOM更新
    • Vue指令主要目的就是原生DOM操作
    • 减少重复

    自定义指令

    两种声明方式

    方法一:声明一个全局指令
    Vue.directive('x', directiveOptions)
    

    方法二:声明一个局部指令

    在options里写,只能被那个Vue实例/组件使用

    new Vue({
        ...,
        directives:{
            "x":directiveOptions
        }
    })
    

    关于directiveOptions

    directiveOptions是个对象,里面有五个函数属性

    1. bind(el, info, vnode, oldVnode)★
    • 类似created,只调用一次,指令第一次绑定到元素时调用。
    • 参数都是vue给我们的
      el:绑定指令的那个元素
      info:是个对象,我们想要的信息基本都在里面
      vnode:虚拟节点
      oldVnode:之前的虚拟节点
    1. inserted(参数同上)★
    • 类似mounted,被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。
    1. update(参数同上)
    • 类似 updated
    1. componentUpdated(参数同上)
    • 用得不多,见文档
    1. unbind(参数同上)★
    • 类似destroyed,当元素要消亡时调用。

    bind示例

    Mixins混入:复制

    Mixins示例

    • 减少重复
    • directives的作用是减少DOM操作的重复
    • mixins的作用是减少data、methods、钩子的重复
    • options里的构造选项都可以先放到一个js文件,之后哪个实例/组件需要就导入并且用mixins使用就行。

    写在了共同东西里的东西被组件引用了之后,组件还可以覆盖他们,Vue会智能合并

    全局的mixins:不推荐

    Extends 继承、扩展

    • extends是比mixins更抽象一点的封装
    • 如果你嫌写五次mixins麻烦,可以考虑extends一次
    • 不过实际工作中用得很少
    • 你可以使用Vue.extend或options.extends

    provide & inject:提供&注入

    • 祖先提供东西,后代注入东西
    • 作用是大范围、隔N代共享信息(data、methods等)

    示例

    总结

    directive指令

    • 全局用Vue.directive('x', {...})
    • 局部用options.directives
    • 作用是减少DOM操作相关重复代码

    mixins混入

    • 全局用Vue.mixin({..})
    • 局部用options.mixins: [mixin1, mixin2]
    • 作用是减少options里的重复

    extends继承/扩展

    • 全局用Vue.extend({.})
    • 局部用options.extends: {...}
    • 作用跟mixins差不多,只是形式不同

    provide | inject提供和注入

    • 祖先提供东西,后代注入东西
    • 作用是大范围、隔N代共享信息

    作者:过程是风景
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
  • 相关阅读:
    使用NodeJS模块-第三方提供的模块(什么是npm)
    nodejs编写后台
    解决npm下载慢的问题
    全局安装与本地安装
    NPM常用命令
    使用NodeJS模块-NodeJS官方提供的核心模块
    导出模块成员
    Node.js提供了哪些内容(API)
    node.js的安装
    什么是node.js
  • 原文地址:https://www.cnblogs.com/justcho/p/13472939.html
Copyright © 2011-2022 走看看