阶段三 Web APIs -day 1

1. DOM 简介

1.1 什么是 DOM

文档对象模型(Document Object Model,简称 DOM),是 W3C 组织推荐的处理可扩展标记语言(HTML
或者XML)的标准编程接口。

W3C 已经定义了一系列的 DOM 接口,通过这些 DOM 接口可以改变网页的内容、结构和样式。

1.2 DOM 树

  • 文档:一个页面就是一个文档,DOM 中使用 document 表示

  • 元素:页面中的所有标签都是元素,DOM 中使用 element 表示

  • 节点:网页中的所有内容都是节点(标签、属性、文本、注释等),DOM 中使用 node 表示DOM 把以上内容都看做是对象

2.获取元素

DOM在我们实际开发中主要用来操作元素。

我们如何来获取页面中的元素呢?

2.1 如何获取页面元素

获取页面中的元素可以使用以下几种方式:

  • 根据 ID 获取
  • 根据标签名获取
  • 通过 HTML5 新增的方法获取
  • 特殊元素获取

2. 获取元素

2.2 根据 ID 获取

使用 getElementById() 方法可以获取带有 ID 的元素对象。

document.getElementById('id');

使用 console.dir() 可以打印我们获取的元素对象,更好的查看对象里面的属性和方法。

<body>
    <div id="time">2021-5-26</div>
    <script>
        // 1.因为我们文档页面从上往下加载,所以先得有标签 所以我们把script标签写在下面
        // 2.get 获得 element 元素 by 通过 驼峰命名法
        // 3.参数 id 是大小写敏感的字符串
        // 4.返回的是一个元素对象
        var timer = document.getElementById('time');
        console.log(timer);     //<div id="time">2021-5-26</div>
        console.log(typeof timer);  //object
        // 5.console.dir    打印我们返回的元素对象 更好的查看里面的属性和方法
        console.dir(timer);     // div#time
    </script>
</body>
 

2.3 根据标签名获取

使用 getElementsByTagName( ) 方法可以返回带有指定标签名的对象的集合。

document.getElementsByTagName('标签名');

注意:

  1. 因为得到的是一个对象的集合,所以我们想要操作里面的元素就需要遍历。

  2. 得到元素对象是动态的

  3. 如果获取不到元素,则返回为空的伪数组(因为获取不到对象)

<body>
<ul>
<li>知否知否,应是1234</li>
<li>知否知否,应是1234</li>
<li>知否知否,应是1234</li>
<li>知否知否,应是1234</li>
<li>知否知否,应是1234</li>
</ul>
<ul id="nav">
<li>skr~</li>
<li>skr~</li>
<li>skr~</li>
<li>skr~</li>
<li>skr~</li>
</ul>
<script>
// 1.返回的是 获取过来元素对象的集合 以伪数组的形式储存的
var lis = document.getElementById('li');
console.log(lis);
console.log(lis[0]);
// 2.我们想要一次打印里面的元素对象 我们可以采取遍历的方式
for(var i = 0; i < lis.length; i++){
console.log(lis[i]);
}
// 3. element.getElementsByTagName() 可以得到这个元素里面的某种标签
var nav = document.getElementById('nav'); //获得nav元素
var navLis = nav.getElementsByTagName('li');
console.log('navLis');
</script>
</body>

2.4 通过 HTML5 新增的方法获取

  1. document.getElementsByClassName(‘类名’);// 根据类名返回元素对象集合
  1. document.querySelector(‘选择器’); // 根据指定选择器返回第一个元素对象
  1. document.querySelectorAll(‘选择器’);// 根据指定选择器返回

注意:

querySelector 和 querySelectorAll里面的选择器需要加符号,比如:document.querySelector('#nav');

2.5 获取特殊元素(body,html)

获取body元素

  1. doucumnet.body // 返回body元素对象

获取html元素

  1. document.documentElement // 返回html元素对象
<script>
// 1.获取body 元素
var bodyEle = document.body;
console.log(bodyEle);
console.dir(bodyEle);
// 2.获取html 元素
// var htmlEle = document.html;
var htmlEle = document.documentElement;
console.log(htmlEle);
</script>

3. 事件基础

3.1 事件概述

JavaScript 使我们有能力创建动态页面,而事件是可以被 JavaScript 侦测到的行为。
简单理解: 触发— 响应机制。
网页中的每个元素都可以产生某些可以触发 JavaScript 的事件,例如,我们可以在用户点击某按钮时产生一个
事件,然后去执行某些操作。

3.2 事件三要素

  1. 事件源 (谁)
  2. 事件类型 (什么事件)
  3. 事件处理程序 (做啥)

案例:点击按钮弹出警示框
页面中有一个按钮,当鼠标点击按钮的时候,弹出“你好”警示框。

image.png

案例分析

① 获取事件源(按钮)

② 注册事件(绑定事件),使用 onclick

③ 编写事件处理程序,写一个函数弹出 alert 警示框

实现代码

var btn = document.getElementById('btn'); btn.onclick = function() { alert('你好吗'); };

<body>
<button id="btn">唐伯虎</button>
<script>
// 点击一个按钮,弹出对话框
// 1. 事件是有三部分组成  事件源  事件类型  事件处理程序   我们也称为事件三要素
//(1) 事件源 事件被触发的对象   谁  按钮
var btn = document.getElementById('btn');
//(2) 事件类型  如何触发 什么事件 比如鼠标点击(onclick) 还是鼠标经过 还是键盘按下
//(3) 事件处理程序  通过一个函数赋值的方式 完成
btn.onclick = function() {
alert('点秋香');
}
</script>
</body>

3.3 执行事件的步骤

  1. 获取事件源
  2. 注册事件(绑定事件)
  3. 添加事件处理程序(采取函数赋值形式)
<body>
<div>123</div>
<script>
// 执行事件步骤
// 点击div 控制台输出 我被选中了
// 1. 获取事件源
var div = document.querySelector('div');
// 2.绑定事件 注册事件
// div.onclick 
// 3.添加事件处理程序 
div.onclick = function() {
console.log('我被选中了');
}
</script>
</body>

3.3 常见的鼠标事件

image.png

3.4 分析事件三要素

下拉菜单三要素

关闭广告三要素

4. 操作元素

JavaScript 的 DOM 操作可以改变网页内容、结构和样式,我们可以利用 DOM 操作元素来改变元素里面的内容 、属性等。注意以下都是属性

<body>
<button>显示当前系统时间</button>
<div>某个时间</div>
<p>1123</p>
<script>
// 当我们点击了按钮,  div里面的文字会发生变化
// 1. 获取元素 
var btn = document.querySelector('button');
var div = document.querySelector('div');
// 2.注册事件
btn.onclick = function() {
// div.innerText = '2019-6-6';
div.innerHTML = getDate();
}
function getDate() {
var date = new Date();
// 我们写一个 2019年 5月 1日 星期三
var year = date.getFullYear();
var month = date.getMonth() + 1;
var dates = date.getDate();
var arr = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
var day = date.getDay();
return '今天是:' + year + '年' + month + '月' + dates + '日 ' + arr[day];
}
// 我们元素可以不用添加事件
var p = document.querySelector('p');
p.innerHTML = getDate();
</script>
</body>

4.1 改变元素内容

element.innerText
从起始位置到终止位置的内容, 但它去除 html 标签, 同时空格和换行也会去掉
element.innerHTML
起始位置到终止位置的全部内容,包括 html 标签,同时保留空格和换行

<body>
<div></div>
<p>
我是文字
<span>123</span>
</p>
<script>
// innerText 和 innerHTML的区别 
// 1. innerText 不识别html标签 非标准  去除空格和换行
var div = document.querySelector('div');
// div.innerText = '<strong>今天是:</strong> 2019';
// 2. innerHTML 识别html标签 W3C标准 保留空格和换行的
div.innerHTML = '<strong>今天是:</strong> 2019';
// 这两个属性是可读写的  可以获取元素里面的内容
var p = document.querySelector('p');
console.log(p.innerText);  
console.log(p.innerHTML);
</script>
</body>

4.2 常用元素的属性操作

  1. innerText、innerHTML 改变元素内容
  2. src、href
  3. id、alt、title

案例: 分时显示不同图片,显示不同问候语
根据不同时间,页面显示不同图片,同时显示不同的问候语。
如果上午时间打开页面,显示上午好,显示上午的图片。
如果下午时间打开页面,显示下午好,显示下午的图片。
如果晚上时间打开页面,显示晚上好,显示晚上的图片。

案例分析

① 根据系统不同时间来判断,所以需要用到日期内置对象

② 利用多分支语句来设置不同的图片

③ 需要一个图片,并且根据时间修改图片,就需要用到操作元素src属性

④ 需要一个div元素,显示不同问候语,修改元素内容即可

<style>
img {
width: 300px;
}
</style>
</head>
<body>
<img src="images/s.gif" alt="">
<div>上午好</div>
<script>
// 根据系统不同时间来判断,所以需要用到日期内置对象
// 利用多分支语句来设置不同的图片
// 需要一个图片,并且根据时间修改图片,就需要用到操作元素src属性
// 需要一个div元素,显示不同问候语,修改元素内容即可
// 1.获取元素
var img = document.querySelector('img');
var div = document.querySelector('div');
// 2. 得到当前的小时数
var date = new Date();
var h = date.getHours();
// 3. 判断小时数改变图片和文字信息
if (h < 12) {
img.src = 'images/s.gif';
div.innerHTML = '亲,上午好,好好写代码';
} else if (h < 18) {
img.src = 'images/x.gif';
div.innerHTML = '亲,下午好,好好写代码';
} else {
img.src = 'images/w.gif';
div.innerHTML = '亲,晚上好,好好写代码';
}
</script>
</body>
 

4.3 表单元素的属性操作

利用 DOM 可以操作如下表单元素的属性:
type、value、checked、selected、disabled

案例:仿京东显示密码
点击按钮将密码框切换为文本框,并可以查看密码明文。

image.png

案例分析

① 核心思路: 点击眼睛按钮,把密码框类型改为文本框就可以看见里面的密码

② 一个按钮两个状态,点击一次,切换为文本框,继续点击一次切换为密码框

③ 算法:利用一个flag变量,来判断flag的值,如果是1 就切换为文本框,flag 设置为0,如
果是0 就切换为密码框,flag设置为1

    <style>
.box {
position: relative;
width: 400px;
border-bottom: 1px solid #ccc;
margin: 100px auto;
}
.box input {
width: 370px;
height: 30px;
border: 0;
outline: none;
}
.box img {
position: absolute;
top: 2px;
right: 2px;
width: 24px;
}
</style>
</head>
<body>
<div class="box">
<label for="">
<img src="images/close.png" alt="" id="eye">
</label>
<input type="password" name="" 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 = 'images/open.png';
flag = 1; // 赋值操作
} else {
pwd.type = 'password';
eye.src = 'images/close.png';
flag = 0;
}
}
</script>
</body>

4.4 样式属性操作

我们可以通过 JS 修改元素的大小、颜色、位置等样式。

  1. element.style 行内样式操作
  2. element.className 类名样式操作
    <style>
div {
width: 200px;
height: 200px;
background-color: pink;
}
</style>
</head>
<body>
<div></div>
<script>
// 1. 获取元素
var div = document.querySelector('div');
// 2. 注册事件 处理程序
div.onclick = function() {
// div.style里面的属性 采取驼峰命名法 
this.style.backgroundColor = 'purple';
this.style.width = '250px';
}
</script>
</body>

注意:

1.JS 里面的样式采取驼峰命名法 比如 fontSize、 backgroundColor

2.JS 修改 style 样式操作,产生的是行内样式,CSS 权重比较高

原创文章,作者:我心飞翔,如若转载,请注明出处:https://www.pipipi.net/14804.html

发表评论

登录后才能评论