aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/api/hashchangeevent/index.html
diff options
context:
space:
mode:
authorPeter Bengtsson <mail@peterbe.com>2020-12-08 14:40:17 -0500
committerPeter Bengtsson <mail@peterbe.com>2020-12-08 14:40:17 -0500
commit33058f2b292b3a581333bdfb21b8f671898c5060 (patch)
tree51c3e392513ec574331b2d3f85c394445ea803c6 /files/zh-cn/web/api/hashchangeevent/index.html
parent8b66d724f7caf0157093fb09cfec8fbd0c6ad50a (diff)
downloadtranslated-content-33058f2b292b3a581333bdfb21b8f671898c5060.tar.gz
translated-content-33058f2b292b3a581333bdfb21b8f671898c5060.tar.bz2
translated-content-33058f2b292b3a581333bdfb21b8f671898c5060.zip
initial commit
Diffstat (limited to 'files/zh-cn/web/api/hashchangeevent/index.html')
-rw-r--r--files/zh-cn/web/api/hashchangeevent/index.html135
1 files changed, 135 insertions, 0 deletions
diff --git a/files/zh-cn/web/api/hashchangeevent/index.html b/files/zh-cn/web/api/hashchangeevent/index.html
new file mode 100644
index 0000000000..bb45095bac
--- /dev/null
+++ b/files/zh-cn/web/api/hashchangeevent/index.html
@@ -0,0 +1,135 @@
+---
+title: HashChangeEvent
+slug: Web/API/HashChangeEvent
+tags:
+ - API
+ - Event
+ - HTML5
+ - HashChange
+ - 事件
+ - 参考
+ - 接口
+translation_of: Web/API/HashChangeEvent
+---
+<div>{{APIRef("HTML DOM")}}</div>
+
+<p><code><strong>HashChangeEvent</strong></code> 接口表示一个变化事件,当 URL 中的片段标识符发生改变时,会触发此事件。</p>
+
+<p>片段标识符指 URL 中 <code>#</code> 号和它以后的部分。</p>
+
+<p>{{InheritanceDiagram}}</p>
+
+<h2 id="属性">属性</h2>
+
+<p><em> 这个接口也从 {{domxref("Event")}} 中继承属性。</em></p>
+
+<dl>
+ <dt>{{domxref("HashChangeEvent.newURL")}} {{readonlyInline}} {{gecko_minversion_inline("6.0")}}</dt>
+ <dd>window即将导航到达的新 URL。</dd>
+ <dt>{{domxref("HashChangeEvent.oldURL")}} {{readonlyInline}} {{gecko_minversion_inline("6.0")}}</dt>
+ <dd>window此前导航到达过的URL。</dd>
+</dl>
+
+<h2 id="方法">方法</h2>
+
+<p><em>这个接口没有自己的方法,但从 {{domxref("Event")}} 中继承方法</em></p>
+
+<h2 id="示例">示例</h2>
+
+<h3 id="井号内容变化的语法选择">井号内容变化的语法选择</h3>
+
+<p>你可以选择使用下述的任一方法监听 {{event("hashchange")}} 事件。</p>
+
+<pre class="brush: js">window.onhashchange = funcRef;
+</pre>
+
+<p><strong>或</strong></p>
+
+<pre class="brush: html">&lt;body onhashchange="funcRef();"&gt;
+</pre>
+
+<p><strong>或</strong></p>
+
+<pre class="brush: js">window.addEventListener("hashchange", funcRef, false);
+</pre>
+
+<h3 id="基本示例">基本示例</h3>
+
+<pre class="brush:js">function locationHashChanged() {
+ if (location.hash === '#somecoolfeature') {
+ somecoolfeature();
+ }
+}
+
+window.addEventListener('hashchange', locationHashChanged);
+</pre>
+
+<dl>
+</dl>
+
+<h2 id="回落方法(Polyfill)">回落方法(Polyfill)</h2>
+
+<p>在 <a href="https://github.com/Modernizr/Modernizr/wiki/HTML5-Cross-Browser-Polyfills">Modernizr GitHub page</a> 中列出了几种回落(fallback)脚本。基本上,这些脚本每隔一段时间检查以此 {{domxref("HTMLHyperlinkElementUtils.hash", "location.hash")}}。这里是其中一个版本,其仅允许一个处理程序(handler)绑定在 {{domxref("WindowEventHandlers.onhashchange", "onhashchange")}} 属性上:</p>
+
+<pre class="brush:js;">(function(window) {
+
+ // 如果浏览器已经实现了此事件,则退出函数
+ if ( "onhashchange" in window.document.body ) return;
+
+ var location = window.location,
+ oldURL = location.href,
+ oldHash = location.hash;
+
+ // 每隔 100 毫秒,检查一次片段标识符
+ setInterval(function() {
+ var newURL = location.href,
+ newHash = location.hash;
+
+ // 如果片段标识符有变化,且处理程序存在
+ if ( newHash != oldHash &amp;&amp; typeof window.onhashchange === "function" ) {
+ // 执行处理程序
+ window.onhashchange({
+ type: "hashchange",
+ oldURL: oldURL,
+ newURL: newURL
+ });
+
+ oldURL = newURL;
+ oldHash = newHash;
+ }
+ }, 100);
+
+})(window);
+</pre>
+
+<h2 id="规范">规范</h2>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">规范</th>
+ <th scope="col">状态</th>
+ <th scope="col">备注</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>{{SpecName("HTML WHATWG", "#hashchangeevent", "HashChangeEvent")}}</td>
+ <td>{{Spec2("HTML WHATWG")}}</td>
+ <td>Initial definition</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="浏览器兼容性">浏览器兼容性</h2>
+
+
+
+<p>{{Compat("api.HashChangeEvent")}}</p>
+
+<h2 id="相关事件">相关事件</h2>
+
+<ul>
+ <li>{{event("hashchange")}}</li>
+ <li>{{event("popstate")}}</li>
+</ul>