中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么-創(chuàng)新互聯(lián)

這篇文章主要介紹javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

創(chuàng)新互聯(lián)公司從2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元寧海做網(wǎng)站,已為上家服務(wù),為寧海各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575

背景

最近在上班過程中,遇到了這么一個(gè)需求,在多頁面應(yīng)用中,需要在幾個(gè)頁面上共用同一個(gè)數(shù)據(jù)來源,且切換頁面不刷新頁面數(shù)據(jù),并能實(shí)現(xiàn)歷史記錄的后退功能;因前期只考慮在一個(gè)頁面內(nèi)實(shí)現(xiàn)多個(gè)頁面的效果,并未考慮到歷史記錄堆棧中的處理,導(dǎo)致頁面會(huì)一次性推出入口,以下為總結(jié)的幾種解決方法。

hash

在URL中,#我們稱為位置標(biāo)識(shí)符,代表網(wǎng)頁的一個(gè)位置,在我們剛開始接觸到a標(biāo)簽的時(shí)候,我們很多人都有操作過錨點(diǎn)跳轉(zhuǎn),主要就是通過在 href 中設(shè)置想要跳到的位置的id值,在這個(gè)過程中,頁面是沒有刷新的,但歷史記錄卻新增了一條;我們利用window.location.hash可以取得當(dāng)前頁面的hash值,同時(shí)也可以也可以通過其寫入新的hash值,并通過監(jiān)聽hashchange事件,來檢測(cè)hash值是否發(fā)生了改變。當(dāng)我們?cè)冱c(diǎn)開彈框式的遮罩頁面的時(shí)候,可以手動(dòng)的去修改location.hash的值,這樣點(diǎn)擊window.history.back(),就可以實(shí)現(xiàn)歷史記錄回退;

例子

代碼如下:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        body{
            background: #ccc;
        }
        .colorBlock {
            border: 10px solid #fff;
            height: 40vh;
           width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
        }
        .colorBlue{
            border: 10px solid #fff;
            height: 40vh;
           width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
            background: cornflowerblue;
        }
        .colorgray{
            border: 10px solid #fff;
            height: 40vh;
           width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
            background: lightcoral;
        }
        .colorgreen{
            border: 10px solid #fff;
            height: 40vh;
           width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
            background: greenyellow;
        }
        .btnBlock{
            text-align: center;
        }
        .btn{
            border: 5px solid #ffffff;
            font-size: 24px;
            line-height: 50px;
           width: 40vh;
        }
    </style>
</head>
<body>
<div id="content">
    加載中....
</div>
<div>
    <button>change-url</button>
</div>
<script>
    (
        function () {
            var a=0;
            setInterval(function () {
                a++;
                document.getElementById("content").innerText=a;
            },1000)
        }
    )()
   window.addEventListener("hashchange",function (e) {
        var now=location.hash && location.hash.substring(1);
        switch (now){
            case "blue":
                document.getElementById("content").setAttribute("class","colorBlue");
                break;
            case "gray":
                document.getElementById("content").setAttribute("class","colorgray");
                break;
            case "green":
                document.getElementById("content").setAttribute("class","colorgreen");
                break;
        }

    },false);
    document.getElementsByClassName("btn")[0].addEventListener("click",function () {
        var now=location.hash && location.hash.substring(1);
        if(now=="blue"){
            location.hash="gray"
            document.getElementById("content").setAttribute("class","colorgray");
        }else if(now=="gray"){
            location.hash="green"
            document.getElementById("content").setAttribute("class","colorgreen");
        }else if(now=="green"){
            location.hash="blue"
            document.getElementById("content").setAttribute("class","colorBlue");
        }
    },false);
</script>
</body>
</html>

在瀏覽器中打開該頁面,并在路由上加上#blue,如下:

javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么

可看到如下頁面,初始條件下,頁面的顯示加載中...,而后定時(shí)器觸發(fā)更新,顯示遞增的數(shù)字,此時(shí)我們可以在控制臺(tái)中打印出對(duì)應(yīng)的history.length,其值為2:

javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么

javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么

接下來,我們通過點(diǎn)擊change-url 按鈕,去實(shí)現(xiàn)修改hash值,我們可以看到,對(duì)應(yīng)的路徑發(fā)生了改變,#blue變?yōu)?g'ra,背景顏色也對(duì)應(yīng)的更改,但此時(shí)遞增的數(shù)字沒有被刷新,說明我們的頁面并沒有經(jīng)過刷新重載的過程。

javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么

javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么

重新在控制臺(tái)輸入window.history.length可以看到,其值已經(jīng)變?yōu)?,點(diǎn)擊瀏覽器后退箭頭,頁面背景改為之前的藍(lán)色背景,到這里,我們就實(shí)現(xiàn)我們想要的功能;

javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么

history.pushState

除了上面講到的方法外,通過html5新增的history.pushState也可以實(shí)現(xiàn)同樣的效果;
history.pushState和history.replaceState同是html5新增的api,都可以實(shí)現(xiàn)改變狀態(tài)欄的url而不刷新頁面,但兩者的區(qū)別是,replaceState是替換當(dāng)前地址為指定的url,而pushState則是創(chuàng)建一條新的歷史紀(jì)錄。執(zhí)行history.back()和history.forward()后會(huì)觸發(fā)window.onpopstate事件。

API

history.pushState(state,title,url)
state:對(duì)象,可以存放一些數(shù)據(jù)表示當(dāng)前的狀態(tài)。當(dāng)瀏覽器執(zhí)行前進(jìn)或在后退的時(shí)候,會(huì)觸發(fā)onpopState事件,state將會(huì)是event對(duì)象的屬性對(duì)象,可以通過event.state訪問;需要注意的是,statez中的屬性值不能為對(duì)象。url為將要替換的地址;如果是puhState則會(huì)添加一條歷史記錄;

例子

我們同樣可以用上面的例子來測(cè)試,只不過,我們需要監(jiān)聽的是popstate事件,新建歷史記錄,將當(dāng)前信息保存到history.state中,

history.pushState && window.addEventListener("popstate",function(e){})
history.pushState && history.pushState(state,title,url)

以上是javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

當(dāng)前題目:javascript實(shí)現(xiàn)不重載頁面前提下創(chuàng)建一條歷史紀(jì)錄的方法是什么-創(chuàng)新互聯(lián)
本文地址:http://m.rwnh.cn/article38/hsssp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈網(wǎng)站排名、手機(jī)網(wǎng)站建設(shè)、App開發(fā)、網(wǎng)頁設(shè)計(jì)公司網(wǎng)站維護(hù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
庆云县| 扶余县| 连江县| 湘潭市| 满城县| 武清区| 开远市| 洪江市| 子洲县| 时尚| 永靖县| 盱眙县| 锦屏县| 延寿县| 永城市| 林甸县| 林州市| 新昌县| 隆昌县| 蓝山县| 穆棱市| 威信县| 曲沃县| 绥棱县| 枣庄市| 府谷县| 定南县| 同江市| 洛南县| 天气| 元阳县| 迁西县| 江孜县| 鲁甸县| 西乌| 连江县| 轮台县| 正阳县| 马公市| 沽源县| 湖口县|