vue有什么常用api

vue的api有:1、nextTick;2、mixin;3、“$forceUpdate”;4、set和delete;5、filter;6、directive;7、“$root”;8、“$el”;9、“$data”;10、“$props”等。

vue有什么常用api

本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。

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

功能: 对响应式数据的属性进行设置、删除,同时触发视图更新。
用法:

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

登录后复制

说明:

target:目标对象key:要添加的属性名value:要添加的属性值

ps:主要使用场景,可以避开 Vue 不能检测到 property 被删除的限制

filter

功能: 用于一些常见的文本格式化和一些规范数据mapping。
用法:

{{ message | capitalize }}

登录后复制

// 注册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

功能: 用于注册自定义指令。
用法:

 

登录后复制

// 注册一个全局自定义指令 `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 () {}})

登录后复制

v-model 语法糖

v-model 常用于表单元素上进行数据的双向绑定,比如 。除了原生的元素,它还能在自定义组件中使用。

v-model 是一个语法糖,可以拆解为 props: value 和 events: input。就是说组件必须提供一个名为 value 的 prop,以及名为 input 的自定义事件,满足这两个条件,使用者就能在自定义组件上使用 v-model。比如下面的示例,实现了一个数字选择器:

  
        {{ currentValue }}      
export default { name: 'InputNumber', props: { value: { type: Number } }, data () { return { currentValue: this.value } }, watch: { value (val) { this.currentValue = val; } }, methods: { increase (val) { this.currentValue += val; this.$emit('input', this.currentValue); } } }

登录后复制

props 一般不能在组件内修改,它是通过父级修改的,因此实现 v-model 一般都会有一个 currentValue 的内部 data,初始时从 value 获取一次值,当 value 修改时,也通过 watch 监听到及时更新;组件不会修改 value 的值,而是修改 currentValue,同时将修改的值通过自定义事件 input 派发给父组件,父组件接收到后,由父组件修改 value。所以,上面的数字选择器组件可以有下面两种使用方式:

    import InputNumber from '../components/input-number/input-number.vue';  export default {    components: { InputNumber },    data () {      return {        value: 1      }    }  }

登录后复制

或:

    import InputNumber from '../components/input-number/input-number.vue';  export default {    components: { InputNumber },    data () {      return {        value: 1      }    },    methods: {      handleChange (val) {        this.value = val;      }    }  }

登录后复制

如果你不想用 value 和 input 这两个名字,从 Vue.js 2.2.0 版本开始,提供了一个 model 的选项,可以指定它们的名字,所以数字选择器组件也可以这样写:

  
        {{ currentValue }}      
export default { name: 'InputNumber', props: { number: { type: Number } }, model: { prop: 'number', event: 'change' }, data () { return { currentValue: this.number } }, watch: { value (val) { this.currentValue = val; } }, methods: { increase (val) { this.currentValue += val; this.$emit('number', this.currentValue); } } }

登录后复制

在 model 选项里,就可以指定 prop 和 event 的名字了,而不一定非要用 value 和 input,因为这两个名字在一些原生表单元素里,有其它用处。

.sync 修饰符

如果你使用过 Vue.js 1.x,一定对 .sync 不陌生。在 1.x 里,可以使用 .sync 双向绑定数据,也就是父组件或子组件都能修改这个数据,是双向响应的。在 Vue.js 2.x 里废弃了这种用法,目的是尽可能将父子组件解耦,避免子组件无意中修改了父组件的状态。

不过在 Vue.js 2.3.0 版本,又增加了 .sync 修饰符,但它的用法与 1.x 的不完全相同。2.x 的 .sync 不是真正的双向绑定,而是一个语法糖,修改数据还是在父组件完成的,并非在子组件。

仍然是数字选择器的示例,这次不用 v-model,而是用 .sync,可以这样改写:

  
        {{ value }}      
export default { name: 'InputNumber', props: { value: { type: Number } }, methods: { increase (val) { this.$emit('update:value', this.value + val); } } }

登录后复制

用例:

    import InputNumber from '../components/input-number/input-number.vue';  export default {    components: { InputNumber },    data () {      return {        value: 1      }    }  }

登录后复制

看起来要比 v-model 的实现简单多,实现的效果是一样的。v-model 在一个组件中只能有一个,但 .sync 可以设置很多个。.sync 虽好,但也有限制,比如:

不能和表达式一起使用(如 v-bind:title.sync=”doc.title + ‘!'” 是无效的);

不能用在字面量对象上(如 v-bind.sync=”{ title: doc.title }” 是无法正常工作的)。

其它简单的常用属性和方法

// 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() {}

登录后复制

(学习视频分享:vuejs教程、vuejs教程)

以上就是vue有什么常用api的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2936792.html

(0)
上一篇 2025年3月11日 21:05:09
下一篇 2025年2月22日 19:30:55

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • angular和vue有什么区别

    区别:1、vue占用空间较小,而angular较大;2、Vue比Angular灵活,可按照不同需要去组织项目的应用代码;3、vue简单易学,angular的上手难度较高;4、angular指令是“ng-xxx”,vue指令是“v-xxx”。…

    2025年3月11日
    200
  • vue如何删除数组元素

    删除方法:1、用forEach遍历数组,用splice方法删除下标为index的元素,语法“this.splice(index, 1);”;2、用filer()删除,语法“listArr.filter(item=>item.check…

    2025年3月11日
    200
  • vue怎么将数组转为字符串

    在vue中,可以利用join()方法来将数组转为字符串,该方法可以将数组作为字符串返回,数组元素会使用指定分隔符进行分隔;语法为“数组对象.join(‘分隔符’)”。 本教程操作环境:windows7系统、vue2.…

    2025年3月11日
    200
  • 什么叫vue生命周期

    在vue中,生命周期是指vue实例对象从创建之初到销毁的过程。vue所有的功能实现都是围绕其生命周期进行的,在生命周期的不同阶段调用对应的钩子函数实现组件数据管理和DOM渲染两大重要功能。 本文操作环境:windows10系统、Vue2.9…

    2025年3月11日
    200
  • vue的spa项目是什么

    在vue中,spa项目指的是单页web应用。spa是加载单个HTML页面,并在用户与应用程序交互时动态更新该页面的web应用程序,只有第一次会加载页面,之后的每次请求都是获取必要的数据,通过js解析获取的数据并且展示在页面中。 本文操作环境…

    2025年3月11日
    200
  • vue插值有哪些操作

    vue插值操作有:1、使用Mustache语法,语法“{{值}}”;2、使用v-once指令;3、使用v-html指令,可输出html代码;4、使用v-text指令,用于将数据显示在界面中;5、使用v-pre指令;6、用v-cloak指令。…

    2025年3月11日 编程技术
    200
  • vue是mvvm模式吗

    vue是mvvm模式。vue中支持的双向绑定就是利用mvvm模式,当m层数据进行修改时,vm层会检测到变化,并且通知v层进行相应的修改来实现的,也就是数据影响视图,视图影响数据,极大了提高了开发效率。 本文操作环境:windows10系统、…

    2025年3月11日
    200
  • react与vue的虚拟dom有什么区别

    react与vue的虚拟dom没有区别;react和vue的虚拟dom都是用js对象来模拟真实DOM,用虚拟DOM的diff来最小化更新真实DOM,可以减小不必要的性能损耗,按颗粒度分为不同的类型比较同层级dom节点,进行增、删、移的操作。…

    2025年3月11日
    200
  • angular、react和vue有什么区别

    区别:1、angular中有控制器和过滤器,而react和vue中没有控制器和过滤器;2、react中没有渲染指令,而angular和vue中有渲染指令;3、react的数据绑定是单向的,而angular和vue中数据绑定是双向的。 本教程…

    2025年3月11日
    200
  • vue和jquery用什么语言

    vue和jquery用javascript语言,jquery和vue都是基于javascript脚本语言做了一层封装而成的js类库。vue是一个前端JavaScript框架,用于构建用户界面;而jquery是一个跨平台的JavaScript…

    2025年3月11日
    200

发表回复

登录后才能评论