国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

history和hash詳解

marser / 1954人閱讀

摘要:另外該事件只針對同一個文檔,如果瀏覽歷史的切換,導致加載不同的文檔,該事件不會被觸發使用的時候,可以為事件指定回調函數或者回調函數的參數是一個事件對象,它的屬性指向和方法為當前所提供的狀態對象即這兩個方法的第一個參數。

一、history

window.history(可直接寫成history)指向History對象,它表示當前窗口的瀏覽歷史。
History對象保存了當前窗口訪問過的所有頁面網址

1. length

   history.length屬性保存著歷史記錄的url數量,初始時該值為1,如果當前窗口先后訪問了三個網址,那么history對象就包括3項,history.length=3

2.跳轉方法:允許在瀏覽器歷史之間移動

go()  接受一個整數為參數,移動到該整數指定的頁面,比如history.go(1)相當于history.forward(),history.go(-1)相當于history.back(),history.go(0)相當于刷新當前頁面
back()  移動到上一個訪問頁面,等同于瀏覽器的后退鍵,常見的返回上一頁就可以用back(),是從瀏覽器緩存中加載,而不是重新要求服務器發送新的網頁
forward()  移動到下一個訪問頁面,等同于瀏覽器的前進鍵

如果移動的位置超出了訪問歷史的邊界,以上三個方法并不報錯,而是默默的失敗

3.history.pushState()

在瀏覽器歷史中添加記錄

if(!!(window.hostory && history.pushState)) {
    // 支持History API
} else {
    // 不支持
}

以上代碼可以用來檢查當前瀏覽器是否支持History API。如果不支持的話可以考慮使用Polyfill庫History.js

history.pushstate()方法接受三個參數,以此為:

state: 一個與指定網址相關的狀態對象,popState事件觸發時,該對象會傳入回調函數,如果不需要這個對象,此處可填null
title: 新頁面的標題,但是所有瀏覽器目前都忽略這個值,因此這里可以填null
url: 新的網址,必須與當前頁面處在同一個域,瀏覽器的地址欄將顯示這個網址

假定當前網址是example.com/1.html,我們使用pushState方法在瀏覽記錄(history對象)中添加一個記錄

var stateObj = {foo:"bar"};
history.pushState(stateObj,"page 2","2.html")

添加上邊這個新紀錄后,瀏覽器地址欄立刻顯示example.com/2.html,但不會跳轉到2.html,甚至也不會檢查2.html是否存在,它只是成為瀏覽歷史中的新紀錄。這時,你在地址欄輸入一個新的地址,然后點擊了后退按鈕,頁面的url將顯示2.html;你再點擊以此后退按鈕,url將顯示1.html
總之,pushState方法不會觸發頁面刷新,只是導致了history對象發生變化,地址欄會有反應。
如果pushState的url參數,設置了一個新的錨點值(即hash),并不會觸發hashChange事件,如果設置了一個跨域網址,則會報錯。

//報錯
history.pushState(null,null,"https://twitter.com/hello")

上邊代碼中,pushState()想要插入一個跨域的網址,導致報錯,這樣設計的目的是防止惡意代碼讓用戶以為他們是在另一個網站上

4. history.replaceState()
history.replaceState()方法的參數和pushState()方法一摸一樣,區別是它修改瀏覽器歷史當中的記錄
假定當前頁面是example.com/example.html

history.pushState({page:1},"title 1","?page=1")
history.pushState({page:2},"title 2","?page=2")
history.replaceState({page:3},"title 3","?page=3")

history.back() //url顯示為example.com/example.html?page=1
history.back() //url顯示為example.com/example.html
history.go(2) //url顯示為example.com/example.html?page=3

5. history.state屬性
history.state返回當前頁面的state對象

history.pushState({page:1},"title 1","?page=1")
history.state  //{page:1}

5. popState 事件
每當同一個文檔的瀏覽歷史(即history)出現變化時,就會觸發popState事件
需要注意:僅僅調用pushState方法或replaceState方法,并不會觸發該事件,只有用戶點擊瀏覽器后退和前進按鈕時,或者使用js調用back、forward、go方法時才會觸發。另外該事件只針對同一個文檔,如果瀏覽歷史的切換,導致加載不同的文檔,該事件不會被觸發
使用的時候,可以為popState事件指定回調函數

window.onpopstate = function (event) {
  console.log("location: " + document.location);
  console.log("state: " +JSON.stringify(event.state));
};

// 或者

window.addEventListener("popstate", function(event) {
  console.log("location: " + document.location);
  console.log("state: " + JSON.stringify(event.state));
});

回調函數的參數是一個event事件對象,它的state屬性指向pushState和replaceState方法為當前url所提供的狀態對象(即這兩個方法的第一個參數)。上邊代碼中的event.state就是通過pushState和replaceState方法為當前url綁定的state對象
這個state也可以直接通過history對象讀取
history.state
注意:頁面第一次加載的時候,瀏覽器不會觸發popState事件

6.history.scrollRestoration

history.scrollRestoration = "manual";關閉瀏覽器自動滾動行為
history.scrollRestoration = "auto";打開瀏覽器自動滾動行為(默認)

二、hash
hash 就是指 url 尾巴后的 # 號以及后面的字符。這里的 # 和 css 里的 # 是一個意思。hash 也 稱作 錨點,本身是用來做頁面定位的,她可以使對應 id 的元素顯示在可視區域內。

通過window.location.hash獲取hash值

延伸:
window.location對象里面
hash  : 設置或返回從 (#) 開始的 URL(錨)。
host  : 設置或返回主機名和當前 URL 的端口號。
hostname:設置或返回當前 URL 的主機名。
href : 設置或返回完整的 URL。
pathname: 設置或返回當前 URL 的路徑部分。
port:設置或返回當前 URL 的端口號。
search : 設置或返回從問號 (?) 開始的 URL(查詢部分)。
assign() : 加載新的文檔。
reload() : 重新加載當前文檔。
replace() : 用新的文檔替換當前文檔。

hash主要是一個事件:hashchange,當hash值改變時會觸發這個事件
語法:window.onhashchange = fun
或者:
以上事件將覆蓋現有的事件處理程序,為了添加一個新的事件處理程序,而不覆蓋已有的其他的事件處理程序,可以使用函數"addEventListener"

window.addEventListener("hashchange",fun,false)

例子:

if("onhashchange" in window) {
   alert("該瀏覽器支持 hashchange 事件!");
}
function locationHashChanged() {
    if (location.hash === "#somecoolfeature") {
        somecoolfeature();
    }
}
window.onhashchange = locationHashChanged;

hashchange事件有兩個屬性:

newURL: string類型,當前頁面新的url
oldURL: string類型,當前頁面舊的url


window.addEventListener("hashchange", function (e) {
  console.log(e.newURL,e.oldURL)
  var str = e.newURL.split("#")[1]
  document.getElementById("num").innerHTML = str.split("=")[1]
})

三、vue-router中history和hash兩種模式的區別

在vue的路由配置中有mode選項 最直觀的區別就是在url中hash帶了一個很丑的#,而history是沒有#的

mode:"hash",
mode:"history"

hash和history模式的不同

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/104478.html

相關文章

  • 前端路由原理解析實現

    摘要:如何實現前端路由要實現前端路由,需要解決兩個核心如何改變卻不引起頁面刷新如何檢測變化了下面分別使用和兩種實現方式回答上面的兩個核心問題。 原文鏈接:github.com/whinc/blog/… 在單頁應用如此流行的今天,曾經令人驚嘆的前端路由已經成為各大框架的基礎標配,每個框架都提供了強大的路由功能,導致路由實現變的復雜。想要搞懂路由內部實現還是有些困難的,但是如果只想了解路由實現基本...

    lavor 評論0 收藏0
  • React Router 學習手冊(基礎篇)

    摘要:該手冊是基于和使用教程學習編寫而成,可能會有描述不夠清楚的地方,大家可自行參考原文,為提供了一個完整的路由庫,它允許你通過的變化來控制組件的切換與變化有關全家桶的其余相關文章,可以查看以下鏈接,會持續更新別眨眼看安裝使用進行安裝之后 該手冊是基于react-router 和 React Router 使用教程 學習編寫而成,可能會有描述不夠清楚的地方,大家可自行參考原文, React ...

    DobbyKim 評論0 收藏0
  • 跨文檔通信的7種方法

    摘要:摘要以下總結的跨文檔通信方法,均是在服務器不參與的情況下服務端無需特殊的代碼實現的這里的通信,是指頁面向頁面傳遞信息大致分為以下三類通過實現雙向通信通過客戶端存儲實現通信在頁面跳轉的過程中攜帶信息中其中第一種方法沒有跨域的限制,且實現的是雙 摘要 以下總結的跨文檔通信方法,均是在服務器不參與的情況下(服務端無需特殊的代碼)實現的 這里的通信,是指頁面A向頁面B傳遞信息 大致分為以下三類...

    阿羅 評論0 收藏0
  • 在單頁應用中,如何優雅的監聽url的變化

    摘要:單頁應用的原理從早起的根據的變化,到根據的的變化,實現無刷新條件下的頁面重新渲染。那么在單頁應用中是如何監聽的變化呢,本文將總結一下,如何在單頁頁面中優雅的監聽的變化。在下幾章中,重點介紹一下如何監聽的改變。 ??單頁應用的原理從早起的根據url的hash變化,到根據H5的history的變化,實現無刷新條件下的頁面重新渲染。那么在單頁應用中是如何監聽url的變化呢,本文將總結一下,...

    leap_frog 評論0 收藏0

發表評論

0條評論

marser

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<