Maison >interface Web >js tutoriel >Explication détaillée de l'objet window.location dans JS (aide-mémoire)

Explication détaillée de l'objet window.location dans JS (aide-mémoire)

青灯夜游
青灯夜游avant
2021-01-30 18:27:083033parcourir

Explication détaillée de l'objet window.location dans JS (aide-mémoire)

Si vous souhaitez obtenir les informations URL du site, alors window.location vous convient ! Utilisez ses propriétés pour obtenir des informations sur l'adresse de la page actuelle, ou utilisez ses méthodes pour effectuer une redirection ou une actualisation de page

window.location.origin    → '"https://segmentfault.com'
               .protocol  → 'https:'
               .host      → 'segmentfault.com'
               .hostname  → 'segmentfault.com'
               .port      → ''
               .pathname  → '/search'
               .search    → '?q=前端小智'
               .hash      → '#2'
               .href      → 'https://segmentfault.com/search?q=前端小智#2'
window.location.assign('url')
               .replace('url')
               .reload()
               .toString()

propriété window.location

window.location 返回值
.origin 站点主地址(协议 + 主机名 + 端口)
.protocol 协议架构 (http: 或者 htts:)
.host 域名 + 端口
.port 端口
.pathname 最前页的 '/' 后面跟的路径
.search ? 后跟的查询字符串
.hash # 号开始的部分
.href 完整网址

La différence entre l'hôte et le nom d'hôte

Dans l'exemple ci-dessus, vous remarquerez peut-être que host et hostname renvoient la même valeur. Alors pourquoi ces propriétés. Eh bien, il s'agit du numéro de port, alors jetons un coup d'œil.

URL sans port

https://segmentfault.com/search

window.location.host; // 'segmentfault.com'
window.location.hostname; // 'segmentfault.com'

window.location.port; // ''

URL avec port

https://segmentfault.com/search"8080

window.location.host; // 'segmentfault.com:8080'
window.location.hostname; // 'segmentfault.com'

window.location.port; // '8080'

Par conséquent, host sera inclure le numéro de port, tandis que hostname renverra simplement le nom d'hôte

Comment changer l'attribut URL

Nous ne pouvons pas seulement appeler. location`. pour récupérer les informations d'URL, vous pouvez également l'utiliser pour définir de nouvelles propriétés et modifier l'URL

// 开始 'https://segmentfault.com/'

window.location.pathname = '/tidbits'; // 设置 pathname

// 结果 'https://segmentfault.com/tidbits'

Voici la liste complète des propriétés que vous pouvez modifier

// 事例
window.location.protocol = 'https'
               .host     = 'localhost:8080'
               .hostname = 'localhost'
               .port     = '8080'
               .pathname = 'path'
               .search   = 'query string' // (这里不用写 `?`)
               .hash     = 'hash' // (这里不用写 `#`)
               .href     = 'url'

La seule propriété. qui ne peut pas être défini est window.location.origin, cette propriété est en lecture seule

L'objet Location

window.location renvoie un Location. object. Informations sur l'adresse actuelle de la page. Mais nous pouvons également accéder à l'objet Location de plusieurs manières. La raison pour laquelle nous faisons cela est qu'il s'agit de variables globales dans notre navigateur 🎜>

window.location vs location

Explication détaillée de lobjet window.location dans JS (aide-mémoire)

Les quatre propriétés ci-dessus pointent toutes vers le même objet que je préfère personnellement et j'évite en fait d'utiliser . principalement parce que ressemble à une variable normale et que nous pourrions accidentellement la nommer variable, ce qui remplacerait une variable globale. Par exemple :

window.location          → Location
window.document.location → Location
document.location        → Location
location                 → Location

Je pense que la plupart des développeurs savent que Location est une variable globale. . Cela rend moins susceptible de prêter à confusion. Pour être honnête, je ne savais pas que window.location était une variable globale jusqu'à ce que j'écrive cet article. Il est recommandé d'utiliser location au lieu d'autres méthodes d'écriture location.

windowméthode window.location locationwindow.location

.

window.location.toString

根据 MDN :

此方法返回 URL 的 USVString,它是 Location.href 的只读版本。

换句话说,我们可以这样得到  href  的值:

// https://www.samanthaming.com

window.location.href; // https://www.samanthaming.com
window.location.toString(); // https://www.samanthaming.com

assign vs replace

这两种方法都是重定向或导航到另一个URL。区别在于assign 是将当前页面保存在历史记录中,因此用户可以使用“后退”按钮导航到该页面。而使用replace方法时,不会保存它。让我们来看一个例子。

Assign

1. 打开一个新的空白页
2. 输入 www.samanthaming.com (当前页)

3. 使用 `window.location.assign('https://www.w3schools.com')` 载入新页面
4. 按 "返回上一页"
5. 返回到了 ???? www.samanthaming.com

Replace

1. 打开一个新的空白页
2. 输入 www.samanthaming.com (当前页)

3. 使用 `window.location.assign('https://www.w3schools.com')` 载入新页面
4. 按 "返回上一页"
5. 返回到一个空白页

如何让页面重定向

如何重定向到另一个页面,有3种方法。

window.location.href = 'https://www.samanthaming.com';

window.location.assign('https://www.samanthaming.com');

window.location.replace('https://www.samanthaming.com');

replace vs assign vs href

这三个都可以重定向,区别在于浏览器的历史记录。hrefassign 会把当前页面保存在历史记录中,而replace则不会。因此,如果你想创建一种导航无法回到原始页面的体验,请使用replace????

现在的问题是hrefassign。我更喜欢assign,因为它是一种方法,因此感觉好像我正在执行一些操作。还有一个额外的好处是它更易于测试。我已经编写了许多Jest测试,因此通过使用一种方法,它使其更易于模拟。

window.location.assign = jest.fn();

myUrlUpdateFunction();

expect(window.location.assign).toBeCalledWith('http://my.url');

最终希望备忘单,希望能对你有所帮助,在需要的时候,能快速给你带来答案。谢谢大家的观看。

英文原文地址:https://morioh.com/p/b444d291bdfb

作者:Samantha Ming

译者:前端小智

更多编程相关知识,请访问:编程入门!!

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer