站長資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        history解決ajax出現(xiàn)的問題

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

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

        事件描述:

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

        window.history.pushState描述:

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

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

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

        url:用來傳遞新的history實體的URL,瀏覽器將不會在調(diào)用pushState()方法后加載這個URL。也許會過一會嘗試加載這個URL。比如在用戶重啟了瀏覽器后,新的url可以不是絕對路徑。如果是相對路徑,那么它會相對于現(xiàn)有的url。新的url必須和現(xiàn)有的url同域,否則pushState()將拋出異常。這個參數(shù)是選填的,如果為空,則會被置為document當(dāng)前的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>導(dǎo)演</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頁面調(diào)用js文件就可看到運行結(jié)果。

        運行結(jié)果:

        history解決ajax出現(xiàn)的問題

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

        附瀏覽器兼容性:

        history解決ajax出現(xiàn)的問題

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
        主站蜘蛛池模板: 久夜色精品国产一区二区三区| 亚洲欧美国产精品第1页| 国产在线观看一区二区三区精品| 亚洲日韩精品无码专区网站| 国产VA免费精品高清在线| 国产精品无码成人午夜电影| 无码人妻精品一区二| 国产精品高清在线| 国内精品久久久久久野外| 久久精品国产亚洲AV电影| 无码国内精品久久人妻麻豆按摩| 国产三级精品三级| MM1313亚洲精品无码| 精品一卡2卡三卡4卡免费视频| 精品国产一区AV天美传媒| 亚洲乱码精品久久久久..| 免费短视频软件精品一区二区| 国产99久久九九精品无码| 国产精品一久久香蕉产线看| 国产精品人成在线播放新网站| 亚洲AV无码久久精品蜜桃| 日韩午夜高清福利片在线观看欧美亚洲精品suv | 麻豆国内精品欧美在线| 91精品视频在线| 91精品久久久久久无码| 成人国产精品秘 果冻传媒在线| 久久久国产精品网站| 日本一区精品久久久久影院| 久久精品国产99国产精品澳门| 久久精品国产一区二区三区日韩| 国产精品视频免费观看| 久久91精品国产91久久小草| 久久精品成人国产午夜| 真实国产乱子伦精品免费| 亚洲国产成人久久精品影视| 亚洲精品无码不卡| www.日韩精品| 欧美日韩国产中文精品字幕自在自线| 日本一区二区三区精品国产| 中文字幕精品一区二区精品| 亚洲国产精品无码AAA片|