专注SEO、SEM、百度排名、快速提升权重、关键字优化、网络推广,seo莫然可以分享移动手机端SEO知识!免费提供网站优化诊断。 
 莫然博客是山东省最主流,最具人气的莫然seo博客频道。专注SEO、SEM、百度排名、快速提升权重、关键字优化、网络推广,seo莫然可以分享移动手机端SEO知识!免费提供网站优化诊断。

IE浏览器兼容问题(上)——html和css的兼容写法

作者:seo , 分类:seo实战技术 , 浏览:1759 , 评论:0

  

用户使用的浏览器五花八门,我们要保证每一种浏览器都能兼容我们的代码,不能要求用户去改变浏览器,那么就得在我们的代码上下功夫。此时我们要用到hack。  

HACK就是针对不同的浏览器写不同的HTML、CSS样式,从而使各种浏览器达到一致的渲染效果。  

下面我们就分别了解一下HTML的hack和CSS的hack。  

(一)、HTML的hack  

HTML的hack由注释<!---->演变而来,在高级浏览器中注释不会被加载,把IE浏览器的兼容代码写在注释中,IE浏览器会识别。  

HTML的hack代码模板:  

注:  

①用于写兼容的注释,标签内首位都要加!感叹号。  

②单词都写在一对中括号中  

③IE和版本号之间要加空格  

④不加比较单词,表示只兼容这一个版本;  

比较单词:lt=lessthan(小于)、lte=lessthanorequal(小于等于)、gt=greatthan(大于)、gte=greatthanorequal(大于等于)  

<!--[ifIE6]>  

<p>只有IE6认识我</p><![endif]-->  

只要记住这一个模板就知道HTML的兼容怎么写了,下面我们列举几个:  

<!--[ifgteIE9]>  

<h1>大于等于IE9的浏览器能看到</h1>  

<![endif]-->  

<!--[iflteIE8]>  

<h1class="red">您的浏览器版本过低,IE8及以下版本不支持新样式,请更新浏览器</h1>  

<![endif]-->  

复制代码  

单独写给IE6的解决兼容问题的HTML代码:<!--[ifIE6]>  

<scriptsrc="js/iepng.js"type="text/javascript"></script>  

<scripttype="text/javascript">  

EvPNG.fix('div,ul,img,li,input,span,b,h1,h2,h3,h4');  

</script>  

<![endif]-->  

复制代码  

(二)、CSS的hack  

CSS的hack包括:属性的hack和选择器的hack  

设置css的hack要注意的是css样式的层叠性,给同一个元素设置的兼容写法必须写在后面,否则会被层叠掉。  

(1)属性的hack  

①只兼容IE6的hack  

hack符:-或_,当做前缀写在属性前面,中间不加空格  

在属性名前面加短横-或者下划线_(原理:高级浏览器及其他浏览器会认为这个前缀符号是一个unknownpropertyname),未知的属性名,不会报错,不予加载。  

例:  

background:red;//高级浏览器识别_background:pink;//仅IE6识别  

②兼容IE6、7的hack  

hack符:`~!@#$%^&*()+=[]|<>,.中的任一字符,作为前缀写在属性前面  

例:  

background:red;//高级浏览器识别!background:pink;//仅IE6、7识别  

③只兼容IE8的hack  

hack符:\0/,必须写在属性值与分号之间,中间不加空格  

background:red;//高级浏览器识别background:pink\0/;//仅IE8识别  

④兼容IE8、9、10的hack  

hack符:\0,必须写在属性值与分号之间,中间不加空格  

background:red;//高级浏览器识别background:pink\0;//IE8、9、10识别  

⑤兼容IE6、7、8、9、10  

hack符:\9,必须写在属性值与分号之间,中间不加空格  

(2)选择器的hack  

给选择器添加hack,这个选择器中的样式都是IE兼容样式,其他高级浏览器不识别,同理给同一个选择器设置的兼容样式要写在高级浏览器可识别的常规样式后面,否则会被层叠  

①IE6及以下版本的hack  

hack符:*html,*和html之间有空格,再加一个空格,后面写选择器  

例:  

复制代码  

<!--常规写法-->  

.box{  

width:200px;  

height:200px;  

border-radius:50%;  

background:yellowgreen;  

}  

<!--兼容写法-->  

*html.box{  

width:100px;  

height:100px;  

background:skyblue;  

}  

复制代码  

②IE7及以下版本的hack  

hack符:,英文逗号,写在选择器后面,不加空格  

例:  

.box,{  

background:#999;  

border:10pxsolidred;  

③兼容IE6以外的其他版本的hack  

hack符:html>body,写在选择器前面,与选择器之间有一个空格隔开  

例:  

html>body.box{  

background:yellow;  

}  

④兼容IE6、7以外的版本的hack  

hack符:html>/**/或html~/**/,写在选择器前面,与选择器之间有一个空格隔开  

例:  

html>/**/body.box{  

background:purple;  

}  



莫然博客是山东省最主流,最具人气的莫然seo博客频道。专注SEO、SEM、百度排名、快速提升权重、关键字优化、网络推广,seo莫然可以分享移动手机端SEO知识!免费提供网站优化诊断。

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

额 本文暂时没人评论 来添加一个吧
SEO_山东SEO_网站优化_网络推广