link引入与script引入的区别(转载)
序言
我们都知道,内联的JavaScript是在页面的
<script> ... </script>
标签内添加,内联的样式是在<style> ... </style>
标签内添加;而外部共享的JavaScript文件,则是通过<script src="..."></script>
来引入,共享的样式文件不是通过<style src=""></style>
的形式引入,而是通过<link rel="stylesheet" href="...">
形式引入,这是为什么呢?
w3c最初的设计中 <script>
标签也没有src属性,使用 <link rel="..." href="...">
来引入当前文档外部的资源,如:父文档,翻译,或者层叠样式表等。 <link rel="" href="" meidia="">
元素规定了当前文档和外部资源之间的关系,它常用来引入外部的样式表,我们可以通过rel属性设置为stylesheet来使用。后来为 <script>
添加了src属性。
href是引用和页面关联,是在当前元素和引用资源之间建立联系,src表示引用资源,表示替换当前元素,用在img,script,iframe上,src是页面内容不可缺少的一部分。
<script src="js.js"></script>
当浏览器解析到这一句的时候会暂停其他资源的下载和处理,直至将该资源加载,编译,执行完毕,图片和框架等元素也是如此,类似于该元素所指向的资源嵌套如当前标签内,这也是为什么要把放在底部而不是头部。
<link href="common.css" rel="stylesheet"/>
当浏览器解析到这一句的时候会识别该文档为css文件,会下载并且不会停止对当前文档的处理,这也是为什么建议使用link方式来加载css而不是使用@import。
说明
HTML页面加载和解析流程
-
用户输入网址(假设是个html页面,并且是第一次访问),浏览器向服务器发出请求,服务器返回html文件。
-
浏览器开始载入html代码,发现
<head>
标签内有一个<link>
标签引用外部CSS文件。 -
浏览器又发出CSS文件的请求,服务器返回这个CSS文件。
-
浏览器继续载入html中
<body>
部分的代码,并且CSS文件已经拿到手了,可以开始渲染页面了。 -
浏览器在代码中发现一个
<img>
标签引用了一张图片,向服务器发出请求。此时浏览器不会等到图片下载完,而是继续渲染后面的代码。 -
服务器返回图片文件,由于图片占用了一定面积,影响了后面段落的排布,因此浏览器需要回过头来重新渲染这部分代码。
-
浏览器发现了一个包含一行Javascript代码的
<script>
标签,赶快运行它。 -
Javascript脚本执行了这条语句,它命令浏览器隐藏掉代码中的某个
<style>
(style.display=”none”)。杯具啊,突然就少了这么一个元素,浏览器不得不重新渲染这部分代码。 -
终于等到了
</html>
的到来,浏览器泪流满面…… -
等等,还没完,用户点了一下界面中的“换肤”按钮,Javascript让浏览器换了一下<link>标签的CSS路径。
-
浏览器召集了在座的各位
<div><span><ul><li>
们,“大伙儿收拾收拾行李,咱得重新来过……”,浏览器向服务器请求了新的CSS文件,重新渲染页面。
因此,这两个标签既可以写到head也可以写到body当中,因为他们都是不在浏览器当中显示的.
一般情况下,习惯性 <link>
标签写在 <head>
里面, <script>
标签写在body标签的尾部.
link和script区别
link 一般引入css样式
link引入强调次序
script 一般引入的是 JAVASCRIPT 脚本
因此,引入jQuery,只能用script引入而不能用link引入
link用来存外部css的链接,script存放js代码。
最后
十分感谢原博主,原博客地址如下:
__EOF__

本文链接:https://www.cnblogs.com/GoodMemoryBlog/articles/14459236.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)