NavigateEvent:canIntercept 属性
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
NavigateEvent 接口的 canIntercept 只读属性在可以拦截导航并重写其 URL 时返回 true,否则返回 false。
关于何时可以拦截导航,有几条规则。例如:
- 你不能拦截跨源导航。
- 对于
http或httpsURL,仅当新 URL 的path、query和fragment部分与当前 URL 不同时可以拦截。 - 对于
fileURL,仅当新 URL 的query和fragment部分不同时可以拦截。 - 对于其他 URL 类型,仅当
fragment部分不同时可以拦截导航。
请参阅规范以获取有关何时可以重写文档的 URL 的更多解释,其中包括示例表格。
值
布尔值——如果可以拦截导航则为 true,否则为 false。
示例
js
navigation.addEventListener("navigate", (event) => {
// 有些导航,例如跨源导航,我们无法拦截。让浏览器正常处理这些导航。
if (!event.canIntercept) {
return;
}
// 不要拦截片段导航或下载。
if (event.hashChange || event.downloadRequest !== null) {
return;
}
event.intercept({
handler() {
if (event.formData) {
processFormDataAndUpdateUI(event.formData, event.signal);
} else {
doSinglePageAppNav(event.destination, event.signal);
}
},
});
});
规范
| Specification |
|---|
| HTML> # dom-navigateevent-canintercept-dev> |
浏览器兼容性
Loading…
参见
- 现代客户端路由:导航 API
- 导航 API 说明
- Domenic Denicola 的导航 API 在线演示