网站导航网学 原创论文 原创专题 网站设计 最新系统 原创论文 论文降重 发表论文 论文发表 UI设计定制 论文答辩PPT格式排版 期刊发表 论文专题
返回网学首页
网学原创论文
最新论文 推荐专题 热门论文 论文专题
当前位置: 网学 > 设计资源 > DIVCSS技术 > 正文

CSS之兼容浏览器篇

来源:http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 发布时间: 09/03/16

  先温习一下对于IE的box-model的破解

  IE box-model这个臭名昭著的bug存在于IE6/Win以前的每一只版本,这个虫子直到tantak发布了流传最为广泛的那个hack才开始被驯服

  http://www.tantek.com/CSS/Examples/boxmodelhack.html

  IE5.X/win对box-model的解析是一样的,他们认为width包括了边框(border)和补白(padding),幸运的是这个情况在IE6中有了好转

  但是IE6在向后兼容的同时也包容了以前的错误,IE6其实有两个核心,在旧的页面前他仍旧表现出对错误的宽容,只有在文档中严格地加上文档类型(DOCTYPE)声明,IE6才能够接受正确的box-model

  所以,tantak的hack必须和正确的DOCTYPE同时包含在文档中才能够正常工作

  Quote

  div.content {

  width:400px; //这个是错误的width,所有浏览器都读到了

  voice-family: "\"}\""; //IE5.X/win忽略了"\"}\""后的内容

  voice-family:inherit;

  width:300px; //包括IE6/win在内的部分浏览器读到这句,新的数值(300px)覆盖掉了旧的

  }

  html>body .content { //html>body是CSS2的写法

  width:300px; //支持CSS2该写法的浏览器有幸读到了这一句

  }

  现在回到主题,我们经常看到!important和(空格)/**/:组合在一起使用,这个写法有什么奥妙呢?

  看刚才那个写法,我这里可以提供另一种写法也能达到这样的效果

  Quote

  div.content {

  width:300px !important; //这个是正确的width,大部分支持!important标记的浏览器使用这里的数值

  width(空格)/**/:400px; //IE6/win不解析这句,所以IE6/win仍然认为width的值是300px;而IE5.X/win读到这句,新的数值(400px)覆盖掉了旧的,因为!important标记对他们不起作用

  }

  html>body .content { //html>body是CSS2的写法

  width:300px; //支持CSS2该写法的浏览器有幸读到了这一句

  }

  同样,这个方法仍必须依靠正确的文档类型声明才能够正常工作,原因在前面已经说过。

  文档类型声明就像一个开关,打开向后兼容的未来,而错误使用的话,就是一个Pandora box

  • 下一篇资讯: CSS选择符详解
  • 设为首页 | 加入收藏 | 网学首页 | 原创论文 | 计算机原创
    版权所有 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2020 myeducs.Cn www.myeducs.Cn All Rights Reserved 湘ICP备09003080号 常年法律顾问:王律师