菜鸟看前端(js获取DOM)

什么是DOM

JavaScript操作网页的接口,全称为“文档对象模型(Document Object Model)。 有这几个概念:文档、元素、节点
整个文档是一个文档节点
每个标签是一个元素节点
包含在元素中的文本是文本节点
元素上的属性是属性节点
文档中的注释是注释节点

DOM树

DOM树是结构,树是由DOM元素和属性节点组成的,DOM的本质是把html结构化成js可以识别的树模型;
有了树模型,就有了层级结构,层级结构是指元素和元素之间的关系父子,兄弟。

dom树如一个倒长的树

js获取DOM

	<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style type="text/css">
			
		
		
		</style>
	</head>
	<body>	
		<div id="box">
			<div class="item">
				<span>span1</span>
				<span>span2</span>
				<input type="text" name="text" value="我是input"/>
			</div>
			<div class="item">
				
			</div>
		</div>
	
	</body>
	<script type="text/javascript">
	
		
		// 获取html
		let html = document.documentElement 
		console.log(html)
		
		// 获取<body>
		let body = document.body
		console.log(body)
	
		// 获取样式表
		let style = document.styleSheets
		console.log(style)
		
		// 通过id获取
		let box = document.getElementById('box')
		console.log(box)
		
		// 通过clsaa获取dom元素
		let item = document.getElementsByClassName('item')[0]
		console.log(item)
		
		// 通过标签名获取dom元素
		let span1 = document.getElementsByTagName('span')[0]
		console.log(span1)
		
		// 通过name属性获取dom元素
		let input = document.getElementsByName('text')
		console.log(input)
		
		// 通过querySelector获取dom
		let box1 = document.querySelector('#box')
		console.log(box1)
		
		// 通过querySelectorAll获取dom
		let Span =  document.querySelectorAll('span')
		console.log(Span)
		
	
	</script>
</html>

在这里插入图片描述

简单添加删除

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<input type="text" /><button type="button">添加</button>
		<ul>

		</ul>
	</body>
	<script type="text/javascript">
		// 获取元素
		let btn = document.querySelector('button')
		let ul = document.querySelector('ul')
		let txt = document.getElementsByTagName('input')[0]
		// console.log(txt[0])
		// console.log(btn)
		btn.onclick = function() {
			let value = txt.value
			// 创建li
			let li = document.createElement('li')
			li.innerHTML = `
				<li>${value}<buttton class="del" οnclick="del(this)">删除</buttton></li>
		`
			ul.appendChild(li)
		}
		// 删除事件
		function del(ele) {
			ele.parentNode.parentNode.remove();

			console.log(ele)
		}
	</script>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值