浅析javascript中的DOM


Posted in Javascript onMarch 01, 2015

什么是Dom?

1.简介

        文档对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口。Document Object Model的历史可以追溯至1990年代后期微软与Netscape的“浏览器大战”,双方为了在JavaScript与JScript一决生死,于是大规模的赋予浏览器强大的功能。微软在网页技术上加入了不少专属事物,计有VBScript、ActiveX、以及微软自家的DHTML格式等,使不少网页使用非微软平台及浏览器无法正常显示。DOM即是当时蕴酿出来的杰作。

        DOM(文档对象模型)是HTML和XML的应用程序接口(API)。DOM将把整个页面规划成由节点层级构成的文档。

        所谓文档对象模型,其实就是对网页HTML中的各种元素的一种内部的表示,例如HTML中的头、段落、列表、风格、ID等,所有的元素都能通过DOM来访问 。

        JavaScript最终是要操作Html页面,让Html变成DHtml,而操作Html页面就要用到DOM。DOM就是把Html页面模拟成一个对象,如果JavaScript只是执行一些计算、循环等操作,而不能操作Html也就失去了它存在的意义。

        DOM就是Html页面的模型,将每个标签都做为一个对象,JavaScript通过调用DOM中的属性、方法就可以对网页中的文本框、层等元素进行编程控制。比如通过操作文本框的DOM对象,就可以读取文本框中的值、设置文本框中的值。

2.图解

浅析javascript中的DOM

关于window整个页面或者说窗口就是一个window对象---------------window是顶级对象

页面中定义的变量和方法都是window的

window.id

document.getElementById()

使用window对象的属性、方法的时候可以省略window。

比如:

window.alert(‘hello');

可以省略成alert(‘hello');

window.document可以直接写document

能不写window就不要写,这样可以减少js文件的字节数。

window.alert(‘大家好!');//弹出警告对话框

window.confirm(‘确定要删除吗?');//确定、取消对话框,返回true或false;

window.navigate(url);//将网页重新导航到url,支持IE、Opera11.6。并不推荐,有些浏览器不行,

建议使用window.location.href=‘url';//支持大多数浏览器

动态操作DOM元素

1.获取DOM

getElementById(), (非常常用),根据元素的Id获得对象,网页中id不能重复。也可以直接通过元素的id来引用元素,但是有有效范围、

getElementsByName(),根据元素的name获得对象,由于页面中元素的name可以重复,比如多个RadioButton的name一样,因此getElementsByName返回值是对象数组。

getElementsByTagName(),获得指定标签名称的元素数组,比如getElementsByTagName(“input”)可以获得所有的<input>标签。*表示所有标签

2.添加、移除、替换

document.write只能在页面加载过程中才能动态创建。

可以调用document的createElement方法来创建具有指定标签的DOM对象,然后通过调用某个元素的appendChild();方法将新创建元素添加到相应的元素下。//父元素对象.removeChild(子元素对象);删除元素。

createElement(‘element');创建一个节点

appendChild(node); 追加一个节点

removeChild(node);移除一个节点

replaceChild(new,old);替换一个节点

insertBefore(new,参照);把节点加到前面(插到某个节点前面)

方法:

属性:

firstChild

lastChild

3.用innerHTML还是createElement()、appendChild()与removeChild()?

操作页面的元素的时候是用innerHTML的方式还是createElement()、appendChild()与removeChild()的方式?

1.对于大量进行节点操作时,使用innerHTML的方式性能要好于频繁的Dom操作(有专门用C或C++写的html解析器。)。先将页面的HTML代码写好,然后调用一次innerHTML,而不要反复调用innerHTML.

2.对于使用innerHTML=‘'的方式来删除节点,在某些情况下会存在内存问题。比如:div下面有很多其他元素,每个元素都绑定有事件处理程序。此时,innerHTML只是把当前元素从节点树上移除了,但是那些事件处理程序依然占用内存。

js操作样式

修改元素的样式是className属性。

(class是JavaScript的一个保留字,属性不能用关键字、保留字所以就变成className了)网页开关灯的效果。

修改元素的样式不能this.style="background-color:Red"。

单独修改样式的属性使用“style.属性名”。注意在css中属性名在JavaScript中操作的时候属性名可能不一样,主要集中在那些属性名中含有-的属性,因为JavaScript中-是不能做属性、类名的。

操作float样式的时候

IE:obj.style.styleFloat=‘right';

其他浏览器:obj.style.cssFloat=‘right';

Form对象

常用:click(),focus(),blur();//相当于通过程序来触发元素的单击、获得焦点以及失去焦点的事件。

form对象是表单的Dom对象。

方法:submit()提交表单,但是不会触发onsubmit事件。

实现autopost,也就是焦点离开控件以后页面立即提交,而不是只有提交submit按钮以后才提交,当光标离开的时候触发onblur事件,在onblur中调用form的submit方法。

在点击submit后form的onsubmit事件被触发,在onsubmit中可以进行数据校验,如果数据有问题,返回false即可取消提交

以上所述就是个人对于javascript的DOM的理解了,希望大家能够喜欢。

Javascript 相关文章推荐
学习YUI.Ext第七日-View&amp;JSONView Part Two-一个画室网站的案例
Mar 10 Javascript
JQuery 浮动导航栏实现代码
Aug 27 Javascript
jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例
Jun 17 Javascript
AngularJS iframe跨域打开内容时报错误的解决办法
Jan 26 Javascript
JS HTML5拖拽上传图片预览
Jul 18 Javascript
JS闭包与延迟求值用法示例
Dec 22 Javascript
js放大镜放大购物图片效果
Jan 18 Javascript
JS基于onclick事件实现单个按钮的编辑与保存功能示例
Feb 13 Javascript
vue用addRoutes实现动态路由的示例
Sep 15 Javascript
JavaScript实现数值自动增加动画
Dec 28 Javascript
vue中$set的使用(结合在实际应用中遇到的坑)
Jul 10 Javascript
让你30分钟快速掌握vue3教程
Oct 26 Javascript
javascript中的正则表达式使用指南
Mar 01 #Javascript
JQuery中使文本框获得焦点的方法实例分析
Feb 28 #Javascript
jQuery实现折线图的方法
Feb 28 #Javascript
js中split和replace的用法实例
Feb 28 #Javascript
jQuery实现菜单感应鼠标滑动动画效果的方法
Feb 28 #Javascript
js实现完全自定义可带多级目录的网页鼠标右键菜单方法
Feb 28 #Javascript
js实现同一页面可多次调用的图片幻灯切换效果
Feb 28 #Javascript
You might like
关于session在PHP5的配置文件中的详细设置参数说明
2011/04/20 PHP
php提取微信账单的有效信息
2018/10/01 PHP
php设计模式之职责链模式实例分析【星际争霸游戏案例】
2020/03/27 PHP
Javascript 匿名函数及其代码模式原理
2010/03/19 Javascript
Web跨浏览器进程通信(Web跨域)
2013/04/17 Javascript
千分位数字格式化(用逗号隔开 代码已做了修改 支持0-9位逗号隔开)的JS代码
2013/12/05 Javascript
分享20个提升网站界面体验的jQuery插件
2014/12/15 Javascript
js+CSS实现弹出居中背景半透明div层的方法
2015/02/26 Javascript
JavaScript常用脚本汇总(三)
2015/03/04 Javascript
JS实现页面载入时随机显示图片效果
2016/09/07 Javascript
chrome下判断点击input上标签还是其余标签的实现方法
2016/09/18 Javascript
Vue触发隐藏input file的方法实例详解
2019/08/14 Javascript
JS使用正则表达式判断输入框失去焦点事件
2019/10/16 Javascript
使用 JavaScript 创建并下载文件(模拟点击)
2019/10/25 Javascript
vue+iview实现文件上传
2020/11/17 Vue.js
[15:56]Heroes18_暗影萨满(完美)
2014/10/31 DOTA
[51:53]完美世界DOTA2联赛循环赛 LBZS vs DM BO2第二场 11.01
2020/11/02 DOTA
python和shell变量互相传递的几种方法
2013/11/20 Python
用map函数来完成Python并行任务的简单示例
2015/04/02 Python
python 创建弹出式菜单的实现代码
2017/07/11 Python
Python爬虫番外篇之Cookie和Session详解
2017/12/27 Python
python使用pipeline批量读写redis的方法
2019/02/18 Python
python 爬虫请求模块requests详解
2020/12/04 Python
详解CSS透明opacity和IE各版本透明度滤镜filter的最准确用法
2016/12/20 HTML / CSS
自我评价的范文
2014/02/02 职场文书
行政专员岗位职责范本
2014/08/26 职场文书
2014财产信托协议书范本
2014/11/18 职场文书
2014年班组工作总结
2014/11/20 职场文书
2014小学数学教师个人工作总结
2014/12/18 职场文书
初中家长评语和期望
2014/12/26 职场文书
2015年党建工作总结
2015/03/30 职场文书
2015年共青团工作总结
2015/05/15 职场文书
奖学金申请书(范文)
2019/08/14 职场文书
十大最强格斗系宝可梦,超梦X仅排第十,第二最重格斗礼仪
2022/03/18 日漫
Android Flutter实现图片滑动切换效果
2022/04/07 Java/Android
解决IIS7下无法绑定https主机的问题
2022/04/29 Servers