• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    ajax后退解決方案

    來源:懂視網 責編:小采 時間:2020-11-27 22:52:27
    文檔

    ajax后退解決方案

    ajax后退解決方案:一、使用iframe,通過document.write產生歷史 代碼如下:<!DOCTYPE html> <html> <head> <meta charset=utf-8/> <title>0</title> </head> <body>
    推薦度:
    導讀ajax后退解決方案:一、使用iframe,通過document.write產生歷史 代碼如下:<!DOCTYPE html> <html> <head> <meta charset=utf-8/> <title>0</title> </head> <body>

    一、使用iframe,通過document.write產生歷史
    代碼如下:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8"/>
    <title>0</title>
    </head>
    <body>
    <input type="button" value="加1" onclick="add()" />
    <div id="info" style="border:red 1px solid;width:200px;padding:10px;margin:5px;">0</div>
    </body>
    </html>
    <script src="history-0.1.js"></script>
    <script>
    var info = document.getElementById('info');
    var i = 1;
    function add() {
    info.innerHTML = i;
    document.title = i;
    var data = {
    param : i,
    func : func
    };
    History.push(data);
    i++;
    }
    History.push({param:0, func: func});
    function func(i) {
    info.innerHTML = i;
    document.title = i;
    }
    </script>

    點擊按鈕后更新頁面DOM(模擬ajax提交),會發現瀏覽器后退按鈕可用了。點擊后退,可返回到前一個狀態。
    這種方式缺點是只支持IE和Firefox。
    ajax后退解決方案(二)
    二、使用iframe,通過修改iframe.src產生歷史
    代碼如下:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8" />
    <title>0</title>
    </head>
    <body>
    <input type="button" value="加1" onclick="add()" />
    <div id="info" style="border:red 1px solid;width:200px;padding:10px;margin:5px;">0</div>
    </body>
    </html>
    <script src="history-0.2.js"></script>
    <script>
    var info = document.getElementById('info');
    var i = 1;
    function add() {
    info.innerHTML = i;
    document.title = i;
    var data = {
    param : i,
    func : func
    };
    History.push(data);
    i++;
    }
    History.push({param:0, func: func});
    function func(i) {
    info.innerHTML = i;
    document.title = i;
    }
    </script>

    較上一篇多了個blank.html,是一個空html架子,沒有JS邏輯代碼,如下
    代碼如下:

    <!DOCTYPE HTML>
    <html>
    <head>
    <title>blank.html</title>
    </head>
    <body>
    </body>
    </html>

    每次ajax操作會往iframe.src的問號后附加一個數字以記錄歷史。點擊后退按鈕,iframe的onload事件中獲取iframe的url,根據問號后的數字去取記錄。
    所有瀏覽器均支持該方式。缺點是如果主頁面中存在其它iframe,且修改了其src。歷史管理會混亂。
    三、使用iframe,通過修改iframe.src產生歷史,回調寫在iframe對應的html頁面中
    代碼如下:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8" />
    <title>0</title>
    </head>
    <body>
    <input type="button" value="加1" onclick="add()" />
    <div id="info" style="border:red 1px solid;width:200px;padding:10px;">0</div>
    </body>
    </html>
    <script src="history-0.3.js"></script>
    <script>
    var info = document.getElementById('info');
    var i = 1;
    function add() {
    var data = {
    param : i,
    func : func
    };
    History.push(data);
    i++;
    }
    History.push({param:0, func: func});
    function func(i) {
    info.innerHTML = i;
    document.title = i;
    }
    </script>

    與方案2相同也是使用iframe.src來產生歷史,也需要一個單獨的html頁面(iframe)。不同的是回調邏輯不是寫在iframe.onload中,而直接寫在html頁面中(上一篇則是空的html架子)。blank.html如下
    代碼如下:

    <!DOCTYPE HTML>
    <html>
    <head>
    <title>blank.html</title>
    </head>
    <body>
    <script>
    var url= location.href;
    if(url.indexOf('?')>-1) {
    var idx = url.substr(url.indexOf('?')+1);
    parent.History.get(idx);
    }
    </script>
    </body>
    </html>

    和方案2一樣所有瀏覽器均支持。
    四、通過修改location.hash產生歷史,hashchange事件處理后退
    代碼如下:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8" />
    <title>0</title>
    </head>
    <body>
    <input type="button" value="加1" onclick="add()" />
    <div id="info" style="border:red 1px solid;width:200px;padding:10px;">0</div>
    </body>
    </html>
    <script src="history-0.4.js"></script>
    <script>
    var info = document.getElementById('info');
    var i = 1;
    function add() {
    var data = {
    param : i,
    func : func
    };
    History.push(data);
    i++;
    }
    History.push({param:0, func: func});
    function func(i) {
    info.innerHTML = i;
    document.title = i;
    }
    </script>

    每次ajax操作去改變location.hash的值,每次修改后地址欄均會有所體現。在window.onhashchange中監聽該事件。通過hash的值取對應的歷史。
    較iframe的好處是可以復制地址欄的url直接進入該歷史記錄,缺點是IE6/7不支持。
    文中代碼打包下載

    相關:

    http://msdn.microsoft.com/en-us/library/cc288209(v=vs.85).aspx

    https://developer.mozilla.org/en/DOM/window.onhashchange

    http://www.whatwg.org/specs/web-apps/current-work/multipage/history.html#event-hashchange

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    ajax后退解決方案

    ajax后退解決方案:一、使用iframe,通過document.write產生歷史 代碼如下:<!DOCTYPE html> <html> <head> <meta charset=utf-8/> <title>0</title> </head> <body>
    推薦度:
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 2021国产精品视频| 在线电影国产精品| 国产成人精品怡红院在线观看| 中文字幕久久精品无码| 99久久精品国产毛片| 国产亚洲精品自在久久| 亚洲日韩国产精品乱| 久久99精品久久久久久齐齐| 国产精品一区在线播放| 亚洲高清专区日韩精品| 久久精品二区| 91不卡在线精品国产| 69SEX久久精品国产麻豆| 亚洲国产精品VA在线观看麻豆| 久久精品亚洲福利| 国内精品伊人久久久久影院对白| 精品人妻少妇嫩草AV无码专区| 麻豆精品三级全部视频| 亚洲国产精品人久久| 国产精品久久久久久福利69堂| 久久久久久亚洲Av无码精品专口| 一本色道久久88—综合亚洲精品| 日韩精品欧美| 精品国产午夜福利在线观看| 日韩精品www| 午夜精品福利视频| 国产欧美久久久精品| 国产成人精品男人的天堂538| 国产精品免费福利久久| 国产麻豆一精品一AV一免费| 亚洲精品成人无码中文毛片不卡| 亚洲精品国产电影| 中文字幕精品一区| 亚洲线精品一区二区三区| 在线精品亚洲一区二区三区| 亚洲A∨午夜成人片精品网站| 无码8090精品久久一区| 亚洲综合国产精品第一页| 亚洲国产精品无码一线岛国| 亚洲精品无码久久久久去q | 亚洲国产精品无码久久98|