打开淘宝,在输入框输入商品时,下拉的推荐商品:
或是当打开某个不想再浏览的网页时,右上角的那个×:
这些大部分都存在DOM的身影。
这里的“DOM”,通常来讲,叫做 DOM 文档对象模型 , 通过 *** 纵DOM,可以随意更改内容,样式,或者增删改查 ,因为网页是在浏览器中显示的,整个浏览器是BOM,所以DOM其实是BOM的一部分,BOM 就是 window对象 ,DOM 就是 document(文档)对象。
如果该元素,是网页的必备元素,而且只能有一个,可以通过document对象直接获取。比如:图片的src属性:
任由我们怎么去修饰图片的显示,但它本身的路径属性是独有的,所以我们可以直接获取:
更多的时候,我要需要获取网页中的指定元素,这就需要专门的方法来获取了,这里列举几个方法:
getElementById()方法,根据元素的id属性值来获取指定的元素,因为ID的唯一性,使得该方法需要搭配ID选择器使用,如果网页里ID重复时,它会获取第一个:
getElementsByTagName()方法,根据元素的标签名获取所有该元素,该方法获取的是所有该标签的元素,以伪数组的形式呈现:
getElementsByClassName()方法,根据元素的类选择器名称获取所有该元素,该方法获取的途径是标签的类,也就是class属性,由于拥有该属性的标签可能不只一个,所以该方法获得的也是一个伪数组(还有,可以看方法名,凡是带Elements的大多数都是伪数组):
getElementsByName()方法,根据元素的name属性值获取所有该元素,相同的性质,有name属性的标签也不少:
querySelector()方法,根据选择器的名称返回元素,如果有多个元素,只返回第一个元素,这个方法就比较常用了,而且IE这个啥也不咋适配的浏览器现在几乎不咋能见到了,可以多多考虑用他了该方法是 ES6新增,无论是ID 还是class都可以选,但是和上面区别的是选ID时前面要加#号,选class时前面要加“.”:
区别于Elements,这里是个单数,所以只会获取一个,要是想获取多个相同的,就用querySelectorAll()吧!querySelectorAll()看这个ALL就知道它是用来选全部的:
最后这俩方法更实用,可以选取CSS几乎所有选择器,而且querySelectorAll()得到的数组数据后还可以使用数组的方法。
*** 作DOM的样式 ,有多种方式:
通过style属性直接设置
通过className属性设置类选择器
也可以通过classList属性添加多个类选择器
*** 作DOM的内容:
innerText属性,用于获取 和 *** 作 DOM的文本内容。
innerHTML属性,用于获取 和 *** 作 DOM的HTML内容:
createElement()方法,用于创建DOM元素:
appendChild()方法,用于在当前DOM元素中添加子元素:
自删 remove()方法,是元素删除自己:
通过父级删除子级 removeChild()方法,是删除元素里面指定的子元素:
classList属性返回元素的类名,它是一个DOMTokenList对象。相比较className来说,它的 *** 作更加简洁,类似于对数组的 *** 作。
通过控制台,我们可以看到,DOM元素的classList是一个DomTokenList对象,结构 类似 于数组:
不过classList在IE10以下,并不能支持classList。因此,来看看如何自己实现一个classList。
首先,我们知道 div,span等html标签,有一个共同的父类,就是HTMLElement
我们要在它上面,创建一个新的prototype。
首先我们想到了直接定义:
但是这样会有个问题,就是通过prototype定义属性,属性的值是共享的。因此当我们给myDiv的newClassList.push的时候,也改变了mySpan,这显然不符合我们的要求。
因此,我们可以采用Object.defineProperty这个方法,来实现,给我们的HTMLElement定义属性。
为什么要把这个属性变成类数组呢?是因为我们既要让它拥有数组的特性,也要可以有自己的方法,就是add(),remove(),toggle(),contains()...
接下来我们,写一个构造器。
然后我们再在构造器里添加方法,因为prototype定义的方法是共享的,所以在这里可以使用。
我们给构造器里创建了几个 *** 作类数组的方法,因为这个实例是类数组对象,所以我们可以直接通过[].join.call(this," ")[].push.call(this,class)调用数组的方法。
那么我们现在可以直接使用 myDiv.neCLassList.add("classB") 等方法了,但是这样仅仅是改变了这个属性的value,如何通知并改变DOM的classname呢?
很简单,我们在构造器里监听一下。
至此,我们就完成了classList的构造,要修改dom的class,直接使用myDiv.newClassList.add('classB')。。。就可以实现。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)