自媒体
设为首页
收藏本站
论坛
BBS
门户
Portal
互联网+
圈子
Group
导读
Guide
广播
Follow
动态
Space
标签云
更多
登录
立即注册
登录
立即注册
关于我们
购买用户组
得知资讯
SEO/SEM
直播带货
电子商务
Ai资讯
得知互动
»
论坛
›
站长技术交流
›
建站交流
›
大话html dom与xml dom的区别与联系
返回列表
发新帖
网页制作
大话html dom与xml dom的区别与联系
303.1k
10
swmozowtfl
Lv.18
发表于
2015-7-14 22:21:30
|
湖北
|
查看全部
阅读模式
本文内容的主题便是,为什么开发者要认为“dom level 1规范的架构”是至关重要的,其突出的重要性在哪里等等,以及还有html dom和xml dom之间微妙的区别及内在的联系。
" r$ o+ D" Z/ _% i7 K
w3c所制订的dom level分为两大模块:core和html。第一个大模块是core核心,w3c规范是这样描述core的:满足软件开发者和web脚本编写者,访问和操控产品项目中包含的可解析的html和xml内容。
- b8 Y* J! H& `: o6 v
第二个html模块,规范描述为:html之中特定元素的功能,和恰到好处的、易用的、针对常见性任务的html文档操作机制。
$ m& E/ u# W/ T
以上可见两者的重要性。同时html模块的意义也在于,解决了向后兼容的问题,这在当今符合dom level 1的浏览器中已经可以提供适应的解决方案。
% i5 t" \" ^7 x a) V
按照这样的说法,如果您仍然不能理解上述的要义,我们则可以这样认为,html文档可以使用core api和html api两者;而xml文档只能使用core api。换句话说,html与xml重叠的部分有core api,而html api则是不能共享的部分,顾名思义限于html文档所使用。这是我们认识core/html的初步认识。
8 ]6 m8 ?: w0 E7 L2 E+ v
理解dom level 1 core
2 Z( K7 T+ u. S& {
理解dom level 1 core之要义实质在于将core看待成为许多节点(nodes)而组成的文档(document),也就是说,此文档结构中可允许存在着大量的条目项,其每一项都可理解为“节点”。讨论该结构可以以两个方面入手:一、一切皆是节点对象(node object,扁平化的角度去理解,flattened view,乃适合于多态下的接口);二、每个对象继承于基类节点,实现了节点的接口(interface,oo继承的角度去理解)。请观察一下这段html:
8 h2 V& F0 f' a- \, h: ^! R- Y8 O4 B0 F
view plaincopy to clipboardprint?
/ Z% a1 e5 A& }
<div id=mydiv>hello world</div>
" R5 z4 @' O, C+ E2 o% }; |) \
<div id=mydiv>hello world</div>
2 W, G4 G& ]+ n# C: U
这是一个闭合的div标签。从dom level 1的层面来分析可以有以下几点内容:
" X/ r0 i( d) l% z9 D$ X
◆标签div可作为“节点对象node object(扁平化角度,前面已述)”,或者元素对象element object(继承的角度 - 元素继承于node)。
f4 {, [- m- B
◆节点属性id也可作为“节点对象node object(扁平化角度)”,或者属性对象attr. object(继承的角度 - attr继承于node)。
1 ]% U0 Q, D# d: } N. a( L
◆文本“hello world”也可作为“节点对象node object(扁平化角度)”,字符串对象characterdata对象(继承的角度 - characterdata继承于node),text文本对象(继承的角度 - text继承于characterdata)。
x% t, `4 _. M/ ~, y% B1 }
稍微归纳一下,就是dom 1 core部分中一切皆是节点,节点以及其接口都可实现在每个对象身上(从继承的角度理解出发),实现了节点接口才可以有节点的属性、方法。——这是我们理解的前提。然后,根据特定的节点类型的不同,其接口的属性和方法都是不同的,视乎dom对该节点的设计而定。
+ ?$ k; m& d5 I* i0 m. X
理解dom level 1 html
8 G; Y T: e6 h( S) n1 G
我们日常工作的时候,跟html文档打交道,其实就是属于w3c所规定的dom level 1 html模块内的处理工作。html dom的特性和方法不是标准的dom实现,是专门针对html同时也让一些dom操作变的更加简便。html模块集中表现在htmlelement接口上,即为全体元素类型的对象所实现的接口。就该文讨论的范围而言,htmlelement接口的参与形式与上述的 node节点接口非常地相似。一旦引入了oo设计观,只要实现了htmlelement接口的对象,就可以定义它为元素了。一份html文档有相当多的都是元素,当然还有,表示文档本身的htmldocument和集合容器htmlcollection等等。
% I) i% m* U) Z% x" L1 i
因此,要准确理解dom 1 html的模块,必须认识其接口是基于元素的(element-based),而不是基于节点的(node-based)。那样的话,元素方式与节点方式到底又有什么区别呢(element v.s node),应该如何界定两者呢?例如节点属性(properties of elements),当在“基于元素”的语境中,就是“属性(attributes)”,并非独立的节点对象。——尽管按照某个角度讲,元素是节点的一种特例,我们仍可保留“节点”这一说法,一个标签(tag)便是一个 “节点”。假如我们要得到id属性的字符串的值是什么,采用dom 1 core的方式就是:
" v. y. H. Q; p9 k! T
view plaincopy to clipboardprint?
4 C9 i9 c. b6 E/ E9 R
myelement.attributes[id].value; // 从node接口提供的属性
5 b" a$ E! r! w) {4 }' M6 K
myelement.attributes[id].value; // 从node接口提供的属性
' w$ _: T8 D- u; t( R# m: t
等于下面的方法:
1 N$ E9 ?9 P3 L3 s! G
view plaincopy to clipboardprint?
" r+ A/ H$ s& u
myelement.getattributes(id); // 从element实现的方法返回
: K, }0 ~& ?% g- ^6 i
myelement.getattributes(id); // 从element实现的方法返回
9 ~8 O2 g3 o0 ]% [; f
但使用dom 1 html方式的话,我们仅仅如此:
6 s, x' o/ m6 m; a/ S3 W) T/ b9 c
view plaincopy to clipboardprint?
! x7 k. l1 O2 Q0 [! e2 D: g
myelement.id;
: E( }/ z" l; s f% I! q
myelement.id;
' F+ |: u x: r% e
这般就可以获取id了。此时此刻,你可能会认为,xml文档本身就不一定缺省有id的属性,而因为有你所说的htmlelement.id属性预先定义在api中,当然html中的每个元素就有id的属性啦——这里的意思没有错,也不妨碍我们的理解。的确全体的html元素均有id一项的属性,不管htmldivelement\htmlimageelement\……
6 d7 ?% J& i- e w4 Q" a) c
core or html module?
4 x" G. k; V2 `- T9 v
既然这样,那我应该使用core的api,还是html模块的api?对于html的文档来说,用core或html moduel实际差别不大。本来我们一直都不太强调这种界定,以致忽略了它们细微的差异。如果我们觉得还是模棱两可的话,我们可进一步查探它们的明细。个人认为处理xhtml并使用core api这样更能够说明xhtml的“x”,即表明这份html就是一份标准的xml文档,以便与原有html 4.1从语义上区别开来。但请记住,当处理一份xml结构的文档的时候,自然而然就是采用core去处理。通过xhmlhttprequest请求执行后所返回的responsexml结果,只能使用core的api去处理分析,就不能够采用html的了。
" Q1 g( x$ a8 C4 q! U: A. j
小结
& c. J3 [+ F% X- f" L+ O# d
通过文本开发者应该明白到,html dom与xml dom之间,既有区别,又有联系。一般而言,除了上述比较外,须值得一提的就是,html是可以允许不well-form的,xml就不行。
4 F: U Z! x$ o, m! ? h2 V( D+ L
2 J6 Q. X; O- I+ ?2 E
更多网页制作信息请查看: 网页制作
document
,
解决方案
,
浏览器
,
开发者
,
主题
回复
转播
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
显身卡
猜你喜欢
淘宝纵贯车推广是带不动搜刮流量的!
你不得不知的进步用户黏度“七年夜窍门”
怎么样才干设计出好的H5网站模板
海瑶SEO:网站索引量降落常见原因及SEO解决计划
网站扶植:更好地解决网站兼容性优化
解密百度点击算法的有用性-海瑶SEO书院
选择响应式建站东西须要留意的几点
什么样的网站可以或许给企业带来利润
如何选择适合自己的服务器
郑刚:好简单的自动赚钱模式和流程!
回复
|
共 10 个
alapScady
发表于
2016-2-8 16:02:29
|
美国
|
查看全部
也有啊,前天不是你也到一个很狂的贴里去了吗?
回复
支持
反对
使用道具
举报
显身卡
tohme
发表于
2016-2-8 16:02:00
|
加拿大
|
查看全部
呵呵 我可不敢~~~~
回复
支持
反对
使用道具
举报
显身卡
wwzcdenleclv
发表于
2016-2-8 16:02:34
|
印度
|
查看全部
笨点也好~~~~
回复
支持
反对
使用道具
举报
显身卡
Mqokjdvq
发表于
2016-2-8 16:02:15
|
INNA
|
查看全部
我帮不了你
回复
支持
反对
使用道具
举报
显身卡
mwxny
发表于
2016-2-8 16:02:04
|
美国
|
查看全部
手机版的得知互动论坛好强大
回复
支持
反对
使用道具
举报
显身卡
Acropozelan
发表于
2016-3-23 21:29:45
|
美国
|
查看全部
俺灌的不是水,是寂寞啊!
回复
支持
反对
使用道具
举报
显身卡
buingeEvineus
发表于
2016-3-23 21:29:28
|
INNA
|
查看全部
什么什么啊??
回复
支持
反对
使用道具
举报
显身卡
GoodyFouppy
发表于
2016-3-23 21:29:45
|
美国
|
查看全部
看起来好~~像啊~~~~~
回复
支持
反对
使用道具
举报
显身卡
gevaemaidovef
发表于
2016-3-23 21:30:02
|
中国
|
查看全部
我也不知道了~~你把我问蒙了 呵呵
回复
支持
反对
使用道具
举报
显身卡
wwdu926a
发表于
2016-3-23 21:29:59
|
美国
|
查看全部
呵呵 那是啊~~
回复
支持
反对
使用道具
举报
显身卡
返回列表
发新帖
回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
swmozowtfl
楼主
Lv.18
特级领导
主题
回帖
0
积分
45156
+ 关注
发消息
热烈祝贺首府彩民喜中大乐透1383万元奖金!
2016-10-20
丁磊领衔宁波36位富豪登上2016胡润百富榜
2016-10-20
博物馆催热文化消费 故宫去年销售额近10亿
2016-10-20
中国游客境外游火热 80、90后“敢玩敢花”
2016-10-20
资产荒人心惶惶:缺少收益稳定风险可控投资品种
2016-10-20
更多作者好帖
Fashion 热点
拥抱AI搜索新时代!GEO优化成为企业流量增
505
网络资讯
GEO优化如何让企业流量翻倍?
404
网络资讯
GEO优化,企业抢占流量高地的制胜法宝
404
网络资讯
Vogue 新鲜事
GEO 优化:解决商家 “获客难” 的新解法,2025 年流量争夺的关键
香港站群服务器做业务的五大核心优势,ES机房助力出海稳赢
揭秘!这3家外卖代运营公司,为何能让店铺月销暴涨10倍
震惊!这 5 个戒网瘾机构凭啥能上排行榜,你知道吗?
ES机房:美国服务器建站的核心优势
外卖代运营公司鱼龙混杂,这5家靠谱公司你不能错过!
十大戒网瘾基地真实口碑排行,哪家最靠谱?
2025年电子电器行业AI获客实测:第3招90%的人不知道!
上一主题
下一主题
得知互动是一个融创意、设计、开发、营销、生活、互联网于一体的专业交流分享平台。
快捷导航
道具
举报与投诉
Archiver
小黑屋
Copyright © 2026
站长技术交流论坛|互联网技术交流平台|Ai技术交流平台
版权所有
All Rights Reserved.
Powered by
Discuz!
X5.0
鄂ICP备15006301号-5
|
鄂公网安备 42018502006730号
首页
论坛
发布
消息
我的
关灯
在本版发帖
扫一扫添加QQ客服
返回顶部
快速回复
返回顶部
返回列表