文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue中如何获取DOM元素

2023-07-04 20:14

关注

今天小编给大家分享一下Vue中如何获取DOM元素的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

dom是一种文档对象模型,同时也是用于html编程的接口,通过dom来操作页面中的元素。DOM是HTML文档的内存中对象表示,它提供了使用JavaScript与网页交互的方式。DOM是节点的层次结构(或树),其中document节点作为根。

什么是dom

dom是一种文档对象模型,同时也是用于html编程的接口,通过dom来操作页面中的元素。当html页面被实现加载的时候,浏览器会创建一个dom,给文档提供了一种新的逻辑结构,并且可以改变内容和结构。

DOM称为文件对象模型(DocumentObjectModel,简称DOM),是W3C组织推荐的处理可扩展置标语言的标准编程接口

DOM是HTML文档的内存中对象表示,它提供了使用JavaScript与网页交互的方式。DOM是节点的层次结构(或树),其中document节点作为根。

实际上DOM是以面向对象的方式来描述的文档模型。DOM定义了表示和修改文档所需的对象和这些对象的行为和属性以及这些对象之间的关系。

通过JavaScript,我们可以重构整个HTML文档。比如添加、移除、改变或重排页面上的项目。

要改变页面上的某个东西,JavaScript就需要获得对HTML文档中所有元素进行访问的入口。这个入口,连同对HTML元素进行添加、移动、改变或移除的方法和属性,都是通过文档对象模型来获得的。

什么是虚拟DOM

虚拟 DOM (Virtual DOM )这个概念相信大家都不陌生,从 React 到 Vue ,虚拟 DOM 为这两个框架都带来了跨平台的能力(React-Native 和 Weex)

实际上它只是一层对真实DOM的抽象,以JavaScript 对象 (VNode 节点) 作为基础的树,用对象的属性来描述节点,最终可以通过一系列操作使这棵树映射到真实环境上

在Javascript对象中,虚拟DOM 表现为一个 Object对象。并且最少包含标签名 (tag)、属性 (attrs) 和子元素对象 (children) 三个属性,不同框架对这三个属性的名命可能会有差别

创建虚拟DOM就是为了更好将虚拟的节点渲染到页面视图中,所以虚拟DOM对象的节点与真实DOM的属性一一照应

在vue中同样使用到了虚拟DOM技术

定义真实DOM

<div id="app">    <p class="p">节点内容</p>    <h4>{{ foo }}</h4></div>

实例化vue

const app = new Vue({    el:"#app",    data:{        foo:"foo"    }})

观察render的render,我们能得到虚拟DOM

(function anonymous() {with(this){return _c('div',{attrs:{"id":"app"}},[_c('p',{staticClass:"p"},  [_v("节点内容")]),_v(" "),_c('h4',[_v(_s(foo))])])}})

通过VNode,vue可以对这颗抽象树进行创建节点,删除节点以及修改节点的操作, 经过diff算法得出一些需要修改的最小单位,再更新视图,减少了dom操作,提高了性能。

Vue获取DOM的几种方法

虽然Vue实现了MVVM模型,将数据和表现进行了分离,我们只需要更新数据就能使DOM同步更新,但是某些情况下,还是需要获取DOM元素进行操作(比如引入的某个库要求传入一个根dom元素作为根节点,或者写一些自定义指令),本文主要介绍几种在Vue中获取DOM元素的方法。

使用DOM API直接找元素

<script>...mounted () {let elm = this.$el.querySelector('#id')}</script>

这种方法足够简单直观,Vue组件在patch阶段结束时会把this.$el赋值为挂载的根dom元素,我们可以直接使用$elquerySelector, querySelectorAll等方法获取匹配的元素。

refs

<template><div ref="bar">{{ foo }}</div><MyAvatar ref="avatar" />...</template><script>...mounted () {let foo = this.$refs['bar'] // 一个dom元素let avatar = this.$refs['avatar'] // 一个组件实例对象}</script>

使用组件实例的$refs即可拿到组件上ref属性对应的元素。
如果ref属性加在一个组件上,那么拿到的是这个组件的实例,否则拿到的就是dom元素了。

值得注意的是包含v-for循环模板指令的情况,其循环元素和子元素上ref属性对应的都是一个数组(就算动态生成ref,也是数组):

<template><div v-for="item in qlist" :key="item.id" ref="qitem"><h4>{{ item.title  }}</h4><p ref="pinitem">{{ item.desc }}</p><p :ref="'contact'+item.id">{{ item.contact }}</p></div>...</template><script>...data () {return {qlist: [{ id: 10032, title: 'abc', desc: 'aadfdcc', contact: 123 },{ id: 11031, title: 'def', desc: '--*--', contact: 856 },{ id: 20332, title: 'ghi', desc: '?/>,<{]', contact: 900 }]}},mounted () {let foo = this.$refs['qitem'] // 一个包含dom元素的数组let ps = this.$refs['pinitem'] // p元素是v-for的子元素,同样是一个数组let contact1 = this.$refs['contact' + this.qlist[0].id] // 还是个数组}</script>

关于这个的原因,可以从Vue关于ref处理的部分代码得到:

function registerRef (vnode, isRemoval) {  var key = vnode.data.ref;  if (!isDef(key)) { return }  var vm = vnode.context;  // vnode如果有componentInstance表明是一个组件vnode,它的componentInstance属性是其真实的根元素vm  // vnode如果没有componentInstance则不是组件vnode,是实际元素vnode,直接取其根元素  var ref = vnode.componentInstance || vnode.elm;  var refs = vm.$refs;  if (isRemoval) {    ...  } else {  // refInFor是模板编译阶段生成的,它是一个布尔值,为true表明此vnode在v-for中    if (vnode.data.refInFor) {      if (!Array.isArray(refs[key])) {        refs[key] = [ref]; // 就算元素唯一,也会被处理成数组      } else if (refs[key].indexOf(ref) < 0) {        // $flow-disable-line        refs[key].push(ref);      }    } else {      refs[key] = ref;    }  }}

使用自定义指令

Vue提供了自定义指令,官方文档给出了如下的使用方法,其中el就是dom元素的引用

Vue.directive('focus', {  // 当被绑定的元素插入到 DOM 中时……  inserted: function (el) {    // 聚焦元素    el.focus()  }})// 在模板中<template><input v-model="name" v-focus /></template>

关于自定义指令,在一些组件库和事件上报等场景下非常有用。

以上就是“Vue中如何获取DOM元素”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯