javascript 对浏览器兼容问题.docVIP

  • 0
  • 0
  • 约2.29千字
  • 约 3页
  • 2018-05-25 发布于河南
  • 举报
javascript 对浏览器兼容问题

浏览器兼容问题》》》》》》》》》》》》》》注意事项 编写javascript代码,要注意编码方式规范性 如:div/div要有完整对应的标签 input type=”text” id=”” name=”” /要有明确标识type类型,还有 / 结束符号 切记多余的逗号(iconCls:’ ’ ,)在IE7.0,就会出现异常,所以,要严格保证js代码的完整性。 Div+css通用兼容性代码 style type=”text/css” *html{padding:0px} /* 清除浮动 */ .clearfix:after { content:”.”; display:block; height:0; clear:both; visibility:hidden;} .clearfix { display:inline-block;} .clearfix {display:block;} /style 符号 IE6 IE7 IE8 FF * √ √ × × !important × √ × √ _ √ × × × \9 × × √ × *html √ × × × *+html × √ × × 说明:”√”代表能识别;” ×”代表不识别 关于css部份技巧,div/IE6/IE7/IE8/FF div的垂直居中问题 (1) vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行 (2) margin加倍的问题 设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。解决方案是在这个div里面加上display:inline; (3) 浮动ie产生的双倍距离 #box{ float:left; width:100px; margin:0 0 0 100px; //这种情况之下IE会产生200px的距离 display:inline; //使浮动忽略} 这里细说一下block与inline两个元素: Block:元素的特点是,总是在新行上开始,高度,宽度,行高,边距都可以控制(块元素); Inline:元素的特点是,和其他元素在同一行上,不可控制(内嵌元素); #box{ display:block; //可以为内嵌元素模拟为块元素 display:inline; //实现同一行排列的效果 diplay:table; } (4) IE与宽度和高度的问题 IE不认得min-这个定义,但实际上它把正常的width和height当作有min的情况来使。这样问题就大了,如果只用宽度和高度,正常的浏览器里这两个值就不会变,如果只用min-width和min-height的话,IE下面根本等于没有设置宽度和高度。 比如要设置背景图片,这个宽度是比较重要的。要解决这个问题,可以这样: #box{ width: 80px; height: 35px;} htmlbody #box{ width: auto; height: auto; min-width: 80px; min-height: 35px;} (5) 页面的最小宽度 min-width是个非常方便的CSS命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。但IE不认得这个,而它实际上把 width当做最小宽度来使。为了让这一命令在IE上也能用,可以把一个div 放到 body 标签下,然后为div指定一个类,然后CSS这样设计: #container{ min-width: 600px; width:expression(document.body.clientWidth 600? 600px: auto ); } 第一个min-width是正常的;但第2行的width使用了Javascript,这只有IE才认得,这也会让你的HTML文档不太正规。它实际上通过Javascript的判断来实现最小宽度。 jsp页面布局要规范合理,有一定的缩进Tab标签,方便自己同时也方便别人阅读和维护。 单元测试:自己开发的代码(要做到内部测试),并且特别要注意边界值的覆盖,

文档评论(0)

1亿VIP精品文档

相关文档