e.target.value和 binding.value 区别

e.target.valuebinding.value 都是在 Vue.js 中用于处理事件绑定时的值,但它们的使用场景和含义有所不同,分别用于普通的 DOM 事件和自定义指令。

  1. e.target.value
    • 这是常用于原生 DOM 事件处理函数中的一个属性,用于获取事件目标元素的值。
    • 在事件处理函数中,e 是事件对象,e.target 表示触发事件的 DOM 元素。对于输入元素(例如 <input><textarea><select> 等),e.target.value 可以获取用户输入的值。

示例:

html 复制代码
<template>
  <input type="text" @input="handleInput" />
</template>

<script>
export default {
  methods: {
    handleInput(e) {
      console.log('用户输入的值:', e.target.value);
    },
  },
};
</script>
  1. binding.value
    • 这是用于自定义指令中的一个属性,用于获取在指令绑定时传递给指令的值。
    • 在自定义指令的定义中,binding 是一个包含有关指令绑定信息的对象,其中的 value 属性用于获取传递给指令的值。

示例:

html 复制代码
<template>
  <div v-my-directive="directiveValue">Custom Directive Example</div>
</template>

<script>
// 自定义指令
Vue.directive('my-directive', {
  bind(el, binding) {
    console.log('传递给指令的值:', binding.value);
  },
});

export default {
  data() {
    return {
      directiveValue: 'Hello from directive!',
    };
  },
};
</script>

总结:

  • e.target.value 用于获取事件目标元素的值,通常在事件处理函数中使用。
  • binding.value 用于获取自定义指令绑定时传递给指令的值,通常在自定义指令的定义中使用。
相关推荐
Larcher10 小时前
新手也能学会,100行代码玩AI LOGO
前端·llm·html
徐子颐11 小时前
从 Vibe Coding 到 Agent Coding:Cursor 2.0 开启下一代 AI 开发范式
前端
小月鸭11 小时前
如何理解HTML语义化
前端·html
jump68011 小时前
url输入到网页展示会发生什么?
前端
诸葛韩信11 小时前
我们需要了解的Web Workers
前端
brzhang11 小时前
我觉得可以试试 TOON —— 一个为 LLM 而生的极致压缩数据格式
前端·后端·架构
yivifu12 小时前
JavaScript Selection API详解
java·前端·javascript
这儿有一堆花12 小时前
告别 Class 组件:拥抱 React Hooks 带来的函数式新范式
前端·javascript·react.js
十二春秋12 小时前
场景模拟:基础路由配置
前端
六月的可乐12 小时前
实战干货-Vue实现AI聊天助手全流程解析
前端·vue.js·ai编程