分享更有价值
被信任是一种快乐

Vue中如何获取DOM元素

文章页正文上

今天小编给大家分享一下Vue中如何获取DOM元素的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 dom是一种文档对象模型,同时也是用于html编程的接口,通过dom来操作页面中的元素。DOM是HTML文档的内存中对象表示,它提供了使用JavaScript与网页交互的方式。DOM是节点的层次结构(或树),其中document节点作为根。什么是domdom是一种文档对象模型,同时也是用于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

节点内容

{{foo}}

节点内容实例化vue

constapp=newVue({
el:"#app",
data:{
foo:"foo"
}
})

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

(functionanonymous(
){
	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直接找元素

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

使用组件实例的$refs即可拿到组件上ref属性对应的元素。
如果ref属性加在一个组件上,那么拿到的是这个组件的实例,否则拿到的就是dom元素了。值得注意的是包含v-for循环模板指令的情况,其循环元素和子元素上ref属性对应的都是一个数组(就算动态生成ref,也是数组):

{{item.desc}}{{item.contact}}关于这个的原因,可以从Vue关于ref处理的部分代码得到:

functionregisterRef(vnode,isRemoval){
varkey=vnode.data.ref;
if(!isDef(key)){return}

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

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

Vue.directive('focus',{
//当被绑定的元素插入到DOM中时……
inserted:function(el){
//聚焦元素
el.focus()
}
})

//在模板中

关于自定义指令,在一些组件库和事件上报等场景下非常有用。以上就是“Vue中如何获取DOM元素”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注云技术行业资讯频道。

相关推荐: 怎么用Vue实现APP录音功能并上传功能

这篇文章主要介绍“怎么用Vue实现APP录音功能并上传功能”,在日常操作中,相信很多人在怎么用Vue实现APP录音功能并上传功能问题上存在疑惑,小编查阅了各式资料,整理免费云主机、域名出简单好用的操作方法,希望对大家解答”怎么用Vue实现APP录音功能并上传功…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册