前言
最常看见的CSS的使用方式有三种
1. 在span, div 等标签上直接使用 style 属性定义CSS
<span style="color:blue">This is Blue.</span>
2. 在当前的html 文件中定义class, 在html 标签中用class 的属性设置。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE> New Document </TITLE> <style type="text/css"> .blue{ color:blue } </style> </HEAD> <BODY> <span class="blue">This is Blue.</span> </BODY> </HTML>
3. 第三种方式就是把CSS 的定义单独到一个文件中, html 文件中使用link 引入css文件
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE> New Document </TITLE> <link href="blue.css" rel="stylesheet" type="text/css" /> </HEAD> <BODY> <span class="blue">This is Blue.</span> </BODY> </HTML>
4. 除了以上方式之外, 还有一种方式就是使用 @import
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE> New Document </TITLE> <style type="text/css"> @import url(blue.css); </style> </HEAD> <BODY> <span class="blue">This is Blue.</span> </BODY> </HTML>
前两种方式自不必多说, 这里比较一下 link 和 @import 的方式?
Link 与 @import 差异
1. 来源与作用。 link 属于 XHTML 标签, 除了可以加载CSS外, 还可以定义RSS, 定义rel 连接属性等其他作用;
而@import 完全是CSS提供的一种方式, 只能加载CSS。
2. 加载顺序不同。 link 引用的CSS会在页面被加载的时候同时加载;
而@import 引用的CSS会等到页面全部被下载完再被加载, 所以有时候会出现开始没有样式,之后页面闪烁一下出现样式(在网速慢的时候会更明显)。
3. 兼容性的差别。 @import 是CSS2.1 提出的,老的浏览器不支持,IE5 以上的才能识别(不过现在来说,已经不是问题了,应该很少有使用IE5及以下的浏览器了)。
link 浏览器都支持。
4. 使用javascript 可以控制到 link, 但@import 却无法控制。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE> New Document </TITLE> <link id="linkId" href="" rel="stylesheet" type="text/css" /> </HEAD> <BODY> <span class="blue">This is Blue.</span> <script> document.getElementById("linkId").href = "blue.css"; </script> </BODY> </HTML>
5. @import 可以在CSS 中再此引入其他样式表。可以创建一个主样式表, 在主样式表中引入其他的样式表。
这样的好处是便于修改和扩展。
CSS拆分成文件, 虽然对于开发和维护来说比较方便和清晰, 但是有一个缺点是会对网站服务器产生较多的HTTP请求。浏览量大的网站还是谨慎使用,像一些大型访问量大的网站的首页,会直接把CSS或js 直接写在html 中。
如果你想样式表并行载入,以使页面更快,请使用LINK 替代@import。