成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

JS返回頁(yè)面時(shí)自動(dòng)回滾到歷史瀏覽位置

在我的系統(tǒng)實(shí)際開發(fā)過(guò)程中遇到一個(gè)需求,我需要讓應(yīng)用在各個(gè)頁(yè)面間跳轉(zhuǎn)時(shí)回到每頁(yè)原先瀏覽到的位置,方便用戶使用。

成都創(chuàng)新互聯(lián)2013年至今,先為蘭坪等服務(wù)建站,蘭坪等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為蘭坪企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。

在網(wǎng)上查資料時(shí),看到的方案有不少,眾說(shuō)紛紜,但真正給出可行可用代碼的寥寥無(wú)幾,所以我干脆按自己的想法用SessionStorage寫了一個(gè)緩存頁(yè)面的方法,在離開頁(yè)面時(shí)將需要緩存的容器中所有內(nèi)容都存到SessionStorage中,在返回頁(yè)面時(shí)重新加載,方便用戶操作,效果如下:

JS返回頁(yè)面時(shí)自動(dòng)回滾到歷史瀏覽位置

頁(yè)面緩存

使用方法

用法也很簡(jiǎn)單,咱一步一步講。

首先,在你需要緩存標(biāo)簽容器的類名中加入cache,并寫一個(gè)name作為該容器的唯一標(biāo)記,示例如下:

<div class="weui-tab cache" name="index">
 ....
</div>

其次,聲明全局變量,獲取緩存內(nèi)容和容器,示例如下:

var cache;
var cacheId = $(".cache").attr("name");

隨后,在頁(yè)面加載時(shí)調(diào)用緩存,在離開頁(yè)面時(shí)生成緩存,代碼如下:

window.onload = function () {
 //載入緩存的列表
 loadCache(cacheId);
}

window.onunload = function () {
 //可以通過(guò)needCache這個(gè)flag來(lái)控制是否需要緩存
 if (localStorage.needCache == 'true') {
  //離開頁(yè)面時(shí)生成緩存
  createCache(cacheId);
 }
}

/* *
 * @brief 可對(duì)指定多個(gè)控件進(jìn)行內(nèi)容和位置的緩存
 * @param cacheId 緩存元素的id
 * @return null
 * */
function createCache(cacheId) {
 //對(duì)內(nèi)容進(jìn)行緩存
 var list = [];
 var listController = $('.cache');
 $.each(listController, function (index, value, array) {
  list.push(value.innerHTML);
 })
 //對(duì)瀏覽到的位置進(jìn)行緩存
 var top = [];
 var topController = $(".cache").find(".top");
 $.each(topController, function (index, value, array) {
  top.push(value.scrollTop);
 })
 //存入sessionstorage中
 sessionStorage.setItem(cacheId, JSON.stringify({
  list: list,
  top: top
 }));
}

/* *
 * @breif 可對(duì)指定多個(gè)控件加載緩存
 * @param 加載緩存的id
 * @return null
 * */
function loadCache(cacheId) {
 //一定要放在整個(gè)js文件最前面
 cache = sessionStorage.getItem(cacheId);
 if (cache) {
  cache = JSON.parse(cache);
  //還原內(nèi)容
  var listController = $('.cache');
  $.each(listController, function (index, value, array) {
   value.innerHTML = cache.list[index];
  })
  //還原位置
  var topController = $(".cache").find(".top");
  $.each(topController, function (index, value, array) {
   value.scrollTop = cache.top[index];
  })
 }
}

大部分都可以直接copy,再根據(jù)你的需要改進(jìn)一下,就可以很好的使用了。

github傳送地址: https://github.com/JunJieDing666/YouZhiGou

總結(jié)

以上所述是小編給大家介紹的JS返回頁(yè)面時(shí)自動(dòng)回滾到歷史瀏覽位置,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)創(chuàng)新互聯(lián)網(wǎng)站的支持!

本文名稱:JS返回頁(yè)面時(shí)自動(dòng)回滾到歷史瀏覽位置
當(dāng)前鏈接:http://jinyejixie.com/article18/jojsdp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、軟件開發(fā)服務(wù)器托管、網(wǎng)站排名、搜索引擎優(yōu)化Google

廣告

聲明:本網(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í)需注明來(lái)源: 創(chuàng)新互聯(lián)

營(yíng)銷型網(wǎng)站建設(shè)
民乐县| 疏附县| 太和县| 榆中县| 泉州市| 修武县| 东阳市| 团风县| 衡阳市| 东宁县| 乐亭县| 焉耆| 潼关县| 蒲江县| 乳山市| 抚顺县| 祁连县| 屯昌县| 星子县| 台东县| 菏泽市| 石柱| 祥云县| 郧西县| 怀来县| 兴文县| 普兰店市| 洱源县| 搜索| 武夷山市| 河北区| 鸡泽县| 娄底市| 灵武市| 高平市| 瑞昌市| 东丰县| 临邑县| 公安县| 鄂伦春自治旗| 盈江县|