JS操作document对象

Posted 邢昊天

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS操作document对象相关的知识,希望对你有一定的参考价值。

找到对象:

document.getElementById()返回对拥有指定 id 的第一个对象的引用。

document.getElementsByName()返回带有指定名称的对象集合。

document.getElementsByTagName()返回带有指定标签名的对象集合。

document.getElementsByClassName()返回对拥有指定 class 的对象集合。

操作对象

操作属性:

取值:getAttribte();

document.getElementsByTagName("标签名")[0].getAttribute("属性名");

赋值:setAttribte();

document.getElementsByTagName("标签名")[0].setAttribute("属性名","属性值");

删除赋值:removeAttribute();

document.getElementsByTagName("标签名")[0].removeAttribute("属性名");

 

操作样式:

内联样式:style.xxxx;

class:

1.className。

2.把class当成属性来看

element.className = ‘blue‘;

操作内容:

表单元素:value;

document.getElementById("id名字").value;

文本框,单选框,复选框。

 

非表单元素:

innerhtml

document.getElementById("id名字").innerHTML="<a href=‘https://www.baidu.com‘>到百度</a> ";

浏览器会将inneHTML后面的内容作为html来解析。

 

innerText:

document.getElementById("id名字").innerText="<a href=‘https://www.sina.com‘>到新浪</a> ";

浏览器会将innerText后面的内容作为纯文本来解析。

 

操作节点:

什么是节点

1、整个文档时一个文档节点。
2、每个HTML元素是元素节点。
3、HTML元素内的文本是文本节点。
4、每个HTML属性是属性节点。
5、每个注释是注释节点。
所以HTML DOM 将 HTML 文档视作树结构,这种结构被称为节点树。通过 HTML DOM,节点树中的所有节点都可以通过 JS 进行访问。所有 HTML 元素(节点)均可被修改。

 

 

创建节点、追加节点:

createElement(标签名)创建一个元素节点(具体的一个元素);

appendChild(节点)追加一个节点。

createTextNode(节点文本内容)创建一个文本节点。

例子:

<body>

<div id="div1">
<p id="p1">这是一个段落。</p>
<p id="p2">这是另一个段落。</p>
</div>
<script>
var para=document.createElement("p");
var node=document.createTextNode("这是一个新段落。");
para.appendChild(node);
var element=document.getElementById("div1");
element.appendChild(para);
</script>

删除、移除节点:

removeChild(节点) 删除一个节点,用于移除删除一个参数(节点)。其返回的被移除的节点,被移除的节点仍在文档中,只是文档中已没有其位置了

    var removeChild = document.body.removeChild(div1);//移除document对象的方法div1  

 

替换节点:

replaceChild(插入的节点,被替换的节点) ,用于替换节点,接受两个参数,第一参数是要插入的节点,第二个是要被替换的节点。返回的是被替换的节点。

var replaceChild= document.body.replaceChild(div1,div2); //将div1替换div2

 

查找节点:

 

childNodes 包含文本节点和元素节点的子节点:

    for (var i = 0; i < oList.childNodes.length; i++) {//oList是做的ul的对象。  
    //nodeType是节点的类型,利用nodeType来判断节点类型,再去控制子节点  
    //nodeType==1 是元素节点  
    //nodeType==3 是文本节点  
        if (oList.childNodes[i].nodeType == 1) {//查找到oList内的元素节点  
            console.log(oList.childNodes[i]);//在控制器日志中显示找到的元素节点  
        }  
    }  

children也可以获取子节点,而且兼容各种浏览器:

console.log(oList.children);//在控制器日志中显示oList子节点

 

parentNode:获取父节点:

    var oList = document.getElementById(‘list‘);//oList是做的ul的对象  
    var oChild=document.getElementById(‘child‘);//oChild是做的ul中的一个li的对象  
    //通过子节点查找父节点//parentNode:获取父节点  
    console.log(oChild.parentNode);//在控制器日志中显示父节点  
    console.log(oList.children);//在控制器日志中显

nextSibling;查找下一个兄弟节点

previousSibling:查找上一个兄弟节点

 

对元素节点的所有操作:

element.accessKey     设置或返回元素的快捷键。
element.appendChild()     向元素添加新的子节点,作为最后一个子节点。
element.attributes     返回元素属性的 NamedNodeMap。
element.childNodes     返回元素子节点的 NodeList。
element.className     设置或返回元素的 class 属性。
element.clientHeight     返回元素的可见高度。
element.clientWidth     返回元素的可见宽度。
element.cloneNode()     克隆元素。
element.compareDocumentPosition()     比较两个元素的文档位置。
element.contentEditable     设置或返回元素的文本方向。
element.dir     设置或返回元素的内容是否可编辑。
element.firstChild     返回元素的首个子。
element.getAttribute()     返回元素节点的指定属性值。
element.getAttributeNode()     返回指定的属性节点。
element.getElementsByTagName()     返回拥有指定标签名的所有子元素的集合。
element.getFeature()     返回实现了指定特性的 API 的某个对象。
element.getUserData()     返回关联元素上键的对象。
element.hasAttribute()     如果元素拥有指定属性,则返回true,否则返回 false。
element.hasAttributes()     如果元素拥有属性,则返回 true,否则返回 false。
element.hasChildNodes()     如果元素拥有子节点,则返回 true,否则 false。
element.id     设置或返回元素的 id。
element.innerHTML     设置或返回元素的内容。
element.insertBefore()     在指定的已有的子节点之前插入新节点。
element.isContentEditable     设置或返回元素的内容。
element.isDefaultNamespace()     如果指定的 namespaceURI 是默认的,则返回 true,否则返回 false。
element.isEqualNode()     检查两个元素是否相等。
element.isSameNode()     检查两个元素是否是相同的节点。
element.isSupported()     如果元素支持指定特性,则返回 true。
element.lang     设置或返回元素的语言代码。
element.lastChild     返回元素的最后一个子元素。
element.namespaceURI     返回元素的 namespace URI。
element.nextSibling     返回位于相同节点树层级的下一个节点。
element.nodeName     返回元素的名称。
element.nodeType     返回元素的节点类型。
element.nodeValue     设置或返回元素值。
element.normalize()     合并元素中相邻的文本节点,并移除空的文本节点。
element.offsetHeight     返回元素的高度。
element.offsetWidth     返回元素的宽度。
element.offsetLeft     返回元素的水平偏移位置。
element.offsetParent     返回元素的偏移容器。
element.offsetTop     返回元素的垂直偏移位置。
element.ownerDocument     返回元素的根元素(文档对象)。
element.parentNode     返回元素的父节点。
element.previousSibling     返回位于相同节点树层级的前一个元素。
element.removeAttribute()     从元素中移除指定属性。
element.removeAttributeNode()     移除指定的属性节点,并返回被移除的节点。
element.removeChild()     从元素中移除子节点。
element.replaceChild()     替换元素中的子节点。
element.scrollHeight     返回元素的整体高度。
element.scrollLeft     返回元素左边缘与视图之间的距离。
element.scrollTop     返回元素上边缘与视图之间的距离。
element.scrollWidth     返回元素的整体宽度。
element.setAttribute()     把指定属性设置或更改为指定值。
element.setAttributeNode()     设置或更改指定属性节点。
element.setIdAttribute()     
element.setIdAttributeNode()     
element.setUserData()     把对象关联到元素上的键。
element.style     设置或返回元素的 style 属性。
element.tabIndex     设置或返回元素的 tab 键控制次序。
element.tagName     返回元素的标签名。
element.textContent     设置或返回节点及其后代的文

 

 

 

 

 

 

 

 

 

 

 

 

 

以上是关于JS操作document对象的主要内容,如果未能解决你的问题,请参考以下文章

前端开发常用js代码片段

前端开发中最常用的JS代码片段

js-权威指南学习笔记14

VSCode自定义代码片段——JS中的面向对象编程

VSCode自定义代码片段9——JS中的面向对象编程

JS操作document对象