DOM (文档对象模型),简单来说就是当网页被加载时,浏览器会为整个网页创建一个对象document
1、查找元素
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
</head>
<body>
<p id="p1">第一个段落标签</p>
<p id="p2">第二个段落标签</p>
<script type="text/javascript">
var p1 = document.getElementById("p1");
console.log(p1);
</script>
</body>
</html>
网页输出:
data:image/s3,"s3://crabby-images/ebfb7/ebfb75c1563f615344bd526b76fd49c49d3c86ff" alt=""
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
window.onload = function() {
var p1 = document.getElementById("p2");
console.log(p1);
}
</script>
</head>
<body>
<p id="p1">第一个段落标签</p>
<p id="p2">第二个段落标签</p>
</body>
</html>
2、查找多个元素
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
window.onload = function() {
var p1 = document.getElementsByClassName("p1");
console.log("数组长度为:"+p1.length);
for(var i=0;i<p1.length;i++)
{
console.log("分割线-----------");
console.log(p1[i]);
}
}
</script>
</head>
<body>
<p class="p1">第一个段落标签</p>
<p class="p1">第二个段落标签</p>
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/245c8/245c886de6002654b35fd906782f3d1fe28944f5" alt=""
3、操作css
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<style type="text/css">
#p1{
width: 100px;
height: 100px;
border: dashed red ;
}
</style>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
window.onload = function() {
var p2=document.getElementById("p2");
//注意css属性要全部用双引号引起来
p2.style.width="200px";
p2.style.height="100px";
p2.style.border="dotted blue"
}
</script>
</head>
<body>
<p id="p1">第一个段落标签</p>
<p id="p2">第二个段落标签</p>
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/a3de6/a3de69b9a955c81de9108d0bfd294cddf63ea9d5" alt=""
4、innerHTML、innerText
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<style type="text/css">
#p1{
width: 100px;
height: 100px;
border: dashed red ;
}
</style>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
window.onload = function() {
var p1=document.getElementById("p1");
console.log(p1.innerText);
console.log(p1.innerHTML);
}
</script>
</head>
<body>
<p id="p1">
第一个段落标签
<font color="antiquewhite">
颜色变啦
<a href="http://www.baidu.com">跳转</a>
</font>
</p>
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/57af6/57af6af862e31c8817817015314bc8521886fb47" alt=""
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<style type="text/css">
#p1{
width: 100px;
height: 100px;
border: dashed red ;
}
</style>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
window.onload = function() {
var p1=document.getElementById("p1");
p1.innerHTML="<font color='antiquewhite'>颜色变啦 <a href='http://www.baidu.com'>跳转</a></font>"
console.log(p1);
}
</script>
</head>
<body>
<p id="p1">
</p>
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/08d50/08d50f380f1be8db65380ee6da6db8b95b24689a" alt=""
5、设置属性、获取属性
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<style type="text/css">
#p1{
width: 100px;
height: 100px;
border: dashed red ;
}
</style>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
window.onload = function() {
var p1=document.getElementById("input1");
console.log(p1.type);
console.log(p1.value);
}
</script>
</head>
<body>
<input id="input1" type="button" value="点击" />
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/ea6fd/ea6fdd72cdccb85433b79966d83d240e588e9267" alt=""
如果这个属性是我们自己定义的就不能这么用了
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<style type="text/css">
#p1{
width: 100px;
height: 100px;
border: dashed red ;
}
</style>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
window.onload = function() {
var p1=document.getElementById("input1");
console.log(p1.type);
console.log(p1.getAttribute("city"));
//也可以设置属性
p1.setAttribute("city","上海");
p1.setAttribute("address","市中心");
}
</script>
</head>
<body>
<input id="input1" type="button" value="点击" city="北京"/>
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/d053b/d053b526c97e793daafca0ffe2b2cc3437ca829d" alt=""
html中的属性也可以被修改
data:image/s3,"s3://crabby-images/fbb58/fbb58a13f67aae0ebcafe60611167dc9ddb261cd" alt=""
6、文本事件
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
function onfocusFn()
{
console.log("元素获取到焦点了")
}
function onblurFn()
{
console.log("元素失去焦点了")
}
</script>
</head>
<body>
用户名:<input id="username" type="text" placeholder="请输入用户名" onfocus="onfocusFn()" onblur="onblurFn()"/>
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/f9523/f95234cc28ad28c3131093e3205b86d8e39dbeb2" alt=""
7、form表单 submit一点问题
看下这段代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
function checkValue()
{
var username=document.getElementById("username");
console.log(username.value);
if(username.value=="zhangsan")
{
console.log("输入不合法");
alert("输入不合法");
return false;
}
else{
return true;
}
}
</script>
<style type="text/css">
</style>
</head>
<body>
<form action="" method="get" onsubmit="return checkValue()">
用户名:<input id="username" name="username" type="text" placeholder="请输入用户名"/></br>
<input type="submit" value="注册"/>
</form>
</body>
</html>
注意下form标签的onsubmit属性
onsubmit="return checkValue()"
在submit提交时,如果onsubmit属性的值是"return true"则会提交,如果onsubmit属性的值是"return false",则不会提交
例如上面的代码中我们需要在提交前检验输入的合法性,如果用户名是"zhangsan"就不让提交
网页显示:
data:image/s3,"s3://crabby-images/ede7b/ede7b67e11d1a544a52da55351f034083b9e5438" alt=""
8、下拉列表 onchange事件
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
function onchangeFn()
{
var tag=document.getElementById("city");
console.log(tag.value);
}
</script>
<style type="text/css">
</style>
</head>
<body>
<select id="city" onchange="onchangeFn()">
<option value="bj">北京</option>
<option value="sh">上海</option>
<option value="sz">深圳</option>
</select>
</body>
</html>
网页显示:
data:image/s3,"s3://crabby-images/73cb6/73cb6c65a69075ecbd6beb51c9a05ac0bf23c4f6" alt=""
还有一种简单写法:我们可以直接把当前元素作为参数传递给方法
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>网页的标题</title>
<!--如果js中要操作的元素位于js代码块的后面,需要这么写-->
<script type="text/javascript">
function onchangeFn(obj)
{
console.log(obj.value);
}
</script>
<style type="text/css">
</style>
</head>
<body>
<select id="city" onchange="onchangeFn(this)">
<option value="bj">北京</option>
<option value="sh">上海</option>
<option value="sz">深圳</option>
</select>
</body>
</html>
网友评论