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

        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瑜伽| 国产精品久久久久一区二区三区| 精品久久一区二区三区| 国产剧情国产精品一区| 午夜精品久久久久久中宇| 日韩精品国产自在欧美| 精品国产福利尤物免费| 国产精品自产拍在线观看花钱看| 五月花精品视频在线观看| 精品亚洲一区二区| 99久久精品国产高清一区二区| 久久精品国产亚洲AV高清热| 日产精品久久久久久久性色| 亚洲精品国产成人片| 亚洲性日韩精品一区二区三区| 国产精品va在线观看无码| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久青青草原精品国产 | 国产精品白丝jkav网站| 国产成人AV无码精品| 国产精品va在线观看无码| 国产精品单位女同事在线| 88国产精品欧美一区二区三区| 91麻精品国产91久久久久| 99精品人妻少妇一区二区| Aⅴ精品无码无卡在线观看| 91国内揄拍国内精品情侣对白| 午夜精品美女写真福利| 亚洲国产精品自在在线观看 | 精品国产福利在线观看| 精品久久久久香蕉网| 国精品无码一区二区三区左线| 精品不卡一区二区| 69国产成人综合久久精品| 久久国产亚洲精品麻豆| 国产精品九九九|