1、bootstrap源码:
html {
font-family: sans-serif;}
解析: -webkit-text-size-adjust: 100%; 解决的是chrome等以webkit为内核的浏览器下不支持小于12px的问题,在chrome下,缩小网页,其他元素缩小,但是字体大小不变的问题。 -ms-text-size-adjust: 100%;;解决IE的字体调整问题。
我们常用设置可以为:
html {
font-family: sans-serif; /* 默认字体 */
font-size: 100%; /* 在用户调整窗口大小时,字体大小做相应调整。 */
-ms-text-size-adjust: 100%; /* IE浏览器 */
-webkit-text-size-adjust: 100%;
}
2、bootstrap源码:
body {
margin: 0;
}
解析:解决的是浏览器对基本样式的支持之间的差异,
常用的有:
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym,
address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt,
var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td{
margin:0;
padding:0;
border:0;
outline:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
3、bootstrap源码:
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
display: block;
}
解析:使用了html5标签。IE9一下的浏览器将不支持这些标签元素,比如<header;><article;><footer;><figure;>等等。包含 html5.js 文件将会是这些浏览器明白这些新元素。
<!--[if lt IE 9]>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
另外,在css将新HTML5元素初始化为块元素,即上述代码。
4、bootstrap源码:
audio,
canvas,
progress,
video {
display: inline-block;
vertical-align: baseline;
}
使html5的媒体文件与img文件一致
常用设置:
audio,
canvas,
progress,
video{
display: inline-block;
*display: inline; //解决IE6、IE7的hack问题,方法,首先行内显示inline属性,然后使用*zoom:1,触发它的haslayout,使产生块的结构
*zoom: 1;
vertical-align: baseline; //Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera
}
5、bootstrap源码
audio:not([controls]) {
display: none;
height: 0; //Remove excess height in iOS 5 devices.
}
对于html中的audio,解决部分浏览器不能正确显示出control插件的问题,
6、[hidden],
template {
display: none;
}
//处理不支持html5中的hidden属性的浏览器
// Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
7、a {
background-color: transparent; //将部分浏览器的灰色背景去除,统一风格
}
a:active,
a:hover {
outline: 0;
}
浏览器在响应时,或者鼠标置于其上时的默认轮廓去掉
只有在规定了 !DOCTYPE 时,Internet Explorer 8 (以及更高版本) 才支持 outline 属性。
8、abbr[title] {
border-bottom: 1px dotted;
}
对于定义了title属性的abbr缩写标签,统一样式。注意IE6以前的浏览器不支持abbr标签。
9、b,
strong {
font-weight: bold;
}
//Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
注意:b标签作为最后的选择,h1---h6表示标题,em为强调的内容,strong表示更加强调的内容,
10、dfn {
font-style: italic; //Address styling not present in Safari and Chrome.
}
h1 {
margin: .67em 0; //Address variable `h1` font-size and margin within `section` and `article`
font-size: 2em; //contexts in Firefox 4+, Safari, and Chrome.
}
注意:margin属性分类
margin:10px 5px 15px 20px;表示,上边距10px,右边距为5px,下边距为15px,左边距为20px
margin:10px 5px 15px;表示,上边距为10px,左右边距为5px,下边距为15px
margin:10px 5px;
margin:10px;
11、bootstrap源码
mark {
color: #000;
background: #ff0; //Address styling not present in IE 8/9.
}
small {
font-size: 80%; //Address inconsistent and variable font size in all browsers.
}
sub,
sup {
position: relative;
font-size: 75%;
line-height: 0;
vertical-align: baseline; //Prevent `sub` and `sup` affecting `line-height` in all browsers.
}
sup {
top: -.5em;
}
sub {
bottom: -.25em;
}
12、bootstrap源码
img {
border: 0;
}
svg:not(:root) {
overflow: hidden;
}
在IE8/9浏览器中,当img标签中包含a标签时,去除img边框属性。
figure {
解决其在Firefox中的兼容性问题
13、bootstrap源码
Address odd `em`-unit font size rendering in all browsers.
button,
input,
optgroup,
select,
textarea {
margin: 0;
font: inherit;
color: inherit;