开发者社区> auqbllxiu> 正文

Dom基本操作之CURD

简介: Dom基本操作之CURD
+关注继续查看

查找元素

<div id="box">id="box"</div>
<div class="box">class="box"</div>
<div name="box">name="box"</div>
<p><span>+ p > span</span></p>
<span>+ span</span>
/**

* 获取单个元素或多个元素(HTMLCollection)
*/
console.log(document.getElementById('box'));
console.log(document.getElementsByClassName('box'));
console.log(document.getElementsByTagName('div'));

/**
* 类似jQuery方式
* 获取单个元素 返回单个DOM元素,没有返回null
*/
console.log(document.querySelector('.box'));
console.log(document.querySelector('#box'));
console.log(document.querySelector('div'));
console.log(document.querySelector('[name="box"]'));
console.log(document.querySelector('div + p > span'));

/**
* 获取多个元素,返回NodeList, 转为数组
*/
const arr = [...document.querySelectorAll('div')]
console.log(arr);

// or
const alsoArr = Array.from(document.querySelectorAll('div'))
console.log(alsoArr);

// 链式操作
console.log(document.querySelector('p').querySelector('span'));

// 绑定 console中可以直接用$
const $ = document.querySelector.bind(document)
// console.log($('div'));

// 向上查找
console.log($('p > span').closest('p'));

添加 DOM 元素

<a href="/home" class="active">首页</a>

以前的方式

const link = document.createElement('a')
link.setAttribute('href', '/home')
link.className = 'active'
link.textContent = '首页'

// finally
document.body.appendChild(link)

jQuery

$('body').append('<a href="/home" class="active">首页</a>')

JavaScript

// 插入html
document.body.insertAdjacentHTML(
'beforeend',
'<a href="/home" class="active">首页</a>'
)

// 插入 HTML 元素
document.body.insertAdjacentElement(
'beforeend',
document.createElement('a')
)

// 插入文本
document.body.insertAdjacentText('afterbegin', 'cool!')

位置参数

<!-- beforebegin -->
<div>
<!-- afterbegin -->
<span></span>
<!-- beforeend -->
</div>
<!-- afterend -->

移动 DOM 元素

<div class="first">
<h1>Title</h1>
</div>

<div class="second">
<h2>Subtitle</h2>
</div>

h2 移动到 h1 的后面去

const h1 = document.querySelector('h1')
const h2 = document.querySelector('h2')

h1.insertAdjacentElement('afterend', h2)

替换 DOM 元素

// 之前
parentNode.replaceChild(newNode, oldNode)

// 现在
oldElement.replaceWith(newElement)

移除 DOM 元素

// 之前
const target = document.querySelector('#target')
target.parentNode.removeChild(target)

// 现在
const target = document.querySelector('#target')
target.remove()

用 HTML 字符串创建 DOM 元素

const createSingleElement = (domString) => {
const parser = new DOMParser()
return parser.parseFromString(domString, 'text/html').body.firstChild
}

// usage
const element = createSingleElement('<a href="./home">Home</a>')

参考

DOM 高级工程师不完全指南

            </div>

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Dom基本操作之CURD
Dom基本操作之CURD
10 0
Vue实现对数据的增删改查(CURD)
在这个页面里,就实现了增删改查4个功能,点击demo查看:demo。
35 0
java数组的增删改查CURD操作
java数组的增删改查CURD操作
18 0
单链表的增删改查等操作(C++语言)
单链表的增删改查等操作(C++语言)
10 0
java实现遍历树形菜单方法——数据库表的创建
java实现遍历树形菜单方法——数据库表的创建
41 0
curd 操作| 学习笔记
快速学习 curd 操作。
25 0
DOM操作之CRUD操作
1.append():父元素将子元素追加到末尾 对象1.append(对象2):将对象2添加到对象1元素内部,并且在尾部 2.prepend():父元素将子元素追加到开头 对象1.prepend(对象2):将对象2添加到对象1元素内部,并且在开头 3.appendTo(): 对象1.appendTo(对象2):将对象1添加到对象2内部,并且在尾部 4.prependTo(): 对象1.prependTo(对象2):将对象1添加到对象2内部,并且在开头 5.after():添加元素到元素后面 对象1.after(对象2):将对象2添加到对象1后面。对象1和对象2是兄弟关系
17 0
dom4j 里面封装方法的操作| 学习笔记
快速学习 dom4j 里面封装方法的操作。
34 0
使用 dom4j 实现修改的操作| 学习笔记
快速学习使用 dom4j 实现修改的操作。
65 0
WebApi入门第七章(dom增删改页面元素)
WebApi入门第七章(dom增删改页面元素)
26 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载