10 关于DOM的操作
一、JavaScript的组成
JavaScript基础分为三个部分:
ECMAScript:JavaScript的语法标准。包括变量、表达式、运算符、函数、if语句、for语句等。
DOM:文档对象模型,操作网页上的元素的API。比如让盒子移动、变色、轮播图等。
BOM:浏览器对象模型,操作浏览器部分功能的API。比如让浏览器自动滚动。
二、事件
- JS是以事件驱动为核心的一门语言。
事件的三要素
事件的三要素:事件源、事件、事件驱动程序。
比如,我用手去按开关,灯亮了。这件事情里,事件源是:手。事件是:按开关。事件驱动程序是:灯的开和关。
再比如,网页上弹出一个广告,我点击右上角的X
,广告就关闭了。这件事情里,事件源是:X
。事件是:onclick。事件驱动程序是:广告关闭了。
于是我们可以总结出:谁引发的后续事件,谁就是事件源。
总结如下:
事件源:引发后续事件的html标签。
事件:js已经定义好了(见下图)。
事件驱动程序:对样式和html的操作。也就是DOM。
代码书写步骤如下:(重要)
(1)获取事件源:document.getElementById(“box”); //类似与ios语言的 UIButton *adBtn = [UIButton buttonWithType:UIButtonTypeCustom];
(2)绑定事件: 事件源box.事件onclick = function(){ 事件驱动程序 };
(3)书写事件驱动程序:关于DOM的操作
代码举例:

- <body>
- <div id="box1"></div>
- <script type="text/javascript">
- // 1、获取事件源
- var div = document.getElementById("box1");
- // 2、绑定事件
- div.onclick = function () {
- // 3、书写事件驱动程序
- alert("我是弹出的内容");
- }
- </script>
- </body>

常见事件如下:
下面针对这事件的三要素,进行分别介绍。
1、获取事件源的方式(DOM节点的获取)
获取事件源的常见方式如下:
1
2
3
4
5
|
var div1 = document.getElementById( "box1" ); //方式一:通过id获取单个标签 var arr1 = document.getElementsByTagName( "div1" ); //方式二:通过 标签名 获得 标签数组,所以有s var arr2 = document.getElementsByClassName( "hehe" ); //方式三:通过 类名 获得 标签数组,所以有s |
2、绑定事件的方式
方式一:直接绑定匿名函数

- <div id="box1" ></div>
- <script type="text/javascript">
- var div1 = document.getElementById("box1");
- //绑定事件的第一种方式
- div1.onclick = function () {
- alert("我是弹出的内容");
- }
- </script>

方式二:先单独定义函数,再绑定

- <div id="box1" ></div>
- <script type="text/javascript">
- var div1 = document.getElementById("box1");
- //绑定事件的第二种方式
- div1.onclick = fn; //注意,这里是fn,不是fn()。fn()指的是返回值。
- //单独定义函数
- function fn() {
- alert("我是弹出的内容");
- }
- </script>

注意上方代码的注释。绑定的时候,是写fn,不是写fn()。fn代表的是整个函数,而fn()代表的是返回值。
方式三:行内绑定

- <!--行内绑定-->
- <div id="box1" onclick="fn()"></div>
- <script type="text/javascript">
- function fn() {
- alert("我是弹出的内容");
- }
- </script>

注意第一行代码,绑定时,是写的"fn()"
,不是写的"fn"
。因为绑定的这段代码不是写在js代码里的,而是被识别成了字符串。
3、事件驱动程序
我们在上面是拿alert举例,不仅如此,我们还可以操作标签的属性和样式。举例如下:

- <style>
- #box {
- width: 100px;
- height: 100px;
- background-color: pink;
- cursor: pointer;
- }
- </style>
- </head>
- <body>
- <div id="box" ></div>
- <script type="text/javascript">
- var oDiv = document.getElementById("box");
- //点击鼠标时,原本粉色的div变大了,背景变红了
- oDiv.onclick = function () {
- oDiv.style.width = "200px"; //属性值要写引号
- oDiv.style.height = "200px";
- oDiv.style.backgroundColor = "red"; //属性名是backgroundColor,不是background-Color
- }
- </script>

上方代码的注意事项:
- 在js里写属性值时,要用引号
- 在js里写属性名时,是
backgroundColor
,不是CSS里面的background-Color
。记得所有的像css属性的text-*,line-*、backgroun-*等在js中都写成驼峰
onload事件
当页面加载(文本和图片)完毕的时候,触发onload事件。
举例:
- <script type="text/javascript">
- window.onload = function () {
- console.log("小马哥"); //等页面加载完毕时,打印字符串
- }
- </script>
有一点我们要知道:js的加载是和html同步加载的。因此,如果使用元素在定义元素之前,容易报错。这个时候,onload事件就能派上用场了,我们可以把使用元素的代码放在onload里,就能保证这段代码是最后执行。
建议是:整个页面上所有元素加载完毕在执行js内容。所以,window.onload可以预防使用标签在定义标签之前。
事件案例
1、京东顶部广告栏关闭

- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Document</title>
- <style type="text/css">
- *{
- padding: 0;
- margin: 0;
- }
- .top-banner{
- /*position: relative;*/
- background-color: rgb(230, 15, 82);
- }
- .top-banner .w{
- width: 1190px;
- position: relative;
- margin: 0 auto;
- }
- .top-banner .banner{
- display: block;
- width: 100%;
- height: 80px;
- background: url('./close.jpg') no-repeat center 0;
- }
- .top-banner .close{
- position: absolute;
- right: 0;
- top:0;
- text-decoration: none;
- color: white;
- width: 20px;
- height: 20px;
- line-height: 20px;
- text-align: center;
- }
- .hide{
- display: none;
- }
- </style>
- </head>
- <body>
- <div class="top-banner" id="topBanner">
- <div class="w">
- <a href="#" class="banner"></a>
- <a href="#" class="close" id="closeBanner">x</a>
- </div>
- </div>
- <script type="text/javascript">
- // /需求:点击案例,隐藏盒子。
- //思路:点击a链接,让top-banner这个盒子隐藏起来(加隐藏类名)。
- window.onload = function(){
- // /1.获取事件源和相关元素
- var closeBanner = document.getElementById('closeBanner');
- var topBanner = document.getElementById('topBanner');
- //2.绑定事件
- closeBanner.onclick = function(){
- //3.书写事件驱动程序
- //类控制
- //topBanner.className += ' hide';//保留原类名,添加新类名
- //topBanner.className = 'hide';
- //替换旧类名
- topBanner.style.display = 'none';
- }
- }
- </script>
- </body>
- </html>

2.要求实现效果:当鼠标悬停在img上时,更换为另外一张图片;鼠标离开时,还原为本来的图片。

- <!DOCTYPE html>
- <html>
- <head lang="en">
- <meta charset="UTF-8">
- <title></title>
- <script>
- //window.onload页面加载完毕以后再执行此代码
- window.onload = function () {
- //需求:鼠标放到img上,更换为另一张图片,也就是修改路径(src的值)。
- //步骤:
- //1.获取事件源
- //2.绑定事件
- //3.书写事件驱动程序
- //1.获取事件源
- var img = document.getElementById("box");
- //2.绑定事件(悬停事件:鼠标进入到事件源中立即出发事件)
- img.onmouseover = function () {
- //3.书写事件驱动程序(修改src)
- img.src = "image/jd2.png";
- // this.src = "image/jd2.png";
- }
- //1.获取事件源
- var img = document.getElementById("box");
- //2.绑定事件(悬停事件:鼠标进入到事件源中立即出发事件)
- img.onmouseout = function () {
- //3.书写事件驱动程序(修改src)
- img.src = "image/jd1.png";
- }
- }
- </script>
- </head>
- <body>
- <img id="box" src="data:image/jd1.png" style="cursor: pointer;border: 1px solid #ccc;"/>
- </body>
- </html>
10 关于DOM的操作的更多相关文章
- Javascript高级程序设计读书笔记(第10章 DOM)
第10章 DOM 10.1 节点层次 每个节点都有一个nodeType属性,用于表明节点的类型.任何节点类型必是下面中的一个: Node.Element_NODE(1); NODE.ATTRIBUT ...
- VBS脚本和HTML DOM自动操作网页
VBS脚本和HTML DOM自动操作网页 2016-06-16 10:24 1068人阅读 评论(0) 收藏 举报 分类: Windows(42) 版权声明:本文为博主原创文章,未经博主允许不得转 ...
- 10、DOM(文档对象模型)
1.认识DOM html 骨架 css 装修 javascript 物业 ==DOM 打破上述三者的通道.== [注]script标签一般情况下要写在head标签. <div id ...
- 04-老马jQuery教程-DOM节点操作及位置和大小
1. jQuery创建DOM标签 1.1 DOM动态创建标签的方法 DOM时代我们通过document的createElement方法动态创建标签.创建标签后,动态的给他添加属性.例如代码: // 动 ...
- 前端性能优化--为什么DOM操作慢? 浅谈DOM的操作以及性能优化问题-重绘重排 为什么要减少DOM操作 为什么要减少操作DOM
前端性能优化--为什么DOM操作慢? 作为一个前端,不能不考虑性能问题.对于大多数前端来说,性能优化的方法可能包括以下这些: 减少HTTP请求(合并css.js,雪碧图/base64图片) 压缩( ...
- dom事件操作例题,电子时钟,验证码,随机事件
dom事件操作 当事件发生时,可以执行js 例子: 当用户点击时,会改变<h1>的内容: <h1 onClick="this.innerHTML='文本更换'"& ...
- 第10章 DOM
第10章 DOM 10.1 节点层次 10.1.1 Node 类型 10.1.2 Document 类型 10.1.3 Element 类型 10.1.4 Text 类型 10.1.5 Comment ...
- Dom节点操作总结
Dom 一:Dom的概念 Dom的简介: 全称为 document object model 文档对象模型,是操作文档的一整套方法 - 文档 - html,document时一个对象,是dom ...
- 关于DOM的操作以及性能优化问题-重绘重排
写在前面: 大家都知道DOM的操作很昂贵. 然后贵在什么地方呢? 一.访问DOM元素 二.修改DOM引起的重绘重排 一.访问DOM 像书上的比喻:把DOM和JavaScript(这里指ECMScri ...
随机推荐
- CUDA多个流的使用
CUDA中使用多个流并行执行数据复制和核函数运算可以进一步提高计算性能.以下程序使用2个流执行运算: #include "cuda_runtime.h" #include < ...
- css 单选框 样式 填充自定义背景 after
input[type='radio'] //width 16px //height 16px display none //input[type='radio']:chcked // backgoun ...
- repo/git Android/CyanogenMod srouce code
For getting the whole Android/CM rom source code, 1. get the repo first.2. make sure the git is inst ...
- chaos —— 混沌
混沌,一个被严重滥用的物理数学概念. 混沌(chaos)是一个动力学系统(Dynamic System)概念,指的是确定性动力学系统因对初值敏感而表现出的不可预测的.类似随机性的运动. 1. 洛伦兹吸 ...
- the solution about "messy code" in elicpse
I use the Elicpse IDE to develope the ansdroid app.Sometime encounter the messy code in the Elicpse ...
- JavaScript:undefined And null差异
班吃饭的时候,同事偶然问了一个问题:undefined和null究竟有什么差别?无法回答,回去查阅相关文档,算了有了一个了解,做相关的总结.在開始之前,请看例如以下代码,算是抛出这个问题: conso ...
- JS表格各行变色
<head> <title></title> <script type="text/javascript"> ...
- C/C++读写csv文件(用getline探测逗号分隔符)
csv文件其实就是文本文件,每行字段用逗号分隔. 代码 #include <iostream> #include <string> #include <vector> ...
- JPlayer-MP3播放器(带播放列表)
第一篇随笔,写的不好的地方,各位不要见笑.其他的也不多说了,下面是我在工作中用的一个基于JQuery开源的插件,官方地址:http://www.jplayer.org/.先看下要实现的效果图: 首先引 ...
- 图像滤镜艺术---挤压(Pinch)滤镜
原文:图像滤镜艺术---挤压(Pinch)滤镜 Pinch滤镜 Pinch滤镜是通过坐标变换来实现以某个点(cenX,cenY)为中心,某个半径R内图像向其挤压变形的效果.实现这个滤镜的算法很多,主要 ...