两者都是外部引用CSS的方式,但是存在一定的区别:
1.从属关系区别
@link是HTML提供的标签,不仅可以加载 CSS 文件,还可以定义 RSS、rel 连接属性等;
@import是 CSS 提供的语法规则,只有导入样式表的作用;
2.加载顺序区别
link标签引入CSS时,在页面载入时被同时加载;@import引入的 CSS 将在页面完全载入以后被加载。
3.兼容性区别
@import是 CSS2.1 才有的语法,故只可在 IE5+ 才能识别;link标签作为 XHTML标签,无兼容问题。
4.DOM可控性区别
可以支持使用 JS 操作 DOM操作 ,插入link改变样式;由于 DOM 方法是基于文档的,无法使用@import的方式插入样式。
5.权重区别(该项有争议,下文将详解)
link引入的样式权重大于@import引入的样式。
引入css的方式
1.内联方式
内联方式指的是直接在 HTML 标签中的 style 属性中添加 CSS。
示例:
<div style="background: red"></div>
它只能改变当前标签的样式,如果想要多个
很显然,内联方式引入 CSS 代码会导致 HTML 代码变得冗长,且使得网页难以维护。
2.嵌入方式
嵌入方式指的是在 HTML 头部中的
示例:
<head>
<style>
.content {
background: red;
}
</style>
</head>
嵌入方式的 CSS 只对当前的网页有效。因为 CSS 代码是在 HTML 文件中,所以会使得代码比较集中,当我们写模板网页时这通常比较有利。因为查看模板代码的人可以一目了然地查看 HTML 结构和 CSS 样式。因为嵌入的 CSS 只对当前页面有效,所以当多个页面需要引入相同的 CSS 代码时,这样写会导致代码冗余,也不利于维护。
3.链接方式
链接方式指的是使用 HTML 头部的 标签引入外部的 CSS 文件。
示例:
<head>
<link rel="stylesheet" type="text/css" href="style.css">
</head>
这是最常见的也是最推荐的引入 CSS 的方式。使用这种方式,所有的 CSS 代码只存在于单独的 CSS 文件中,所以具有良好的可维护性。并且所有的 CSS 代码只存在于 CSS 文件中,CSS 文件会在第一次加载时引入,以后切换页面时只需加载 HTML 文件即可。
4.导入方式
导入方式指的是使用 CSS 规则引入外部 CSS 文件。
示例:
<style>
@import url(style.css);
</style>
本文详细对比了link和@import两种CSS引入方式的区别,包括从属关系、加载顺序、兼容性、DOM可控性和权重差异,并介绍了四种引入CSS的方法:内联、嵌入、链接和导入方式,帮助读者理解不同场景下的最佳实践。
1万+

被折叠的 条评论
为什么被折叠?



