LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

!DOCTYPE声明对JavaScript的影响

admin
2011年2月15日 22:44 本文热度 2698
    DOCTYPE是document type(文档类型)的简写,在web设计中用来说明你用的XHTML或者HTML是什么版本。

    要建立符合标准的网页,DOCTYPE声明是必不可少的关键组成部分;除非你的XHTML确定了一个正确的DOCTYPE,否则你的标识和CSS都不会生效;当然对JS的取值也会有影响。

    DOCTYPE声明如下:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

    DOCTYPE声明包括:过渡型(Transitional),严格型(Strict)和框架型(Frameset)。接下来就看一下这三种类型对不同浏览器在获取元素相关信息时的影响(包括不定义DOCTYPE和只将DOCTYPE定义为<!docType>形式),我测试的浏览器分别为:IE6.0、IE7.0、IE8.0(变态模式)、FF、Opera、Chrome和Safari。由于IE5.5已经几乎被淘汰,所以不在测试范围之内。

    以下就是测试结果(滚动条只是元素本身的滚动条并不是窗口的):

    一、过渡型(Transitional)

        1、测试IE6.0、IE7.0与IE8.0(非变态模式Quirks)的宽度和高度(width,height)

offsetWidth,offsetHeight clientWidth,clientHeight currentStyle[‘width’],currentStyle[‘width’]
有无滚动条均为:
offsetWidth=
paddingLeft+paddingRight+borderLeft+borderRight

offsetHeight=
paddingTop+paddingBottom+borderTop+boderBottom
 1、无滚动条
clientWidth=CSS中定义的宽度+paddingLeft+paddingRight

clientHeight=CSS中定义的高度+paddingTop+paddingBottom
(均不包括边框宽度)

2、有滚动条
clientWidth=CSS中定义的宽度-滚动条宽度(17固定值)-边框宽度,

clientHeight=CSS中定义的高度-滚动条宽度(17固定值)-边框宽度
 实际真实宽度,不包括padding与边框值
(除IE和Opera以外无此属性)
 
offsetLeft,offsetTop clientLeft,clientTop currentSytle[‘left’],currentStyle[‘top’]
有无滚动条均为:
offsetLeft=对象的offsetLeft-边框
offsetTop=实际值
 有无滚动条均为:边框的宽度
 除IE和Opera以外无此属性
 

 

          2、测试IE8.0变态模式(Quirks)的宽度与高度(width,height)

offsetWidth,offsetHeight clientWidth,clientHeight currentStyle[‘width’],currentStyle[‘height]
1、(无滚动条)宽度(高度)=当前对象的实际数值
2、(有滚动条)宽度(高度)=CSS中定义的数值
 1、(无滚动条)宽度(高度)=当前对象的实际数值
2、(有滚动条)宽度(高度)=当前对象在CSS中定义的数值-滚动条(17)
 有无滚动条均为:
宽度和高度均为CSS中定义的数值
 
offsetLeft,offsetTop clientLeft,clientTop currentSytle[‘left’],currentStyle[‘top’]
有无滚动条均为:

offsetLeft(offsetTop)=实际值
 有无滚动条均为:边框的宽度
 除IE和Opera以外无此属性
 

 

          3、FF、Opera、Safari和Chrom中所取得的数值与第一种情况一样。

 

    二、严格型(Strict)

        1、测试IE6.0、IE7.0与IE8.0(非变态模式Quirks)的宽度和高度(width,height)

offsetWidth,offsetHeight clientWidth,clientHeight currentStyle[‘width’],currentStyle[‘width’]
有无滚动条均为:
offsetWidth=
paddingLeft+paddingRight+borderLeft+borderRight

offsetHeight=
paddingTop+paddingBottom+borderTop+boderBottom
 1、无滚动条
clientWidth=CSS中定义的宽度+paddingLeft+paddingRight

clientHeight=CSS中定义的高度+paddingTop+paddingBottom
均不包括边框宽度

2、有滚动条
clientWidth=CSS中定义的宽度-滚动条宽度(17固定值)-边框宽度,

clientHeight=CSS中定义的高度-滚动条宽度(17固定值)-边框宽度
 实际真实宽度,不包括padding与边框值
(除IE和Opera以外无此属性)
 
offsetLeft,offsetTop clientLeft,clientTop currentSytle[‘left’],currentStyle[‘top’]
有无滚动条均为:
offsetLeft=对象的offsetLeft-边框
offsetTop=实际值
 有无滚动条均为:边框的宽度
 除IE和Opera以外无此属性
 
 

          2、测试IE8.0变态模式(Quirks)的宽度与高度(width,height)

offsetWidth,offsetHeight clientWidth,clientHeight currentStyle[‘width’],currentStyle[‘height]
1、(无滚动条)宽度(高度)=当前对象的实际数值
2、(有滚动条)宽度(高度)=CSS中定义的数值
 1、(无滚动条)宽度(高度)=当前对象的实际数值
2、(有滚动条)宽度(高度)=当前对象在CSS中定义的数值-滚动条(17)-边框宽度
 有无滚动条均为:
宽度和高度均为CSS中定义的数值
(除IE和Opera以外无此属性)
 
offsetLeft,offsetTop clientLeft,clientTop currentSytle[‘left’],currentStyle[‘top’]
有无滚动条均为:

offsetLeft(offsetTop)=实际值
 有无滚动条均为:边框的宽度
 除IE和Opera以外无此属性
 
 

          3、FF、Opera、Safari和Chrom中所取得的数值与第一种情况一样。

 

    三、取消DOCTYPE声明

          1、IE6.0、IE7.0在没有DOCTYPE声明时与IE8.0中的变态模式(Quirks)中严格型结果相同。

          2、FF、Safari、Chrome和IE8.0标准模式是与过渡型结果相同。

          3、Opera浏览器中,在元素没有滚动条时offsetHeight与clientHeight的取值是在其当前现实的大小。

 

    四、将DOCTYPE声明改写为<!docType>

          1、IE6.0、IE7.0在没有DOCTYPE声明时与IE8.0中的变态模式(Quirks)中严格型结果相同。

          2、FF、Safari、Chrome和IE8.0标准模式是与过渡型结果相同。

          3、Opera浏览器中,在元素没有滚动条时offsetHeight与clientHeight的取值是在其当前现实的大小。

    在Opera中也拥有与IE一样的属性“currentStyle”,所以在Opera中也可以使用currentStyle来取得元素的精确值。

该文章在 2011/2/15 22:44:14 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2024 ClickSun All Rights Reserved