zl程序教程

您现在的位置是:首页 >  前端

当前栏目

src和href都是链接有啥不一样

链接 一样 src href
2023-09-27 14:26:39 时间

前言

src和href都是用于外部资源的引入,像图片、CSS文件、HTML文件、js文件或其他web页面等。
那么在SRC和HREF之间是否有一个明确的区别呢?在哪些地方或者什么时候应该用SRC还是HREF?我想它们的使用并不是可以随意替换的。
我先给出几个这两个属性的使用例子:

  • 引用css文件时:href="cssfile.css"
  • 引用js文件时:src="myscript.js"
  • 引用图片:src="mypic.jpg"
  • 网站链接:href="http://www.webpage.com"

它们之间的主要区别可以用这样一句话来概括:src用于替代这个元素,而href用于建立这个标签与外部资源之间的关系。
例如:
<a href="www.xxx.com">\<\img src="1.jpg">\</a>
a标签里面的内容是一张图片,a标签加上href属性将图片链接到了www.xxx.com这个网站,但并未替换a标签里面的内容,而img标签的src属性则是将这个标签完全替换成了src里面的资源

href

href (Hypertext Reference) 超文本引用href这个属性指定web资源的位置,从而定义当前元素(如锚点a)或当前文档(如链接)与目标锚点或目标资源之间的联系。
例如当我们写:
<link href="style.css" rel="stylesheet" />
浏览器知道这是个样式表文件,html的解析和渲染不会暂停,css文件的加载是同时进行的,这不同于在style标签里面的内置样式,用@import添加的样式是在页面载入之后再加载,这可能会因为页面重新渲染而导致闪烁。所以我们建议使用link而不是@import。

注:修改DOM、修改样式表、用户操作都会导致页面重新渲染。

src

src (Source)源这个属性是将资源嵌入到当前文档中元素所在的位置。例如当我们写:
<script src="script.js"></script>
当浏览器解析到这句代码时,页面的加载和解析都会暂停直到浏览器拿到并执行完这个js文件。这就像是把js文件里的内容全部注入到这个script标签中,类似于img,img标签是一个空标签,它的内容就是由src这个属性定义,浏览器会暂停加载直到这个图片加载完成。这也是为什么要将js文件的加载放在body最后的原因(在</body>前面)。

参考:Difference between SRC and HREF