diff options
author | Peter Bengtsson <mail@peterbe.com> | 2020-12-08 14:40:17 -0500 |
---|---|---|
committer | Peter Bengtsson <mail@peterbe.com> | 2020-12-08 14:40:17 -0500 |
commit | 33058f2b292b3a581333bdfb21b8f671898c5060 (patch) | |
tree | 51c3e392513ec574331b2d3f85c394445ea803c6 /files/zh-cn/web/api/hashchangeevent/index.html | |
parent | 8b66d724f7caf0157093fb09cfec8fbd0c6ad50a (diff) | |
download | translated-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.html | 135 |
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"><body onhashchange="funcRef();"> +</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 && 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> |