-
• 在模板中绑定并使用 ref 获取
-
• 使用 v-bind 绑定动态值并访问
-
• 直接在方法或事件处理器中获取
-
• 换个思路,作为参数传递
在 Vue.js 中获取元素中的自定义属性值,可以通过以下几种方式:
在模板中绑定并使用 ref 获取
<!-- 在Vue模板中给元素绑定ref -->
<div ref="myElement" :data-custom-attr="customValue"></div>
<script>
export default {
data() {
return {
customValue: 'someValue'
};
},
mounted() {
// 在组件挂载后通过this.$refs获取DOM元素和其自定义属性值
const customAttrValue = this.$refs.myElement.dataset.customAttr;
console.log(customAttrValue); // 输出:'someValue'
}
};
</script>
使用 v-bind
绑定动态值并访问
<!-- 动态绑定自定义属性 -->
<div :data-custom-prop="dynamicProp"></div>
<script>
export default {
data() {
return {
dynamicProp: 'fromData'
};
},
computed: {
// 或者在一个计算属性中获取这个动态值
customPropValue() {
return this.$el.dataset.customProp; // 如果是根元素的自定义属性
// 或者
// return this.$refs.someRef.dataset.customProp; // 如果通过ref引用的元素
}
},
mounted() {
console.log(this.customPropValue);
}
};
</script>
直接在方法或事件处理器中获取
通过e.target.dataset.*** 或者 e.target.getAttribute(‘data-***’)来获取。
<!-- 添加一个点击事件监听器 -->
<button @click="handleClick" :data-some-value="theValue">Click me</button>
<script>
export default {
data() {
return {
theValue: 'hello world'
};
},
methods: {
handleClick(event) {
// 在事件处理函数中通过event.target获取元素并读取自定义属性
// const valueFromEvent = event.target.getAttribute('someValue');
const valueFromEvent = event.target.dataset.someValue;
console.log(valueFromEvent);
}
}
};
</script>
换个思路,作为参数传递
<button @click="say('Hi')">say hi</button>
<script>
export default {
data() {
return {
theValue: 'hello world'
};
},
methods: {
say(message){
console.log(message)
}
}
}
</script>
以上四种方式分别展示了如何在Vue组件的不同阶段获取DOM元素上的自定义属性值。
原文始发于微信公众号(前端爱好者):vue 获取 元素中自定义值
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/267062.html