欢迎来到站长教程网!

Javascript/Ajax

当前位置:主页 > 网页制作 > Javascript/Ajax >

Vue常用API、高级API的相关总结

时间:2021-05-05|栏目:Javascript/Ajax|点击:

最近手痒痒,玩儿了一下Vue3.0,很舒服,赶忙把这几期Vue2.0弄完,写一些3.0的对象。
本文主要摆列息争析一些小我私家认为常用或有大用途的Api,作为自我总结的条记和探讨。

nextTick

成果:

添加在下次Dom更新轮回竣事之后的延迟回调,修改数据之后,可以获取更新后的Dom。
用法:

Vue.nextTick( [callback, context] )
vm.$nextTick( [callback] )
// 用法2
// 作为一个 Promise 利用 (2.1.0 起新增)
Vue.nextTick()
 .then(function () {
  // DOM 更新了
 })

说明:

callback:延迟回调函数
context:可选的object
ps:2.1.0 起新增:假如没有提供回调且在支持 Promise 的情况中,则返回一个 Promise。请留意 Vue 不自带 Promise 的 polyfill,所以假如你的方针欣赏器不原生支持 Promise (IE:你们都看我干嘛),你得本身提供 polyfill。

扩展:

关于nextTick的执行机制和利用场景,我们还必需把握雷同的requestAnimationFrame() 和 process.nextTick(), 前者是欣赏器自带的监听(在下次重绘之前执行),后者是node情况下,在下一个事件轮询的时间点上执行

mixin

成果:

注册一个混入,影响注册之后所有建设的每个 Vue 实例。插件作者可以利用混入,向组件注入自界说的行为。
用法:

// 为自界说的选项 'myOption' 注入一个处理惩罚器。
Vue.mixin({
 created: function () {
  var myOption = this.$options.myOption
  if (myOption) {
   console.log(myOption)
  }
 }
})

new Vue({
 myOption: 'hello!'
})
// => "hello!"

说明:

object:一个vm的属性或要领
ps:请审慎利用全局混入,因为它会影响每个单独建设的 Vue 实例 (包罗第三方组件)。大大都环境下,只该当应用于自界说选项,就像上面示例一样。推荐将其作为插件宣布,以制止反复应用混入。

$forceUpdate

成果:

迫使 Vue 实例从头渲染。
用法:

vm.$forceUpdate()

set、delete

成果:

对响应式数据的属性举办配置、删除,同时触发视图更新。
用法:

// 用法1
Vue.set( target, key, value )
Vue.delete( target, key )
// 用法2
vm.$set( target, key, value )
vm.$delete( target, key )

说明:

target:方针工具
key:要添加的属性名
value:要添加的属性值
ps:主要利用场景,可以避开 Vue 不能检测到 property 被删除的限制

filter

成果:

用于一些常见的文本名目化和一些类型数据mapping。
用法:

<!-- 在双花括号中 -->
{{ message | capitalize }}

<!-- 在 `v-bind` 中 -->
<div v-bind:id="rawId | formatId"></div>
// 注册
filters: {
 capitalize: function (value) {
  if (!value) return ''
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
 }
}
// 全局注册
Vue.filter('capitalize', function (value) {
 if (!value) return ''
 value = value.toString()
 return value.charAt(0).toUpperCase() + value.slice(1)
})

new Vue({
 // ...
})

说明:

过滤器函数总吸收表达式的值 (之前的操纵链的功效) 作为第一个参数。
过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”标记指示。

ps:过滤器可以接管多个参数,如{{ message | filterA('arg1', arg2) }},这里,filterA 被界说为吸收三个参数的过滤器函数。个中 message 的值作为第一个参数,普通字符串 'arg1' 作为第二个参数,表达式 arg2 的值作为第三个参数。

directive

成果:

用于注册自界说指令。

用法:

<!-- 当页面加载时,该元素将得到核心 --> 
<input v-focus>
// 注册一个全局自界说指令 `v-focus`
Vue.directive('focus', {
 // 当被绑定的元素插入到 DOM 中时……
 inserted: function (el) {
  // 聚焦元素
  el.focus()
 }
})
// 注册局部指令,组件中也接管一个 directives 的选项
directives: {
 focus: {
  // 指令的界说
  inserted: function (el) {
   el.focus()
  }
 }
}

说明:

inserted 只是注册指令的个中一个插值函数,完整的注册属性还可以包罗:
bind:只挪用一次,指令第一次绑定到元素时挪用,在这里可以举办一次性的初始化配置。
inserted:被绑定元素插入父节点时挪用(仅担保父节点存在,但不必然已被插入文档中)。
update:地址组件的 VNode 更新时挪用,可是大概产生在其子 VNode 更新之前。指令的值大概产生了改变,也大概没有,可是可以通过较量更新前后的值来忽略不须要的模板更新。
componentUpdated:指令地址组件的 VNode 及其子 VNode 全部更新后挪用。
unbind:只挪用一次,指令与元素解绑时挪用。

Vue.directive('my-directive', {
 bind: function () {},
 inserted: function () {},
 update: function () {},
 componentUpdated: function () {},
 unbind: function () {}
})

其它简朴的常用属性和要领

// console.log(vm.$root); 
vm.$root  //实例工具

vm.$el //根元素(真实的DOM元素)
// console.log(vm.$el);

vm.$el.innerHTML  //获得根元素(真实的DOM元素)中的内容
// console.log(vm.$el.innerHTML);

vm.$data  //实例下的data工具
// console.log(vm.$data);

vm.$options   //实例下的挂载项
// console.log(vm.$options);

vm.$props  //组件之间通信的数据
// console.log(vm.$props);

vm.$parent   //在组件中,指父元素
// console.log(vm.$parent);

vm.$children  //在组件中,指子代元素
// console.log(vm.$children);

vm.$attrs  //用来获取父组件通报过来的所有属性
// console.log(vm.$attrs);

vm.$listeners  //用来获取父组件通报过来的所有要领
// console.log(vm.$listeners);

vm.$slots  //组件中的插槽
// console.log(vm.$slots);

vm.$scopedSlots   //用来会见浸染域插槽
// console.log(vm.$scopedSlots);

vm.$refs  //用来定位DOM元素(利用ref举办追踪)
// console.log(vm.$refs);

vm.$watch  //用于监听数据(在vue文件中利用后会自动销毁)
// console.log(vm.$watch);

vm.$emit  //用于派发事件(常用于数据通信)
// console.log(vm.$emit);

vm.$on //用于监听事件的派发
// console.log(vm.$on);

vm.$once  //只监听事件一次(之后不监听)
// console.log(vm.$once);

//生命周期
beforeCreate() {
}
created() {
}
beforeMount() {
}
mounted() {
}
beforeUpdate() {
}
updated() {
}
beforeDestroy() {
}
destroyed() {
}

总结

本文主要收录vue中常用的这几个API,假如有乐趣进修更多,可以参考其官网。但愿本文对你有用,并能纯熟运用到实际的项目开拓中。

为了利便阅读领略,本文代码已经上传Github

文中如有错误,接待在评论区指正,假如有所辅佐,接待点赞和存眷。

上一篇:详解微信小措施轨迹回放实现及碰着的坑

栏    目:Javascript/Ajax

下一篇:JavaScript实现点击廉价菜单结果

本文标题:Vue常用API、高级API的相关总结

本文地址:www.jiaocheng88.com.cn/JavaScript/61964.html

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:584415406 | 邮箱:584415406#qq.com(#换成@)

Copyright © 2015-2020 小白站长教程网 版权所有 苏ICP备20040415号-3