VUE中的自定义指令钩子函数讲解

目录
  • 自定义指令钩子函数
    • 自定义指令
    • 先上官方解释
    • 小贴士
  • 钩子函数运行顺序

自定义指令钩子函数

自定义指令

除了VUE 内置指令外,VUE也支持我们自定义注册指令,分为局部和全局注册 但这些想必大家都不陌生,其中官方API也是写的明明白白 官方API点这里

而且自定义指令也会极大程度上帮助我们日常的编程,但这是很有意思的事情出现了,就是钩子函数,很多老铁都弄不明白这五个函数的具体区别

先上官方解释

  • bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置。
  • inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。
  • update:所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新 (详细的钩子函数参数见下)。
  • componentUpdated:指令所在组件的 VNode 及其子 VNode 全部更新后调用。
  • unbind:只调用一次,指令与元素解绑时调用。

之前有个朋友问我 每个字都认识 连起来就不明白了QAQ 因此这里给大家结合栗子来演示下 这五个过程

webpack 框架

App.vue

<template>
  <div class="container">
      <div class="row">
          <div class="col-xs-12">
           <!-局部这侧的组件->
              <app-test v-if="btn" :text="text"></app-test>
            <button @click="create">加载</button>
            <button @click="update">更新</button>
            <button @click="destory">关闭</button>
          </div>
      </div>
  </div>
</template>
<script>
    export default {
        data() {
            return {
                btn:true,
                text:'hello',
            }
        },
        components: {
            appTest: {
            // v-test 就是自定义指令  具体在main.js中看
                template: '<h1 v-test>{{text}}</h1>',
                props: {
                    text: String
                }
            }
        },
        methods: {
            //创建的方法
            create(){
                this.btn=true
            },
            //更新组件内容
            update(){
                this.text='hi'
            },
            //利用内部指令摧毁组件
            destory(){
                this.btn=false
            }
        },
    }
</script>

main.js

import Vue from 'vue'
import App from './App.vue'
//全局注册自定义指令  在每个钩子函数输出相应内容
//其中为了区分bind ,inserted 还相应输出元素的父节点
//为了区本update,componentUpdated 还想赢输出元素内容
Vue.directive('test', {
  bind: function (el) {
    console.log('bind');
    console.log(el.parentNode)
  },
  inserted: function (el) {
    console.log('inserted');
    console.log(el.parentNode)
  },
  update: function (el) {
    console.log('update');
    console.log(el.innerHTML)
  },
  componentUpdated: function (el) {
    console.log('componentUpdated')
    console.log(el.innerHTML)
  },
  unbind: function (el) {
    console.log('unbind')
  }
})
new Vue({
  el: '#app',
  render: h => h(App)
})

OK 运行 首先我们看到控制台输出

加载

bind
 null
 inserted
 <div class=​"col-xs-12">​…​</div>​

这时候我们可以判断首先加载时会经历这两个钩子函数,分别对应第一次绑定,和父元素加载完毕

按下更新按钮

updata
hello
componentUpdated
hi

这时候我们可以判断节点内容更新时会经历这两个钩子函数,分别对应更新前,和更新后

按下关闭

unbind

阶段销毁时经历unbind钩子函数

按下加载

bind
 null
 inserted
 <div class=​"col-xs-12">​…​</div>​

再次看下加载

小贴士

这时我们应该可以弄明白钩子函数

但其实大多数情况 我们只希望节点在加载和更新时发生同样的事情,而忽略其它钩子函数,可以这么写

Vue.directive('color-swatch', function (el, binding) {
    el.style.backgroundColor = binding.value
})

钩子函数运行顺序

在vue中,实例选项和钩子函数和{{}}表达式都是不需要手动调用就可以直接执行的。

在页面首次加载执行顺序有如下:

  • beforeCreate //在实例初始化之后、创建之前执行
  • created //实例创建后执行
  • beforeMounted //在挂载开始之前调用
  • filters //挂载前加载过滤器
  • computed //计算属性
  • directives-bind //只调用一次,在指令第一次绑定到元素时调用
  • directives-inserted //被绑定元素插入父节点时调用
  • activated //keek-alive组件被激活时调用,则在keep-alive包裹的嵌套的子组件中触发
  • mounted //挂载完成后调用
  • {{}} //mustache表达式渲染页面

修改页面input时,被自动调用的选项顺序如下:

  • watch //首先先监听到了改变事件
  • filters //过滤器没有添加在该input元素上,但是也被调用了
  • beforeUpdate //数据更新时调用,发生在虚拟dom打补丁前
  • directived-update //指令所在的组件的vNode更新时调用,但可能发生在其子vNode更新前
  • directives-componentUpdated//指令所在的组件的vNode及其子组件的vNode全部更新后调用
  • updated //组件dom已经更新

组件销毁时,执行顺序如下:

  • beforeDestroy //实例销毁之前调用
  • directives-unbind //指令与元素解绑时调用,只调用一次
  • deactivated //keep-alive组件停用时调用
  • destroyed //实例销毁之后调用

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 理解Vue2.x和Vue3.x自定义指令用法及钩子函数原理

    目录 Vue2.x用法 全局注册 局部注册 使用 钩子函数 钩子函数的参数 Vue3.x用法 全局注册 局部注册 使用 钩子函数 较 Vue2.x 相比, 钩子函数有变化 Vue2.x用法 全局注册 Vue.directive( 指令名, { 自定义指令生命周期 } ) 局部注册 directives: { 指令名, { 自定义指令生命周期 } } 使用 v-指令名: 属性名.修饰符="value值" 钩子函数 bind - 自定义指令绑定到 DOM 后调用. 只调用一次, 注意: 只

  • 十个有用的自定义Vue钩子函数总结

    目录 useWindowResize useStorage useNetworkStatus useCopyToClipboard useTheme usePageVisibility useViewport useOnClickOutside useScrollToBottom useTimer Vue 是我使用的第一个 JS 框架.可以说,Vue 是我进入JavaScript世界的第一道门之一.目前,Vue 仍然是一个很棒的框架.随着 composition API 的出现,Vue 只会有更

  • vue 自定义指令directives及其常用钩子函数说明

    目录 自定义指令directives及常用钩子函数 说明 钩子函数 vue 全局定义 局部定义(vue-cli) 钩子函数里面的参数 vue 自定义指令 directives选项 directives选项中定义 指令 自定义指令directives及常用钩子函数 说明 除了核心功能默认内置的指令 (v-model 和 v-show),Vue 也允许注册自定义指令 使用的地方:有的情况下,你仍然需要对普通 DOM 元素进行底层操作,这时候就会用到自定义指令 钩子函数 inserted:被绑定元素插

  • VUE中的自定义指令钩子函数讲解

    目录 自定义指令钩子函数 自定义指令 先上官方解释 小贴士 钩子函数运行顺序 自定义指令钩子函数 自定义指令 除了VUE 内置指令外,VUE也支持我们自定义注册指令,分为局部和全局注册 但这些想必大家都不陌生,其中官方API也是写的明明白白 官方API点这里 而且自定义指令也会极大程度上帮助我们日常的编程,但这是很有意思的事情出现了,就是钩子函数,很多老铁都弄不明白这五个函数的具体区别 先上官方解释 bind:只调用一次,指令第一次绑定到元素时调用.在这里可以进行一次性的初始化设置. inser

  • 详解Vue中的自定义指令

    除了默认设置的核心指令( v-model 和 v-show ),Vue 也允许注册自定义指令.在Vue里,代码复用的主要形式和抽象是组件.然而,有的情况下,仍然需要对纯 DOM 元素进行底层操作,这时候就会用到自定义指令.本文将详细介绍Vue自定义指令 指令注册 以一个input元素自动获得焦点为例,当页面加载时,使用autofocus可以让元素将获得焦点 .但是autofocus在移动版Safari上不工作.现在注册一个使元素自动获取焦点的指令 指令注册类似于组件注册,包括全局指令和局部指令两

  • vue中各选项及钩子函数执行顺序详解

    在vue中,实例选项和钩子函数和{{}}表达式都是不需要手动调用就可以直接执行的. vue的生命周期如下图: 在页面首次加载执行顺序有如下: beforeCreate //在实例初始化之后.创建之前执行 created //实例创建后执行 beforeMounted //在挂载开始之前调用 filters //挂载前加载过滤器 computed //计算属性 directives-bind //只调用一次,在指令第一次绑定到元素时调用 directives-inserted //被绑定元素插入父

  • 详解在Vue中通过自定义指令获取dom元素

    vue.js 是数据绑定的框架,大部分情况下我们都不需要直接操作 DOM Element,但在某些时候,我们还是有获取DOM Element的需求的: 在 vue.js 中,获取某个DOM Element常用的方法是将这个元素改成一个组件 (component),然后通过 this.$el 去获取,但是在一些很小的项目里,在一些没有使用 webpack 等构建工具的项目中,创建一个组件并不是那么值得,所以 vue 提供了另一种操作DOM元素的方式,就是自定义指令 (directive) : 自定

  • vue中的自定义指令clickOutside

    目录 自定义指令clickOutside 首先我们先看看vue官方的文档 clickoutside 这个指令用在哪里呢? 写法 自定义指令clickoutside使用及扩展用法 自定义指令clickOutside 这个指令通过vue的自定义指令的钩子函数实现. 首先我们先看看vue官方的文档 emmmm 看着好像有点困难,没关系官方文档也给出了例子. 现在应该就明白了不少了吧. clickoutside 这个指令用在哪里呢? 比如 写法 export default { bind (el, bi

  • 深入讲解AngularJS中的自定义指令的使用

    AngularJS的自定义指令,就是你自己的指令,加上编译器编译DOM时运行的原生核心函数.这可能很难理解.现在,假设我们想在应用中不同页面复用一些特定的代码,而又不复制代码.那么,我们就可以简单地把这段代码放到单独的文件,并调用使用自定义指令的代码,而不是一遍又一遍地敲下来.这样的代码更容易理解.AngularJS中有四种类型的自定义指令: 元素指令 属性指令 CSS class 指令 注释指令 在我们现有的app中实现他们之前,我们来看看自定义指令是个什么样子:   元素指令 在html中写

  • 如何在Vue3中实现自定义指令(超详细!)

    目录 前言 生命周期 钩子的参数 简化形式 对象字面量 在组件上使用指令 几个实用的自定义指令 自动聚焦v-focus 防抖v-debounce 节流v-throttle 弹窗隐藏v-hide 总结 在开发Vue项目时,大多数人都会使用到Vue内置的一些指令,例如v-model.v-if等,在使用的时候不知道有没有想过自己也来实现一个指令呢.本文就以Vue3项目为基础,从原理.方法到实际案例.注意事项,尽可能细致的讲解如何自定义指令. 前言 我们需要明白为什么需要自定义一个指令,其实就是想更加简

  • vue 过滤器和自定义指令的使用

    过滤器 01. 是什么 过滤器可以对我们传入的数据进行必要的处理,并返回处理的结果 过滤器不会修改数据 过滤器的本质是函数 过滤器函数应该有参数,参数必须包含你想进行处理的源数据 过滤器应该有返回值,返回处理后的结果 export default { // 通过filters创建局部过滤器 filters:{ 过滤器名称(data){ // 对传入的data 进行处理 return 处理结果 } } } 02. 怎么做 (1)定义过滤器 局部过滤器:定义在组件内部,只能在当前组件内使用 通过fi

  • Vue 3.0自定义指令的使用入门

    提示:在阅读本文前,建议您先阅读 Vue 3 官方文档 自定义指令 章节的内容. 一.自定义指令 1.注册全局自定义指令 const app = Vue.createApp({}) // 注册一个全局自定义指令 v-focus app.directive('focus', {   // 当被绑定的元素挂载到 DOM 中时被调用   mounted(el) {     // 聚焦元素     el.focus()   } }) 2.使用全局自定义指令 <div id="app"&g

  • Vue.js directive自定义指令详解

    自定义一个demo指令 Vue自定义指令语法如下: Vue.directive(id, definition) 传入的两个参数,id是指指令ID,definition是指定义对象.其中,定义对象可以提供一些钩子函数. <div id="app"> <!-- input输入框获得焦点 --> <input type="text" v-focus/> </div> <script> // 注册一个全局自定义指令

随机推荐