文章目录
四、JavaScript实战(上)
(一)Web APIs 简介
1、Web APIs主要学DOM和BOM,是js的应用
Web API 是浏览器提供的一套操作浏览器功能和页面元素的API(BOM 和 DOM)。
(二)DOM
文档对象模型(DOM),其实是一些接口,通过这些接口可以改变页面的结构、内容和样式。
文档:一个页面就是一个文档,DOM使用document表示
1、获取元素
1.1 根据ID获取
使用 getElementById() 来使用.
<!-- 根据ID获取元素 -->
<!-- <div id="time">2021-11-14</div>
<script>
// 文档页面从上往下加载,所以先得有标签,所以script写到标签的下面
var timee = document.getElementById('time');
console.log(timee);
// 可以打印我们返回的元素对象,更好地查看属性和方法
console.dir(timee);
</script> -->
1.2 根据标签名获取
使用 getElementsByName() 来使用
<!-- 根据标签名获取 -->
<ul>
<li>你好你好1</li>
<li>你好你好2</li>
<li>你好你好3</li>
<li>你好你好4</li>
<li>你好你好5</li>
</ul>
<script>
// 返回的是 获取过来元素对象的集合,以伪数组的形式存储的
var lis = document.getElementsByName('li');
console.log(lis);
console.log(lis[0]);
// 我们想要依次打印里面的元素对象,我们可以采取遍历的方式
for(var i = 0; i < lis.length;i++){
console.log(lis[i]);
}
</script>
伪数组的概念:伪数组我们可以理解为类似数组的一个集合,我们常见的有俩个,一个是arguments还有一个是DOM的children属性,获取回来的子节点集合。他们与数组一样,具有索引(下标)和length属性。
还可以获取某个元素(父元素)内部所有指定标签的子元素
<ul>
<li>你好你好1</li>
<li>你好你好2</li>
<li>你好你好3</li>
<li>你好你好4</li>
<li>你好你好5</li>
</ul>
<ol id="ol">
<li>你好比哈</li>
<li>你好比哈</li>
<li>你好比哈</li>
<li>你好比哈</li>
<li>你好比哈</li>
</ol>
<script>
var oll = document.getElementById('ol');
console.log(oll.getElementsByTagName('li'));
</script>
1.3 H5新增获取元素方式
getElementByClassName() 通过类名来获取元素集合,其返回值是一个数组。
<!-- 通过类名来获取元素集合 -->
<div class="box">我是一个盒子</div>
<div class="box">我是第二个盒子</div>
<script>
var box = document.getElementsByClassName('box');
console.log(box);
</script>
querySelector() 返回指定选择器的第一元素对象
<div class="box">我是一个盒子</div>
<div class="box">我是第二个盒子</div>
<div id="hello">我是第nnnn个盒子</div>
<script>
var box = document.getElementsByClassName('box');
console.log(box);
// querySelector()
var firstBox = document.querySelector('.box');
var hello = document.querySelector('#hello');
</script>
querySelectorAll() 返回指定选择器的所有元素集合
// querySelectorAll()
var boxs = document.querySelectorAll('.box');
console.log(boxs);
1.4 获取body 元素 和 获取html元素
获取body: document.body //返回body元素对象
获取html: document.documentElement //返回html元素对象
2、事件概述
javaScript使我们有能力创建动态页面,而事件是可以被JavaScript检测到的行为
简单理解为:触发——>响应机制 例如:点击按钮,换图片
事件三要素:事件源、事件类型、事件处理程序
2.1 事件源
事件被触发的对象 eg:按钮
var btn = document.getElementById('btn');
2.2 事件类型
如何触发 什么事件 eg:鼠标点击(onclick)还是鼠标经过还是鼠标按下
2.3 事件处理程序
通过一个函数赋值的方式完成
//事件源:按钮
//事件类型:点击
//事件处理程序:通过一个函数,它的作用是弹出一个对话框
btn.onclick = function(){
alert('点秋香');
}
2.4 执行事件的步骤
1、获取元素
2、绑定事件(注册事件),程序处理
<div>123</div>
<script>
// 执行事件步骤
// 点击div,控制台输出:我被选中了
//1 获取事件源
var div = document.querySelector('div');
//2 绑定事件
// div.onclick
//3.添加事件处理程序
div.onclick = function(){
console.log('我被选中了');
}
</script>
3、案例:改变元素内容
element.innerText
从起始位置到终止位置的内容,但它去除html标签,同时空格和换行也会去掉。
注意:innerText 不识别html标签,非标准,一般都用innerHTML
<button>显示当前系统时间</button>
<div>某个时间</div>
<p>12346</p>
<script>
//当我们点击了按钮,div里面的文字会发生变化
//1、获取元素
var button = document.querySelector('button');
var div = document.querySelector('div');
//2、注册事件
button.onclick = function () {
div.innerText = getDate();
}
function getDate() {
//案例,今天的日期
var date = new Date();
var year = date.getFullYear();
var month = date.getMonth() + 1;
var dates = date.getDate();
var arr = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
var day = date.getDate();
return '今天是:' + year + '年' + month + '月' + dates + '日 ' + arr[day];
}
//元素可以不用添加事件
var P = document.querySelector('p');
p.innerText = getDate();
</script>
element.innerHTML
起始位置到终止位置的全部内容,包括html标签,同时保留空格和换行。
注意:识别HTML标签,W3C标准
4、操作元素
4.1 修改元素属性
案例1:通过点击按钮,实现刘德华与张学友图片的转换
<div>
<button id="ldh">刘德华</button>
<button id="zxy">张学友</button>
</div>
<img src="img/liu.jpg" alt="" title="刘德华">
<script>
//修改元素属性
var ldh = document.getElementById('ldh');
var zxy = document.getElementById('zxy');
var img = document.querySelector('img');
//注册事件,处理程序
zxy.onclick = function () {
img.src = 'img/zhang.jpg';
img.title = '张学友';
}
ldh.onclick = function () {
img.src = 'img/liu.jpg';
img.title = '刘德华';
}
</script>
案例2:分时显示不同图片,显示不同问候语
根据不同时间,页面显示不同图片,同时显示不同的问候语
<!-- 分时显示不同图片,显示不同问候语案例 -->
<img src="img/swh.jpg" alt="">
<div>上午好</div>
<script>
// 1、获取元素
var img = document.querySelector('img');
var div = document.querySelector('div');
// 2、得到当前的小时数
var data = new Date();
var h = data.getHours();
//判断小时数,改变图片和文字信息
if(h < 12){
img.src = 'img/swh.jpg';
div.innerHTML = '上午好,好好学习';
}else if(h < 18){
img.src = 'img/zwh.jpg';
div.innerHTML = '中午好,好好学习';
}else{
img.src = 'img/wsh.jpg';
div.innerHTML = '晚上好,好好学习啊';
}
</script>
4.2 修改表单属性
表单里面的内容,是通过 value 属性来修改的
<button>按钮</button>
<input type="text" name="" id="" value="输入内容">
<script>
// 1、获取元素
var btn = document.querySelector('button');
var input = document.querySelector('input');
// 2、注册事件,处理程序
btn.onclick = function () {
// input.onclick = '点击了' 这样不行,得通过value来修改
input.value = '被点击了';
//input.disabled = true; 点击完一次就不能再点击了
this.disabled = true; //this 指向的是事件函数的调用者
}
</script>
4.2.1 表单元素的属性操作
仿京东显示密码的案例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>显示密码案例</title>
<style>
.box {
position: relative;
width: 400px;
border: 1px solid #ccc;
margin: 100px auto;
height: 44px;
}
.box input {
width: 370px;
height: 30px;
border: 0;
outline: none;
margin-top: 6px;
}
.box img {
position: absolute;
top: 10px;
right: 10px;
width: 24px;
height: 24px;
}
</style>
</head>
<body>
<div class="box">
<label>
<img src="img/yanjing1.png" id="eye">
</label>
<input type="password" id="pwd">
</div>
<script>
// 1、获取元素
var eye = document.getElementById('eye');
var pwd = document.getElementById('pwd');
// 2、绑定事件,处理程序
var flag = 0;
eye.onclick = function () {
//点击了一次之后,flag一定要变化
if (flag == 0) {
pwd.type = 'text';
eye.src = 'img/yanjing2.png';
flag = 1;
} else {
pwd.type = 'password';
eye.src = "img/yanjing1.png";
flag = 0;
}
}
</script>
</body>
</html>
4.3 修改样式属性
elemnet.style 行内样式操作 适用于修改的属性少的情况
element.className 类名样式操作 eg:this.className = ‘change’ ; 让我们当前元素的类名改为了 change,适合于样式较多或者功能复杂的情况。 className 会直接更改元素的类名,会覆盖原先的类名。 如果想要保留原先类名,可以这么做:
first 表示原先的类名,change表示更改后的类名
this.className = 'first change' //多类名选择器
JS修改 style 样式操作,产生的是行内样式,CSS权重比较高
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>修改样式</title>
<style>
div {
width: 200px;
height: 200px;
background-color: pink;
}
</style>
</head>
<body>
<div></div>
<script>
//通过点击div,让它换颜色
// 1、获取元素
var div = document.querySelector('div');
// 2、注册事件,处理程序
div.onclick = function () {
//this 指向函数的调用者
this.style.backgroundColor = 'purple';
}
</script>
</body>
</html>
4.4 总结
5、案例
5.1 案例1:关闭二维码
点击关闭按钮时,二维码的属性 display 为 none;
5.2 案例2:显示隐藏文本框的内容
onfocus 获得焦点事件
onblur 失去焦点事件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>显示隐藏文本框的内容</title>
<style>
input {
color: #999;
}
</style>
</head>
<body>
<input type="text" value="手机">
<script>
// 1.获取元素
var text = document.querySelector('input');
// 2.注册事件 获得焦点事件 onfocus
text.onfocus = function() {
// console.log('得到了焦点');
if (this.value === '手机') {
this.value = '';
}
// 获得焦点需要把文本框里面的文字颜色变黑
this.style.color = '#333';
}
// 3. 注册事件 失去焦点事件 onblur
text.onblur = function() {
// console.log('失去了焦点');
if (this.value === '') {
this.value = '手机';
}
// 失去焦点需要把文本框里面的文字颜色变浅色
this.style.color = '#999';
}
</script>
</body>
</html>
5.3 案例3:密码框验证信息
this.value.length 所调用的input标签输入框里所需要输入的长度
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<