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


Posted in Vue.js onFebruary 02, 2021

最近手痒痒,玩儿了一下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

文中如有错误,欢迎在评论区指正,如果有所帮助,欢迎点赞和关注。

以上就是Vue常用API、高级API的相关总结的详细内容,更多关于Vue常用API、高级API的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
vue表单验证之禁止input输入框输入空格
Dec 03 Vue.js
vuex的使用和简易实现
Jan 07 Vue.js
vue使用过滤器格式化日期
Jan 20 Vue.js
用vite搭建vue3应用的实现方法
Feb 22 Vue.js
vue3中的组件间通信
Mar 31 Vue.js
vue-cli4.5.x快速搭建项目
May 30 Vue.js
vite+vue3.0+ts+element-plus快速搭建项目的实现
Jun 24 Vue.js
浅谈Vue的computed计算属性
Mar 21 Vue.js
vue中控制mock在开发环境使用,在生产环境禁用方式
Apr 06 Vue.js
vue打包时去掉所有的console.log
Apr 10 Vue.js
vue里使用create, mounted调用方法
Apr 26 Vue.js
ant design vue的form表单取值方法
Jun 01 Vue.js
Vue项目打包部署到apache服务器的方法步骤
Feb 01 #Vue.js
如何在vue中使用video.js播放m3u8格式的视频
Feb 01 #Vue.js
Vue 实现可视化拖拽页面编辑器
Feb 01 #Vue.js
vue-video-player 断点续播的实现
Feb 01 #Vue.js
Vite和Vue CLI的优劣
Jan 30 #Vue.js
如何使用RoughViz可视化Vue.js中的草绘图表
Jan 30 #Vue.js
vue监听键盘事件的相关总结
Jan 29 #Vue.js
You might like
让你的PHP7更快之Hugepage用法分析
2016/05/31 PHP
PHP利用pdo_odbc实现连接数据库示例【基于ThinkPHP5.1搭建的项目】
2019/05/13 PHP
jquery jqPlot API 中文使用教程(非常强大的图表工具)
2011/08/15 Javascript
jQuery在IE下使用未闭合的xml代码创建元素时的Bug介绍
2012/01/10 Javascript
JS子父窗口互相操作取值赋值的方法介绍
2013/05/11 Javascript
JQuery+Ajax无刷新分页的实例代码
2014/02/08 Javascript
JS实现仿新浪黄色经典滑动门效果代码
2015/09/27 Javascript
angularjs实现下拉列表的选中事件示例
2017/03/03 Javascript
JavaScript之class继承_动力节点Java学院整理
2017/07/03 Javascript
详解微信小程序Radio选中样式切换
2017/07/06 Javascript
详解原生JS回到顶部
2019/03/25 Javascript
vue 项目打包时样式及背景图片路径找不到的解决方式
2019/11/12 Javascript
vue + node如何通过一个Txt文件批量生成MP3并压缩成Zip
2020/06/02 Javascript
[03:42]2014DOTA2西雅图国际邀请赛 Navi战队巡礼
2014/07/07 DOTA
[23:18]Spirit vs Liquid Supermajor小组赛A组 BO3 第二场 6.2
2018/06/03 DOTA
python基于xmlrpc实现二进制文件传输的方法
2015/06/02 Python
Python实现多线程抓取妹子图
2015/08/08 Python
python用列表生成式写嵌套循环的方法
2018/11/08 Python
Python3爬虫学习入门教程
2018/12/11 Python
浅谈python 导入模块和解决文件句柄找不到问题
2018/12/15 Python
pandas读取CSV文件时查看修改各列的数据类型格式
2019/07/07 Python
python 动态迁移solr数据过程解析
2019/09/04 Python
python 魔法函数实例及解析
2019/09/25 Python
python实现用户名密码校验
2020/03/18 Python
Django media static外部访问Django中的图片设置教程
2020/04/07 Python
Python+Selenium随机生成手机验证码并检查页面上是否弹出重复手机号码提示框
2020/09/21 Python
css3遮罩层镂空效果的多种实现方法
2020/05/11 HTML / CSS
美国最大的在线水培用品商店:GrowersHouse.com
2018/08/14 全球购物
考试作弊检讨书大全
2014/02/18 职场文书
服务承诺书格式
2014/05/21 职场文书
工会换届选举方案
2014/05/21 职场文书
大学生党员个人对照检查材料范文
2014/09/25 职场文书
大学生党员个人剖析材料
2014/10/08 职场文书
幼儿园五一劳动节活动总结
2015/02/09 职场文书
读书笔记怎么写
2015/07/01 职场文书
JS前端轻量fabric.js系列物体基类
2022/08/05 Javascript