首頁  >  文章  >  web前端  >  JS hash製作單頁Web應用實例分享

JS hash製作單頁Web應用實例分享

小云云
小云云原創
2018-01-26 10:54:351381瀏覽

本文我們會先從hash是什麼,hash有什麼作用以及何為單頁Web應用開始講解,後面將會介紹到JS hash製作單頁Web應用實例,希望能幫助到大家。

一、何為hash

這裡要講的hash(也叫哈希),指的是JS中location物件的hash屬性,它回傳的是URL中#後所接的零個或多個字元。通常,我們可以透過location.hash的方式來取得哈希值或設定哈希值。當然,我們也可以透過設定a標籤的href屬性來設定哈希值,當使用者點擊該a標籤時即可改變頁面的哈希值。

例如:

/** JS方式 **/
location.hash = 'hash'; //设置hash,该代码执行后URL后面增加“#hash”字符串
console.log(location.hash); //获取hash
/** HTML方式 **/
<a href="#hash" rel="external nofollow" >点击改变hash</a> <!-- 点击后URL后面增加“#hash”字符串 -->

值得注意的是,無論以何種方式改變雜湊值,頁面都不會重新整理。

二、hash有何用處

1. 設定錨連結

#透過設定錨連結(即為上述HTML方式),可使點擊連結後頁面根據元素id滑動到指定位置,即使頁面跳轉後也不例外。

2. 實作單頁應用的製作

可以根據雜湊值的變化來使對應元素顯示或隱藏,從而實現頁面無刷新的單頁切換。

三、何為單頁Web應用

單頁Web應用(single page web application,SPA),就是只有一張Web頁面的應用,是載入單一HTML 頁面並在用戶與應用程式互動時動態更新該頁面的網頁應用程式。

以上是百度百科對單頁應用(SPA)的解釋,而使用hash可以非常方便的實現「頁面」間的切換。

四、如何使用hash製作SPA

簡單來說,就是先只顯示第一個page,然後透過改變hash值來切換顯示不同的page,前一個page隱藏。
這裡寫個簡單的Demo示範一下吧:

1. 先寫好HTML結構

<article class="container">
 <section id="page1" class="page cur">第一页</section>
 <section id="page2" class="page">第二页</section>
 <section id="page3" class="page">第三页</section>
</article>
<nav id="nav" class="bottom-nav">
 <ul>
  <li>第一页</li>
  <li>第二页</li>
  <li>第三页</li>
 </ul>
</nav>

2. 然後為其設定CSS樣式

.page{ display: none; /* 其他样式省略 */}
.page.cur{ display: block;}
/* 其他样式省略 */

3.寫Javascript,實作單頁切換

window.onload = function () {
 var nav = document.getElementById('nav');
 var navLi = nav.getElementsByTagName('li');
 for(var i = 0,len = navLi.length; i < len; i++){
  (function (i) { 
   navLi[i].onclick = function () { //点击nav中的li,改变hash值
    location.hash = 'page' + (i+1);
   }
  })(i);
 }
 location.hash = 'page1'; //每次页面重新加载时都回到page1
 window.onhashchange = function (e) { 
  //当hash变化时,执行hashchange事件,该事件具有oldURL和newURL两个事件属性,分别代表前一个URL和目前的URL
  var oldHash = e.oldURL.split('#')[1]; //取得前一个hash
  var newHash = e.newURL.split('#')[1]; //取得当前hash
  var oldPage = document.getElementById(oldHash);
  var newPage = document.getElementById(newHash);
  oldPage.classList.remove('cur'); //隐藏前一个page
  newPage.classList.add('cur');  //显示当前page
 };
}

這裡有幾個地方要注意的是,IE並不相容於oldURL和newURL這兩個屬性,所以該方法有一定的限制。當然,更好的方法是,一開始將hash值用變數存起來當作oldHash,具體方法如下:

/**** 前面代码省略 ****/
location.hash = 'page1';
var oldHash = location.hash;
window.onhashchange = function (e) {
 var newHash = location.hash;
 var oldPage = document.querySelector(oldHash);
 var newPage = document.querySelector(newHash);
 oldPage.classList.remove('cur');
 newPage.classList.add('cur');
 oldHash = newHash;
};

這裡還有一個地方要注意,就是classList在IE9及其以下瀏覽器不相容,最好透過處理className屬性的方式來實現相同的效果,此處便不再詳述。

相關推薦:

程式設計師進階篇之hash表的脾臟性

php hash加密函數範例程式碼

MySQL之btree與hash兩種索引的差異

以上是JS hash製作單頁Web應用實例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn