自定义指令,全局,局部,注册

让输入框自动获取焦点(每次刷新自动获取焦点)

javascript 复制代码
<template>
  <div>
    <h3>自定义指令</h3>
    <input ref="inp" type="text">
  </div>
</template>

<script>
export default {
  mounted(){
    this.$refs.inp.focus()

  }

}
</script>

<style>

</style>

1.全局注册指令

在main.js中全局注册指令

javascript 复制代码
import Vue from 'vue'
import App from './App.vue'

Vue.config.productionTip = false

// 全局注册指令
// 第一个参数是指令名,第二个参数是指令的配置项(在配置项里可以写指令相关的钩子,相关的生命周期函数)
Vue.directive('focus', {
  // inserted会在指令所在元素被插入到页面时触发
  inserted(el) {
    // el就是指令所绑定的元素
    el.focus()


  }
})


new Vue({
  render: h => h(App),
}).$mount('#app')
javascript 复制代码
《!--在input标签中写上自定义指令 v-自定义的指令名 -->
<template>
  <div>
    <h3>自定义指令</h3>
    <input v-focus ref="inp" type="text">
  </div>
</template>

<script>
export default {
  // mounted(){
  //   this.$refs.inp.focus()

  // }

}
</script>

<style>

</style>

2.局部注册指令(只在当前组件范围使用)

javascript 复制代码
<template>
  <div>
    <h3>自定义指令</h3>
    <input v-focus ref="inp" type="text">
  </div>
</template>

<script>
export default {
  // mounted(){
  //   this.$refs.inp.focus()

  // }
  directives:{
    // 指令名:指令的配置项
    focus:{
      // 这里同样也有个形参el
      inserted(el){
        el.focus()
      }
    }
  }

}
</script>

<style>

</style>

封装一个指令v-color

自定义指令 v-color ,然后在h1标签中写入v-color指令,但是如果指令颜色写固定为red的话,每个使用该指令的标签都是同样的颜色。

希望标签是不同颜色,将该自定义指令传入不同的值,在data中定义不同的值。

但是自定义指令中是拿不到传入指令的值的,所以必须通过另一个配置项binding,通过binding.value取得传入的指令的值

javascript 复制代码
<template>
  <div>
    <!--相当于给两个指令传入不同的值 -->
    <h1 v-color="color1">指令的值1测试</h1>
    <h1 v-color="color2">指令的值2测试</h1>
    
  </div>
</template>

<script>
export default {
  data(){
    return{
      color1:'red',
      color2:'green'

    }
  },
  directives:{
    color:{
      //1.inserted提供的是元素被添加到页面中的逻辑,直接修改数据是无法改变颜色的
      // el形参表示的是传入的dom元素
      inserted(el,binding){
        // console.log(el,binding.value);
        
        // 如何拿到传递的不同的值?在binding配置对象中通过binding.value中拿到所对应的变量值
        // binding.value就是指令的值
        el.style.color = binding.value
      },
      // update(el,binding){
      //   el.style.color = binding.value
      // }
    }
  }

}
</script>

<style>

</style>
相关推荐
pe7er4 小时前
window管理开发环境篇 - 持续更新
前端·后端
We་ct4 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
陈随易8 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星9 小时前
javascript之事件代理/事件委托
前端
陈随易10 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
里欧跑得慢12 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒12 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
cn_mengbei13 小时前
用React Native开发OpenHarmony应用:Reanimated共享元素过渡
javascript·react native·react.js
kyriewen13 小时前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真13 小时前
我自己写的第一个skills--project-core-standards
前端·agent