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、单纯获取当前组件的元素
<p ref="test" id="demo">你好</p>
在js里面用this.$refs.test就可以获取到p标签
等同于:document.getElementById('demo'),但是$refs会减少获取dom节点的消耗
b、当获取的元素的ref是变量
<p :ref="test">你好</p>
在js里面用this.$refs[this.test]就可以获取到p标签
c、父组件获取子组件的方法
子组件
<template> <div> childComponent </div> </template> <script> export default { name: "child", methods: { childClick(e) { console.log(e) } } } </script>
父组件
<template> <div> <button @click="parentClick">点击</button> <Child ref="mychild" /> //使用组件标签 </div> </template> <script> import Child from ‘./child‘; //引入子组件Child export default { name: "parent", components: { Child // 将组件隐射为标签 }, methods: { parentClick() { this.$refs.mychild.childClick("我是子组件里面的方法哦"); // 调用子组件的方法childClick } } } </script>
既然是取dom,操作dom,所以最好不要在模板或computed里使用!
这里是漂亮的分割线
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了