[译] ./dogs.html 和 /dogs.html 间有什么区别?

栏目: CSS · 发布时间: 6年前

内容简介:它们还有完整 URL 路径,如下所示:全限定 URL 的功能再明显不过 —— 它会指向一个确切的页面。所以,让我们再来看看前两个例子。

它们 都是 URL 路径 。但是他们名字不同。

<!-- 相对于当前所在目录(相对路径) -->
<a href="./dogs.html">Dogs</a>

<!-- 相对于根目录(绝对路径) -->
<a href="/dogs.html">Dogs</a>
复制代码

还有完整 URL 路径,如下所示:

<!-- 完整 URL 路径 -->
<a href="https://website.com/dogs.html">Dogs</a>
复制代码

全限定 URL 的功能再明显不过 —— 它会指向一个确切的页面。所以,让我们再来看看前两个例子。

假设你的网站上有这样的目录结构:

public/
├── index.html
└── animals/
    ├── cats.html
    └── dogs.html
复制代码

如果你在 cats.html 上放置了一个链接到 /dogs.html (一个“绝对”路径)的超链接,那么它将指向 404 页面 —— 这个网站的根目录那一层没有 dogs.html 文件!在路径开头的 / 意味着__“从 最底层 开始,然后再往上”__( public/ 是最底层到目录)。

那个在 cats.html 上的链接需要写成 ./dogs.html (从当前文件所在目录开始)或 /animals/dogs.html (明确说明要从哪个目录开始)。

当然,目录结构越复杂,绝对 URL 越长。

public/
├── animals/
  └── pets/
      ├── c/
      |   └── cats.html
      └── d/
          └── dogs.html
复制代码

在这样的结构下,就想要从 dogs.html 链接到 cats.html 而言,URL 肯定是其中之一...

<!-- 注意两个点,它表示源文件所在目录的上一级目录 -->
<a href="../c/cats.html">cats</a>

<!-- 或者相对于根目录 -->
<a href="/animals/pets/c/cats.html">cats</a>
复制代码

在这种情况下值得注意的是,如果 animals/ 被重命名为 animal/ ,就会使得绝对链接失效,但是相对链接仍会有效。这可能是使用绝对链接的缺点。当你使用绝对链接时,改变路径将会影响你的链接。

我们只研究了 HTML 文件中链接到 HTML 文件的情形,但基本上这个思路对于网页(和计算机)是通用的。例如,在 CSS 文件中,你可能有下面这样的代码:

body {
  /* 当前文件所在目录下的 /images 目录里的图片 */
  background-image: url(./images/pattern.png);
}
复制代码

...在这种情况下是正确的:

public/
├── images/
|   └── pattern.png
├──index.html
└── style.css
复制代码

但是如果你移动了 CSS 文件...

public/
├── images/
|   └── pattern.png
├── css/
|   └── style.css
└── index.html
复制代码

...紧接着就会出问题,是因为你的 CSS 文件现在嵌套在另一个目录中,引用路径变得更深。你需要使用两个点再次回到当前文件所在目录的上一级目录,例如 ../images/pattern.png

并不是哪种 URL 格式比另一种格式好 —— 它只取决于你认为当时怎样更有用、更直观。

对我来说,我在思考哪些东西最不可能改变。对于类似图像资源的东西,我发现我不太可能移动它,因此使用绝对 URL 路径(例如 /images/pattern.png )链接它似乎是最安全的。但是为了链接到恰好位于同一目录中的所有文档,使用相对链接的方式似乎更安全。

如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。

掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为掘金 上的英文分享文章。内容覆盖 AndroidiOS前端后端区块链产品设计人工智能 等领域,想要查看更多优质译文请持续关注 掘金翻译计划 、官方微博、 知乎专栏


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

成为乔布斯

成为乔布斯

[美] 布伦特·施兰德、[美] 里克·特策利 / 陶亮 / 中信出版集团 / 2016-10 / 69.00元

本书描绘了一位多姿多彩的人物将与生俱来的激情与成熟的管理方式相结合,打造出史上最有价值、最受消费者追捧的公司,这本书将彻底改变我们看待乔布斯的方式。 本书推翻了关于史蒂夫·乔布斯的传说和陈词滥调,比如他是天才和混蛋的结合体,暴躁易怒、自私自利,怠慢朋友与家人。本书揭示了这位苹果联合创始人和CEO的家庭生活与职业生涯,并回答了一个关键问题:为什么如此轻狂傲慢、以至于被赶出苹果的年轻人能成为史上......一起来看看 《成为乔布斯》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

SHA 加密
SHA 加密

SHA 加密工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换