• 响应式:数据改变时会触发其他联动。例如:模板中的数据绑定;计算属性的重新计算;

————————————————————————————————————————————————————

vm.$parent

  • $parent 属性可以用来从一个子组件访问父组件的实例

vm.$root

  • 在每个 new Vue 实例的子组件中,其根实例可以通过 $root 属性进行访问。子组件通过this.$root访问根组件及包含的data等。
  • 如果当前实例没有父实例,此实例将会是其自己。

vm.$children

  • 当前实例的直接子组件。需要注意 $children 并不保证顺序,也不是响应式的。如果你发现自己正在尝试使用 $children 来进行数据绑定,考虑使用一个数组配合 v-for 来生成子组件,并且使用 Array 作为真正的来源。
  • 只包含组件,包括传入插槽的组件。不包括dom元素

vm.$refs

  • $refs 只会在组件渲染完成之后生效,并且它们不是响应式的。你应该避免在模板或计算属性中访问 $refs。
  • refs引用,在v-for循环中返回的是组件数组,即使只有一个匹配的ref名,依然返回数组
  • ref有多个相同名时,返回最后一个对象(需验证)

vm.$slots

  • 用来访问被插槽分发的内容(用来获取插入插槽的组件或元素)。每个具名插槽 有其相应的属性 (例如:slot="foo" 中的内容将会在 vm.$slots.foo 中被找到)。default 属性包括了所有没有被包含在具名插槽中的节点(数组)

vm.$scopedSlots

  • 用来访问作用域插槽(用来获取插入作用域插槽的组件或元素,返回的是生成这个组件或元素的函数)。对于包括 默认 slot 在内的每一个插槽,该对象都包含一个返回相应 VNode 的函数。
props: ['message'],
render: function (createElement) {// `<div><slot :text="message"></slot></div>`return createElement('div', [this.$scopedSlots.default({ // default作用域插槽也可以具名text: this.message})])
}

————————————————————————————————————————————————————

全局Vue.directive / 局部directives

  • 有的情况下,你仍然需要对普通 DOM 元素进行底层操作,这时候就会用到自定义指令。
  • update、componentUpdated是指指令绑定的当前组件发生改变,例如:在组件my-vue引用时绑定指令,该组件内部发生变化是不会触发事件的。
  • 一个指令定义对象可以提供如下几个钩子函数 (均为可选):
    • bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置。
    • inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。
    • update:所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新。(更新是指绑定的数据更新而不是指界面渲染变化)
    • componentUpdated:指令所在组件的 VNode 及其子 VNode 全部更新后调用。(更新是指绑定的数据更新而不是指界面渲染变化)
    • unbind:只调用一次,指令与元素解绑时调用。
  • 钩子函数的参数 (即 el、binding、vnode 和 oldVnode)
    • el:指令所绑定的元素,可以用来直接操作 DOM 。除了 el 之外,其它参数都应该是只读的,切勿进行修改。如果需要在钩子之间共享数据,建议通过元素的 dataset(元素自定义特性,以data-开头) 来进行。
    • binding:一个对象,包含以下属性:
      • name:指令名,不包括 v- 前缀。
      • value:指令的绑定值,例如:v-my-directive="1 + 1" 中,绑定值为 2。(绑定vue实例下的数据)
      • oldValue:指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。
      • expression:字符串形式的指令表达式。例如 v-my-directive="1 + 1" 中,表达式为 "1 + 1"。
      • arg:传给指令的参数,可选。例如 v-my-directive:foo 中,参数为 "foo"。(传入固定值)
      • modifiers:一个包含修饰符的对象。例如:v-my-directive.foo.bar 中,修饰符对象为 { foo: true, bar: true }。
    • vnode:Vue 编译生成的虚拟节点。(vnode并不是vue实例,而是vue实例中渲染函数render执行后生成的结果)
    • oldVnode:上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。
Vue.directive('demo', {bind: function (el, binding, vnode) {var s = JSON.stringifyel.innerHTML ='name: '       + s(binding.name) + '<br>' +'value: '      + s(binding.value) + '<br>' +'expression: ' + s(binding.expression) + '<br>' +'argument: '   + s(binding.arg) + '<br>' +'modifiers: '  + s(binding.modifiers) + '<br>' +'vnode keys: ' + Object.keys(vnode).join(', ')}
})
  • 在很多时候,你可能想在 bind 和 update 时触发相同行为,而不关心其它的钩子。
Vue.directive('color-swatch', function (el, binding) {el.style.backgroundColor = binding.value
})

转载于:https://www.cnblogs.com/qq3279338858/p/10283954.html

操作 实例 / dom相关推荐

  1. java jdom进行xml的增删改差_java使用DOM对XML文档进行增删改查操作实例代码

    本文研究的主要是java使用DOM对XML文档进行增删改查操作的相关代码,具体实例如下所示. 源代码: package com.zc.homeWork18; import java.io.File; ...

  2. Quill编辑器操作实例详解

    今天分享下"Quill编辑器操作实例详解"这篇文章,文中根据实例编码详细介绍,或许对大家的编程之路有着一定的参考空间与使用价值,需要的朋友接下来跟着云南仟龙Mark一起学习一下吧. ...

  3. .ne中的控制器循环出来的数据如何显示在视图上_Web程序设计-ASP.NET MVC4数据库操作实例...

    ASP.NET MVC4数据库操作实例 之前文章介绍了MVC4与Pure框架结合进行的网页设计过程中如何定义控制器.方法.模型.视图等.并使用实例进行了简单说明.本文将在此基础上进一步说明如何使用MV ...

  4. python数值运算实例_Python矩阵常见运算操作实例总结

    本文实例讲述了Python矩阵常见运算操作.分享给大家供大家参考,具体如下: python的numpy库提供矩阵运算的功能,因此我们在需要矩阵运算的时候,需要导入numpy的包. 一.numpy的导入 ...

  5. html自定义datajs,科技常识:HTML5的自定义属性data-*详细介绍和JS操作实例

    今天小编跟大家讲解下有关HTML5的自定义属性data-*详细介绍和JS操作实例 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关HTML5的自定义属性data-*详细介绍和JS操作实例 的 ...

  6. CentOS 配置防火墙操作实例(启、停、开、闭端口)

          CentOS 配置防火墙操作实例(启.停.开.闭端口):   注:防火墙的基本操作命令: 查询防火墙状态: [root@localhost ~]# service   iptables s ...

  7. c 获取当前时间插入oracle数据库,Oracle如何获取系统当前时间等操作实例,c++获取系统时间...

    Oracle如何获取系统当前时间等操作实例,c++获取系统时间 获取系统当前时间 date类型的 select sysdate from dual; char类型的 select to_char(sy ...

  8. php扇形分布图,PHP制作3D扇形统计图以及对图片进行缩放操作实例

    这篇文章主要介绍了PHP制作3D扇形统计图以及对图片进行缩放操作实例,需要的朋友可以参考下 1.利用php gd库的函数绘制3D扇形统计图 header("content-type" ...

  9. legend3---lavarel多对多模型操作实例

    legend3---lavarel多对多模型操作实例 一.总结 一句话总结: 在多对多模型中,增加关系表的数据 需要 弄一个和关系表一对多的模型关系 1.在lavarel关系模型中,课程和标签表是多对 ...

最新文章

  1. 龙格-库塔法(runge-kutta)matlab代码及含义,龙格-库塔法(Runge-Kutta)matlab代码及含义...
  2. 上机实践 1 初识 Java
  3. 简单枚举(算法竞赛入门经典)
  4. Keras之DNN::基于Keras(sigmoid+binary_crossentropy+predict_classes)利用DNN实现二分类——DIY二分类数据集预测新数据点
  5. 【PP】生产发货仓位决定
  6. [家里蹲大学数学杂志]第045期布朗运动矩的计算
  7. Java中的责任链模式
  8. java bufferarray_Java中的ByteBuffer array()方法
  9. php 高德地图计算距离,距离、长度、面积
  10. 数据结构与算法--图的表示与常用算法
  11. PHP将mysql数据导出为Excel
  12. 后端用的nodejs怎么打包_你怎么也想象不到,平板玻璃、玻璃瓶这些竟可以用PET塑钢带打包!...
  13. 名字正则只能是中文英文_F开头的英文名字有哪些?英文名字典词典,根据中文名姓名发音起关联英文名,最强英文名取名攻略大全!...
  14. Maven 环境变量配置
  15. 在windows上配置本地域名解析,配置hosts文件
  16. mysql 临时表 会话级_会话级的临时表和事务级的临时表
  17. Arduino机器人快速上手经验分享(L298N马达驱动,摇杆模块)
  18. 经常看到RS485和MODBUS写在一起,它们的区别和联系?
  19. /(^\s*)|(\s*$)/g
  20. 3570. 【GDKOI2014】壕壕的寒假作业

热门文章

  1. 关于压缩工具 7z(7-zip) 的选项 -so(从标准输出流写入数据)的解读
  2. 虚拟内存越大越好吗_手机的运行内存真的是越大越好吗?6GB和8GB到底又该如何选择?...
  3. ieee期刊_论文绘图神器来了:一行代码绘制不同期刊格式图表,哈佛博士后开源...
  4. LeetCode 1021 删除最外层的括号
  5. php 返回页面重复提交,php防止表单重复提交
  6. python的内存管理机制及调优手段_Python的内存管理机制及调优手段
  7. matlab plot errorbar,如何为MATLAB errorbar plot的点和垂直线设置不同的图例?
  8. 判别分析分为r型和q型吗_SPSS聚类和判别分析参考.ppt
  9. PHP怎样表示几时几分,PHP将时间戳转换为刚刚、N分钟前、今天几点几分、昨天几点几分......
  10. 用python找对象_还在单身的你 Python教你如何脱单