基于jquery tab切換(防止頁面刷新)
更新時間:2012年05月23日 12:02:25 作者:
tab切換,是一個很常見的效果,今天在項目中遇到這樣一個問題。就是切換后,頁面刷新,又重新定位到第一個上了,很是郁悶
在網(wǎng)上找了很多jquery效果,都是這樣的,于是自己寫了一個。防止頁面刷新的tab切換,
html代碼:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<link href="../Style/admin.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="System/js/jquery-1.7.min.js"></script>
<script type="text/javascript" src="tabs.js"></script>
<style type="text/css">
.tabs{ list-style:none; width:400px; height:23px;}
.tabs a {display:block; float:left;padding:2px 3px; background:#eff7ff; text-decoration:none; margin-right:2px;}
.tabs a.current{ background:#a1c6de; color:#000;}
.tab{ display:block; width:400px; height:300px; border:1px solid #ccc;}
</style>
</head>
<body>
<div class="tabs">
<a href="#xiangmu" >項目信息</a> <a href="#kehu">客戶</a><a href="#wenda">職位提問</a>
</div>
<div id="xiangmu" class="tab">項目信息</div>
<div id="kehu" class="tab"> 客戶</div>
<div id="wenda" class="tab">職位提問 </div>
</body>
</html>
js代碼:
$(function () {
$("div.tab").hide(); //隱藏所有
$("div.tabs a:first").addClass("current"); //第一個元素選中
$("div.tab:first").show(); //第一個內(nèi)容顯示
$("div.tabs a").click(function () {
$("div.tabs a").removeClass("current"); //將所有的tab去掉current樣式
$(".tab").hide(); //隱藏所有
$(this).addClass("current");
var activeTab = $(this).attr("href"); //獲取div
$(activeTab).show();
});
//獲取從url中傳遞的
var url = window.location.href;
var reg = /#.+/;
if (reg.test(url)) {//含有#,默認(rèn)為只有一個#,多個#情況不考慮
//隱藏所有
$("div.tabs a").removeClass("current"); //將所有的tab去掉current樣式
$(".tab").hide(); //隱藏所有
var href = url.split('#')[1];
$("div.tabs [href=#" + href + "]").addClass("current");
$("#" + href).show();
}
});
代碼很簡單,思路也很清晰,不過很實用,
比如上例中,你刷新頁面,想重新定位到第二個tab上,只需要,重新指定xxx.aspx#kehu即可
附截圖
html代碼:
復(fù)制代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<link href="../Style/admin.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="System/js/jquery-1.7.min.js"></script>
<script type="text/javascript" src="tabs.js"></script>
<style type="text/css">
.tabs{ list-style:none; width:400px; height:23px;}
.tabs a {display:block; float:left;padding:2px 3px; background:#eff7ff; text-decoration:none; margin-right:2px;}
.tabs a.current{ background:#a1c6de; color:#000;}
.tab{ display:block; width:400px; height:300px; border:1px solid #ccc;}
</style>
</head>
<body>
<div class="tabs">
<a href="#xiangmu" >項目信息</a> <a href="#kehu">客戶</a><a href="#wenda">職位提問</a>
</div>
<div id="xiangmu" class="tab">項目信息</div>
<div id="kehu" class="tab"> 客戶</div>
<div id="wenda" class="tab">職位提問 </div>
</body>
</html>
js代碼:
復(fù)制代碼 代碼如下:
$(function () {
$("div.tab").hide(); //隱藏所有
$("div.tabs a:first").addClass("current"); //第一個元素選中
$("div.tab:first").show(); //第一個內(nèi)容顯示
$("div.tabs a").click(function () {
$("div.tabs a").removeClass("current"); //將所有的tab去掉current樣式
$(".tab").hide(); //隱藏所有
$(this).addClass("current");
var activeTab = $(this).attr("href"); //獲取div
$(activeTab).show();
});
//獲取從url中傳遞的
var url = window.location.href;
var reg = /#.+/;
if (reg.test(url)) {//含有#,默認(rèn)為只有一個#,多個#情況不考慮
//隱藏所有
$("div.tabs a").removeClass("current"); //將所有的tab去掉current樣式
$(".tab").hide(); //隱藏所有
var href = url.split('#')[1];
$("div.tabs [href=#" + href + "]").addClass("current");
$("#" + href).show();
}
});
代碼很簡單,思路也很清晰,不過很實用,
比如上例中,你刷新頁面,想重新定位到第二個tab上,只需要,重新指定xxx.aspx#kehu即可
附截圖

相關(guān)文章
jQuery實現(xiàn)的小圖列表,大圖展示效果幻燈片示例
這篇文章主要介紹了jQuery實現(xiàn)的小圖列表,大圖展示效果幻燈片,結(jié)合完整實例形式分析了jQuery圖片滑動切換功能的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2016-10-10jquery教程限制文本框只能輸入數(shù)字和小數(shù)點示例分享
這篇文章主要介紹了JQuery限制文本框只能輸入數(shù)字和小數(shù)點的方法,大家參考使用吧2014-01-01jquery dialog open后,服務(wù)器端控件失效的快速解決方法
本篇文章是對jquery dialog open后,服務(wù)器端控件失效的快速解決方法。進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12JQuery中兩個ul標(biāo)簽的li互相移動實現(xiàn)方法
這篇文章主要介紹了JQuery中兩個ul標(biāo)簽的li互相移動實現(xiàn)方法,可實現(xiàn)ul標(biāo)簽中l(wèi)i標(biāo)簽內(nèi)容相互替換的技巧,涉及jQuery操作頁面元素的相關(guān)技巧,需要的朋友可以參考下2015-05-05關(guān)于jQuery中的each方法(jQuery到底干了什么)
這篇文章主要介紹了關(guān)于jQuery中的each方法,需要的朋友可以參考下2014-03-03