vue3.0中自定义指令的使用

前言:

       在vue3.0中使用我们的自定义指令。

实现步骤:(全局定义点击的自定义属性)

1、src/   新建文件夹 directives,新建index.js

export default (app) => {
  //自定义组件
  app.directive('demo', (el, binding) => {
    el.addEventListener('click', () => {
      console.log(binding.value.color) // => "white"
      console.log(binding.value.text) // => "hello!"
    })
  })
}

2、main.js中

import directives from './directives/index.js'

const app = createApp(App)
directives(app)

3、页面使用

<el-button v-demo="{ color: 'white', text: 'hello!' }">自定义指令</el-button>

4、点击按钮,f12中显示

官方介绍:点我进入

官方介绍详情:

函数简写

在前面的例子中,你可能想在 mounted 和 updated 时触发相同行为,而不关心其他的钩子函数。那么你可以通过将这个回调函数传递给指令来实现:

app.directive('pin', (el, binding) => {
  el.style.position = 'fixed'
  const s = binding.arg || 'top'
  el.style[s] = binding.value + 'px'
})

 

#对象字面量

如果指令需要多个值,可以传入一个 JavaScript 对象字面量。记住,指令函数能够接受所有合法的 JavaScript 表达式。

<div v-demo="{ color: 'white', text: 'hello!' }"></div>

 

app.directive('demo', (el, binding) => {
  console.log(binding.value.color) // => "white"
  console.log(binding.value.text) // => "hello!"
})

 

#在组件中使用

非 prop 的 attribute 类似,当在组件中使用时,自定义指令总是会被应用在组件的根节点上。

<my-component v-demo="test"></my-component>

1

app.component('my-component', {
  template: `
    <div> // v-demo 指令将会被应用在这里
      <span>My component content</span>
    </div>
  `
})

 

和 attribute 不同,指令不会通过 v-bind="$attrs" 被传入另一个元素。

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
在Vue.js自定义指令是用于扩展模板语法的一种方式。它允许开发者在DOM元素上添加一些特定的行为或交互逻辑。引用提到,Vue2和Vue3的自定义指令参数是一样的,包括el、binding、vnode和preVNode(oldVNode),这些参数用于指令的操作和交互。具体的用法可以查看官方文档。 然而,Vue2和Vue3在自定义指令的注册方式上有一些区别。在Vue2,我们使用Vue.directive()方法来注册全局自定义指令,或者在组件使用directives选项来注册局部自定义指令。而在Vue3,我们使用app.directive()方法来注册全局自定义指令,或者在组件的setup()函数使用directive()方法来注册局部自定义指令。这是因为Vue3将全局API移动到了应用实例(app)上,以提高代码的可读性和维护性。引用提供的例子展示了Vue2和Vue3注册自定义指令的区别。 总结来说,Vue2和Vue3的自定义指令在参数方面是一样的,但在注册方式上有一些区别。Vue2使用Vue.directive()来注册全局和局部自定义指令,而Vue3则使用app.directive()来注册全局自定义指令,或者在组件的setup()函数使用directive()来注册局部自定义指令。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue2和vue3自定义指令区别?](https://blog.csdn.net/m0_53273062/article/details/126201620)[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^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vue2.0和vue3.0自定义指令directive)的区别](https://blog.csdn.net/m0_46846526/article/details/118911913)[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^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浩星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值