vue 获取div标签_vue中获取标签方法

1、HTML DOM querySelector() 方法

按照以前jq方式, CSS 选择器来获取元素标签   [在mounted方法里面执行]

document.querySelector获取的是被选中元素的第一个元素;

document.querySelectorAll获取到所有被选中元素;

eg:document.querySelector("#demo");

document.querySelector(".demo");

document.querySelector("p");

document.querySelector("a, p")

document.querySelector("p.demo");

document.querySelector("a[target]");

2、vue的ref和$refs方法

ref是写在html里面的,相当于标签的索引,$refs 是所有注册过的ref的一个集合,然后通过$refs找到对应的ref,然后进行操作。

ref在dom标签上,则$refs是dom标签;ref在组件上,则$refs是子组件实例;

相同的ref时,到底取得哪一个时问题,所以ref优先级也是比较重要:

1、同一层级有相同的ref,最终通过$refs取得后面的元素(后>前);

2、嵌套层级(父子关系)的标签,最终通过$refs取得父亲元素(父>子);

使用方式:以下举例说明:

a、单纯获取当前组件的元素

你好

在js里面用this.$refs.test就可以获取到p标签

等同于:document.getElementById('demo'),但是$refs会减少获取dom节点的消耗

b、当获取的元素的ref是变量

你好

在js里面用this.$refs[this.test]就可以获取到p标签

c、父组件获取子组件的方法

子组件

childComponent

name:"child",

methods: {

childClick(e) {

console.log(e)

}

}

}

父组件

点击

//使用组件标签

export default{

name:"parent",

components: {

Child//将组件隐射为标签

},

methods: {

parentClick() {this.$refs.mychild.childClick("我是子组件里面的方法哦"); //调用子组件的方法childClick

}

}

}

既然是取dom,操作dom,所以最好不要在模板或computed里使用!

这里是漂亮的分割线

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值