站長資訊網
        最全最豐富的資訊網站

        history解決ajax出現的問題

        以下內容是關于Jquery.history解決ajax的前進后退問題,具體詳情請看下文。

        本文的前提是基于后臺的,所以這里不會考慮seo的問題。同時,基于后臺的管理系統,也不需要被收藏,所以也不會考慮刷新的這種類似直接敲網址的情況!!!

        事件描述:

        H5增加了一個事件window.onpopstate,當用戶點擊那兩個按鈕就會觸 發這個事件。但是光檢測到這個事件是不夠的,還得能夠傳些參數,也就是說返回到之前那個頁面的時候得知道那個頁面的pageIndex。通過 history的pushState方法可以做到,pushState(pageIndex)將當前頁的pageIndex存起來,再返回到這個 頁面時獲取到這個pageIndex。

        window.history.pushState描述:

        window.history.pushState(state, title, url);

        state對象:是一個JavaScript對象,它關系到由pushState()方法創建出來的新的history實體。用以存儲關于你所要插入到歷史 記錄的條目的相關信息。State對象可以是任何Json字符串。因為firefox會使用用戶的硬盤來存取state對象,這個對象的最大存儲空間為640k。如果大于這個數 值,則pushState()方法會拋出一個異常。

        title:firefox現在回忽略這個參數,雖然它可能將來會被使用上。而現在最安全的使用方式是傳一個空字符串,以防止將來的修改。

        url:用來傳遞新的history實體的URL,瀏覽器將不會在調用pushState()方法后加載這個URL。也許會過一會嘗試加載這個URL。比如在用戶重啟了瀏覽器后,新的url可以不是絕對路徑。如果是相對路徑,那么它會相對于現有的url。新的url必須和現有的url同域,否則pushState()將拋出異常。這個參數是選填的,如果為空,則會被置為document當前的url。

        直接貼代碼:

                 (      loadData=         pageIndex:window.history.state===?1                  init:             .getData(                       getData:              that=                  type:'post'                 url:'./data/getMovices'+pageIndex+'.json'                 dataType:'json'                 async:                 success:             renderDom:              bookHtml=                 "<table>"+                 "<tr>"+                 "<th>電影</th>>"+                 "<th>導演</th>"+                 "<th>上映時間</th>"+                 "</tr>"             ( i=0;i<movies.length;i++                 bookHtml +=                     "<tr>" +                     "   <td>" + movies[i].moviesName + "</td>" +                     "   <td><a>" + movies[i].moviesEditor + "</a></td>" +                     "   <td>" + movies[i].times + "</td>" +                     "</tr>"              bookHtml+="</table>"             bookHtml +=                 "<button>上一頁</button>" +                 "<button class='nextPage'>下一頁</button>"             $('body'          nextPage:              that=             $(document).on("click",".nextPage",                 that.pageIndex++                  window.history.pushState({page:that.pageIndex},                          window.addEventListener("popstate",          page=0         (event.state!==             page=             console.log('page:'+          console.log('page:'+          loadData.pageIndex=   })(jQuery,window,undefined);

        通過直接在html頁面調用js文件就可看到運行結果。

        運行結果:

        history解決ajax出現的問題

        這樣就可以達到通過ajax進行交互也能實現監聽前進/后臺/刷新的功能了。

        附瀏覽器兼容性:

        history解決ajax出現的問題

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产亚洲精品无码拍拍拍色欲 | 久久精品无码专区免费| 精品日韩亚洲AV无码| 黑人巨大精品欧美一区二区| 国产精品免费无遮挡无码永久视频| 欧美成人精品一区二区综合| 欧美+亚洲+精品+三区| 老司机亚洲精品影院| 合区精品中文字幕| 精品人妻V?出轨中文字幕| 成人国产一区二区三区精品| 99久久这里只有精品| 精品国产乱码久久久久久1区2区| 亚洲精品无码AV中文字幕电影网站 | 精品97国产免费人成视频| 亚洲综合精品香蕉久久网97| 2021久久精品国产99国产精品| 无码精品A∨在线观看中文| 无码人妻精品一区二区蜜桃百度 | 亚洲国产精品自产在线播放| 国产成人精品久久二区二区| 人妻少妇精品中文字幕AV| 欧美精品色精品一区二区三区| 国产精品第一页在线| 亚洲精品欧美综合在线| 国产精品视频一区二区三区经| 国产亚洲精品无码成人| 久久亚洲日韩精品一区二区三区| 无码国产精品一区二区免费16| 香港三级精品三级在线专区| 九九久久精品国产| 精品久久久久中文字| 久热精品视频第一页| 欧美人与性动交α欧美精品成人色XXXX视频 | 欧美性videofree精品| 久久青草国产精品一区| 亚洲国产精品久久久久| 日本精品久久久久中文字幕| 亚洲精品在线观看视频| 国产精品 羞羞答答在线| 国产精品国产三级在线专区 |