这一晚上看的我是头疼不已啊,为什么呢?
终究是半路出家,我对javascript的理解只停留在:调用javascript,改变页面样式,元素和实现一些事件的响应,虽然需要的时候可能会用,但是究竟使用的原理却不是很明白,至于DOM,这么专业的词汇,还是省省吧。
不过一晚上也不是毫无收获,先记录下暂时自己的理解,可能存在偏差,随着之后应用的增多慢慢理解吧,先烙个印再说。
1、DOM它是什么?
最直接的回答:“Document Object Model”的缩写,简称“文档对象模型”,听到这样的回答真是让人抓狂啊,但是,不得不说它是正确的。
最专业的回答:W3C对DOM的定义是-----它 是中立于平台和语言的接口,程序和脚本可以通过这个接口动态的访问和修改文档的内容、结构和样式。
最简练的回答:一种API,应用编程接口
毫无疑问,上面的回答都是正确的,而且我们还能提炼出几个要点:1、一种应用接口;2、对文档的操作,在我看来,这大抵就是它的核心了,这样我们来试着通俗的解释下,看看能不能更简单、更直观的了解这种概念
在上一篇文章中,提到了javascript可以分成三部分:ECMAscript、DOM、BOM,然后又简单描述了下ECMAscript:定义了变量来存不同数据类型的值,定义了运算符来对值进行操作,将值的改变和运算符的操作过程合成语句,或者用语句拼接一些完整的方法等等,但是就这样摆着,方法是有了,可没见过说明书可以自己操作机器的,我们要想真正实现动态化和交互性,就必须将他们整合,而这种将html(或者html5)、css和javascript凝聚在一起的就是DOM。
这样我们再来回味上面的三种回答,它是将文档内事物都整合起来作为一个大的对象进行操作的;至于改变文档内的内容,javascript则是来访问这个文档的入口,而举个不恰当的例子,桌上一桌丰盛的菜,你最需要的是什么,是一套餐具,人用餐具吃饭,这已经成了一个标准,不管你吃的是那个菜,不管是你在吃还是他在吃,手扒的倒是可以排除在外,而javascript就是那个媒介,那个通道....