美文网首页前端面试题目集锦
[CSS]提出质疑:@import和link的区别

[CSS]提出质疑:@import和link的区别

作者: Katherine的小世界 | 来源:发表于2018-01-21 14:50 被阅读0次

事情是这样的,自己在看这两个的区别的时候,看到的说法都是在说,@import会慢于link去执行,使用@import的时候样式表会在页面加载完之后再去执行,而link会在页面加载的时候执行,不过我在chrome下去测试却不是这样的,测试的结果是,按照其在页面中的引入顺序来加载的。

一 @import 和 link的区别

link的使用
<link rel="stylesheet" type="text/css" href='path to style.css'></link>

@import的使用
<style type="text/css">@import url(Path To stylesheet.css)</style>

二 yahoo的建议:优先选择link(但是现在我却不得不质疑yahoo的这点建议了)

image.png

三 纠正错误 (测试环境:chrome,IE10)

  • 关于加载: 测试之后只和其在页面的顺序有关系,按照顺序来加载。
  • 关于渲染原则:
    • 如果都是通过head引入的话)如果是在同等的权重的情况下,越是在后面的权重就越高。
    • 如果是在style中引入的话)如果是同等权重的情况下,导入的优先级最低。!!!!注意,import的要在style的顶部引入才有用,不然起不到效果。
  • 关于兼如果是容性: @import已经在IE5以上都支持了,link则无兼容性问题了,但是link自身有很多的属性,有一些属性对一些浏览器还未做到兼容。
四 :兼容性情况图
@import的兼容性支持情况
link的兼容性情况图
四 关于测试的结果图:

打开chrome调试,按照以下步骤,查看日志,分别查看请求的顺序,可以发现,是按照页面的引入顺序来请求的,然后解析的话,则按照哪个先请求回来就先解析。

image.png
五 最后:测试代码

下面写了三部分的测试代码,可以分别注释去测试,查看结果。

// 
<!DOCTYPE html>
<html>
  <head>
  <!-- 测试一,颜色为粉色,权重一样的话,以最后一个为准。 -->
  <!-- <style type='text/css'>@import url("tets.css");</style>
  <link rel="stylesheet" href="test1.css" type='text/css'>
  <style>
      .test {
        background: green;
      }
  </style>
  <link rel="stylesheet" href="test3.css" type='text/css'> -->

  <!-- 颜色为红色,权重一样的情况下,以最后一个为准。 -->
  <!-- <style type='text/css'>@import url("tets.css");</style>
  <link rel="stylesheet" href="test1.css" type='text/css'>
  <style>
      .test {
        background: green;
      }
  </style>
  <link rel="stylesheet" href="test3.css" type='text/css'>
  <style type='text/css'>@import url("tets.css");</style> -->


  <!--颜色为绿色。  -->
  <style type='text/css'>@import url("tets.css");</style>
  <link rel="stylesheet" href="test1.css" type='text/css'>
  <link rel="stylesheet" href="test3.css" type='text/css'>
  <style type='text/css'>@import url("tets.css");</style>
  <style>
      .test {
        background: green;
      }
  </style>
  </head>
  <body>
    <div class='test'>
      <h1>hhhhhh</h1>
    </div>
  </body>
</html>

这是自己的一个质疑和验证过程,也希望有人可以一起来交流。

相关文章

  • [CSS]提出质疑:@import和link的区别

    事情是这样的,自己在看这两个的区别的时候,看到的说法都是在说,@import会慢于link去执行,使用@impor...

  • CSS令人迷惑的知识点

    CSS中link 和@import的区别是? '' (1) link属于HTML标签,而@import是CSS提供...

  • css关键基础点

    CSS中 link 和@import 的区别是什么? a. link属于HTML标签,而@import是CSS提供...

  • FE-interview-HTML/CSS

    link和@import区别: 从属关系的区别:link属于XHTML标签,@import是CSS提供的语法规则。...

  • 前端基础积累

    link和@import的区别 link是HTML标签,@import是css提供的。 link引入的样式页面加载...

  • 前端面试题2

    前端面试题2 区别下css中的 link 和 @import?link属于xhtml标签,而@import是css...

  • CSS中 link与@import

    外部引用CSS中 link与@import的区别: link属于XHTML标签,而@import完全是CSS自己提...

  • link和@import的区别:

    link和@import的区别: 1、 link属于XHTML标签,而@import完全是CSS提供的一种方式。 ...

  • 前端面试题

    1、link和import的区别 1、link属于html标签,而@import是css提供的。 2、页面被加载时...

  • css link和@import区别

    这里 link 与 @import 介绍的是 html 引入css 的语法单词。 两者均是引入css到html的单...

网友评论

    本文标题:[CSS]提出质疑:@import和link的区别

    本文链接:https://www.haomeiwen.com/subject/uzufaxtx.html