自定义指令 函数式/对象式

本文介绍了如何在Vue中创建两个自定义指令:v-big用于将数值放大10倍显示,v-fbind用于让输入框默认获取焦点并自动放大输入值。作者详细展示了指令的定义、绑定时机以及其实现方法。
<template>
  <div class="hello">
    <!-- 需求1-->
    <span v-text="n"></span><br>
    <span v-big="n"></span>
    <button @click="n++">点击之后n+1</button><br>

    <!-- 需求2 -->
    <input type="text" v-fbind:value="n">
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  data() {
    return { n: 1 }
  },

  // 需求1:定义一个v-big指令,数值放大10倍
  // 函数式指令:
  directives: {
    // big函数何时被调用:1.指令与元素成功绑定时;2.指令所在的模板被重新解析时
    big(el, binding) {
      // el是一个真实的DOM,binding是绑定的值
      // console.log(el, bingding.value);
      el.innerText = binding.value * 10
    },

    // 需求2:定义一个v-fbind指令,和v-bind功能类似,但可以让所绑定的input元素默认获取焦点
    // fbind(el, binding) {
    //   // vue把指令和元素绑定成功并vue把元素放入页面了,才能执行成功,所以不能用函数式指令,接下来用对象式指令编写
    //   el.value = binding.value
    //   el.focus()
    // }
    fbind: {
      // 指令与元素绑定成功时
      bind(el, binding) { el.value = binding.value * 20 },
      // 指令所在元素被插入页面时
      inserted(el) { el.focus() },
      // 模板重新解析时调用
      update(el, binding) { el.value = binding.value * 20 }
    }
  }



}
</script>

<style scoped>
h3 {
  margin: 40px 0 0;
}

ul {
  list-style-type: none;
  padding: 0;
}

li {
  display: inline-block;
  margin: 0 10px;
}

a {
  color: #42b983;
}
</style>

注意:命名自定义指令时不建议使用小驼峰命名,尽量使用分隔符命名,比如v-big-number==》自定义指令可写成‘big-number’,所有指令的this指向只指向window的
Vue中,自定义指令也可以实现响应式的绑定操作。通过自定义指令的update钩子函数,我们可以在指令所在模板更新时执行相应的操作。在这个钩子函数中,我们可以获取到绑定值的变化,并根据变化对指令所在的元素进行相应的更新。 例如,我们可以通过自定义指令来监听窗口大小的变化。在update钩子函数中,我们可以使用window对象的resize事件来监听窗口大小的改变,并在窗口大小改变时更新指令所在元素的样式或行为。这样,在窗口大小改变时,指令所在元素的样式或行为就会实时地响应变化。 除了监听窗口大小的变化,自定义指令还可以用于监听其他事件的变化,比如监听滚动事件、鼠标移动事件等。通过自定义指令实现的响应式绑定,可以让我们更加灵活地控制和响应页面的变化。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue 自定义指令](https://blog.csdn.net/qq_34402069/article/details/131512955)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [vue实战-完全掌握Vue自定义指令](https://blog.csdn.net/yyds2026/article/details/127631554)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值