如何解决pushState 导致“无法在原点为‘null’的文档中创建”
当单击以下 div 元素中的文本时,我试图将状态推送到浏览器历史记录:
<!DOCTYPE html>
<head>
</head>
<body>
<div onclick="onNavigate('/tester')">link</div>
<script>const onNavigate = path => history.pushState("","",window.location.pathname + path)</script>
</body>
</html>
我得到一个
未捕获的 DOMException 错误:无法执行 “History”上的“pushState”:URL 为“无法在“History”上执行“pushState”的历史状态对象:URL 为“file://[path-to-file]/index.html/tester”的历史状态对象' 不能在原点为 'null' 且 URL 为 'file://[path-to-file]/index.html' 的文档中创建。无法在来源为“null”且 URL 为“file://[path-to-file]/index.html”的文档中创建。
有很多与 pushState()
和 replaceState()
相关的类似帖子 - 就像这个 History pushState throws Uncaught DOMException,但没有一个提供有效的解决方案。
我也试过用 location.href
而不是 location.pathname
没有成功。
怎么了?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。