jQuery Pagination分页插件
<!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>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>jQuery Pagination分页插件demo</title>
<link rel="stylesheet" href="lib/pagination.css" />
<style type="text/css">
body{font-size:84%; color:#333333; line-height:1.4;}
a{color:#34538b;}
#Searchresult{width:300px; height:100px; padding:20px; background:#f0f3f9;}
</style>
<script type="text/javascript" src="lib/jquery.min.js"></script>
<script type="text/javascript" src="lib/jquery.pagination.js"></script>
<script type="text/javascript">
$(function(){
//这是一个非常简单的demo实例,让列表元素分页显示
//回调函数的作用是显示对应分页的列表项内容
//回调函数在用户每次点击分页链接的时候执行
//参数page_index{int整型}表示当前的索引页
var initPagination = function() {
var num_entries = $("#hiddenresult div.result").length;
// 创建分页
$("#Pagination").pagination(num_entries, {
num_edge_entries: 1, //边缘页数
num_display_entries: 4, //主体页数
callback: pageselectCallback,
items_per_page:1 //每页显示1项
});
}(); function pageselectCallback(page_index, jq){
var new_content = $("#hiddenresult div.result:eq("+page_index+")").clone();
$("#Searchresult").empty().append(new_content); //装载对应分页的内容
return false;
}
});
</script>
</head> <body>
<h1>jQuery Pagination分页插件demo</h1>
<div id="Pagination" class="pagination"><!-- 这里显示分页 --></div>
<div id="Searchresult">分页初始化完成后这里的内容会被替换。</div>
<div id="hiddenresult" style="display:none;">
<!-- 列表元素 -->
<div class="result">第1项内容</div>
<div class="result">第2项内容</div>
<div class="result">第3项内容</div>
<div class="result">第4项内容</div>
<div class="result">第5项内容</div>
<div class="result">第6项内容</div>
<div class="result">第7项内容</div>
<div class="result">第8项内容</div>
</div>
<p>Copyright © <a href="http://www.zhangxinxu.com/wordpress/">张鑫旭-鑫空间-鑫生活</a></p>
</body>
</html>
pagination.css
@charset "utf-8";
.pagination a {
text-decoration: none;
border: 1px solid #AAE;
color: #15B;
} .pagination a, .pagination span {
display: inline-block;
padding: 0.1em 0.4em;
margin-right: 5px;
margin-bottom: 5px;
} .pagination .current {
background: #26B;
color: #fff;
border: 1px solid #AAE;
} .pagination .current.prev, .pagination .current.next{
color:#999;
border-color:#999;
background:#fff;
}
jquery.pagination.js
/**
* This jQuery plugin displays pagination links inside the selected elements.
*
* @author Gabriel Birke (birke *at* d-scribe *dot* de)
* @version 1.2
* @param {int} maxentries Number of entries to paginate
* @param {Object} opts Several options (see README for documentation)
* @return {Object} jQuery Object
*/
jQuery.fn.pagination = function(maxentries, opts){
opts = jQuery.extend({
items_per_page:10,
num_display_entries:10,
current_page:0,
num_edge_entries:0,
link_to:"#",
prev_text:"Prev",
next_text:"Next",
ellipse_text:"...",
prev_show_always:true,
next_show_always:true,
callback:function(){return false;}
},opts||{}); return this.each(function() {
/**
* 计算最大分页显示数目
*/
function numPages() {
return Math.ceil(maxentries/opts.items_per_page);
}
/**
* 极端分页的起始和结束点,这取决于current_page 和 num_display_entries.
* @返回 {数组(Array)}
*/
function getInterval() {
var ne_half = Math.ceil(opts.num_display_entries/2);
var np = numPages();
var upper_limit = np-opts.num_display_entries;
var start = current_page>ne_half?Math.max(Math.min(current_page-ne_half, upper_limit), 0):0;
var end = current_page>ne_half?Math.min(current_page+ne_half, np):Math.min(opts.num_display_entries, np);
return [start,end];
} /**
* 分页链接事件处理函数
* @参数 {int} page_id 为新页码
*/
function pageSelected(page_id, evt){
current_page = page_id;
drawLinks();
var continuePropagation = opts.callback(page_id, panel);
if (!continuePropagation) {
if (evt.stopPropagation) {
evt.stopPropagation();
}
else {
evt.cancelBubble = true;
}
}
return continuePropagation;
} /**
* 此函数将分页链接插入到容器元素中
*/
function drawLinks() {
panel.empty();
var interval = getInterval();
var np = numPages();
// 这个辅助函数返回一个处理函数调用有着正确page_id的pageSelected。
var getClickHandler = function(page_id) {
return function(evt){ return pageSelected(page_id,evt); }
}
//辅助函数用来产生一个单链接(如果不是当前页则产生span标签)
var appendItem = function(page_id, appendopts){
page_id = page_id<0?0:(page_id<np?page_id:np-1); // 规范page id值
appendopts = jQuery.extend({text:page_id+1, classes:""}, appendopts||{});
if(page_id == current_page){
var lnk = jQuery("<span class='current'>"+(appendopts.text)+"</span>");
}else{
var lnk = jQuery("<a>"+(appendopts.text)+"</a>")
.bind("click", getClickHandler(page_id))
.attr('href', opts.link_to.replace(/__id__/,page_id));
}
if(appendopts.classes){lnk.addClass(appendopts.classes);}
panel.append(lnk);
}
// 产生"Previous"-链接
if(opts.prev_text && (current_page > 0 || opts.prev_show_always)){
appendItem(current_page-1,{text:opts.prev_text, classes:"prev"});
}
// 产生起始点
if (interval[0] > 0 && opts.num_edge_entries > 0)
{
var end = Math.min(opts.num_edge_entries, interval[0]);
for(var i=0; i<end; i++) {
appendItem(i);
}
if(opts.num_edge_entries < interval[0] && opts.ellipse_text)
{
jQuery("<span>"+opts.ellipse_text+"</span>").appendTo(panel);
}
}
// 产生内部的些链接
for(var i=interval[0]; i<interval[1]; i++) {
appendItem(i);
}
// 产生结束点
if (interval[1] < np && opts.num_edge_entries > 0)
{
if(np-opts.num_edge_entries > interval[1]&& opts.ellipse_text)
{
jQuery("<span>"+opts.ellipse_text+"</span>").appendTo(panel);
}
var begin = Math.max(np-opts.num_edge_entries, interval[1]);
for(var i=begin; i<np; i++) {
appendItem(i);
} }
// 产生 "Next"-链接
if(opts.next_text && (current_page < np-1 || opts.next_show_always)){
appendItem(current_page+1,{text:opts.next_text, classes:"next"});
}
} //从选项中提取current_page
var current_page = opts.current_page;
//创建一个显示条数和每页显示条数值
maxentries = (!maxentries || maxentries < 0)?1:maxentries;
opts.items_per_page = (!opts.items_per_page || opts.items_per_page < 0)?1:opts.items_per_page;
//存储DOM元素,以方便从所有的内部结构中获取
var panel = jQuery(this);
// 获得附加功能的元素
this.selectPage = function(page_id){ pageSelected(page_id);}
this.prevPage = function(){
if (current_page > 0) {
pageSelected(current_page - 1);
return true;
}
else {
return false;
}
}
this.nextPage = function(){
if(current_page < numPages()-1) {
pageSelected(current_page+1);
return true;
}
else {
return false;
}
}
// 所有初始化完成,绘制链接
drawLinks();
// 回调函数
opts.callback(current_page, this);
});
}
jquery.min.js
/*
* jQuery JavaScript Library v1.3.1
* http://jquery.com/
*
* Copyright (c) 2009 John Resig
* Dual licensed under the MIT and GPL licenses.
* http://docs.jquery.com/License
*
* Date: 2009-01-21 20:42:16 -0500 (Wed, 21 Jan 2009)
* Revision: 6158
*/
(function() {
var l = this, g, y = l.jQuery, p = l.$, o = l.jQuery = l.$ = function(E, F) {
return new o.fn.init(E, F)
}, D = /^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/, f = /^.[^:#\[\.,]*$/;
o.fn = o.prototype = {
init : function(E, H) {
E = E || document;
if (E.nodeType) {
this[0] = E;
this.length = 1;
this.context = E;
return this
}
if (typeof E === "string") {
var G = D.exec(E);
if (G && (G[1] || !H)) {
if (G[1]) {
E = o.clean([ G[1] ], H)
} else {
var I = document.getElementById(G[3]);
if (I && I.id != G[3]) {
return o().find(E)
}
var F = o(I || []);
F.context = document;
F.selector = E;
return F
}
} else {
return o(H).find(E)
}
} else {
if (o.isFunction(E)) {
return o(document).ready(E)
}
}
if (E.selector && E.context) {
this.selector = E.selector;
this.context = E.context
}
return this.setArray(o.makeArray(E))
},
selector : "",
jquery : "1.3.1",
size : function() {
return this.length
},
get : function(E) {
return E === g ? o.makeArray(this) : this[E]
},
pushStack : function(F, H, E) {
var G = o(F);
G.prevObject = this;
G.context = this.context;
if (H === "find") {
G.selector = this.selector + (this.selector ? " " : "") + E
} else {
if (H) {
G.selector = this.selector + "." + H + "(" + E + ")"
}
}
return G
},
setArray : function(E) {
this.length = 0;
Array.prototype.push.apply(this, E);
return this
},
each : function(F, E) {
return o.each(this, F, E)
},
index : function(E) {
return o.inArray(E && E.jquery ? E[0] : E, this)
},
attr : function(F, H, G) {
var E = F;
if (typeof F === "string") {
if (H === g) {
return this[0] && o[G || "attr"](this[0], F)
} else {
E = {};
E[F] = H
}
}
return this.each(function(I) {
for (F in E) {
o.attr(G ? this.style : this, F, o
.prop(this, E[F], G, I, F))
}
})
},
css : function(E, F) {
if ((E == "width" || E == "height") && parseFloat(F) < 0) {
F = g
}
return this.attr(E, F, "curCSS")
},
text : function(F) {
if (typeof F !== "object" && F != null) {
return this.empty().append(
(this[0] && this[0].ownerDocument || document)
.createTextNode(F))
}
var E = "";
o.each(F || this, function() {
o.each(this.childNodes, function() {
if (this.nodeType != 8) {
E += this.nodeType != 1 ? this.nodeValue : o.fn
.text([ this ])
}
})
});
return E
},
wrapAll : function(E) {
if (this[0]) {
var F = o(E, this[0].ownerDocument).clone();
if (this[0].parentNode) {
F.insertBefore(this[0])
}
F.map(function() {
var G = this;
while (G.firstChild) {
G = G.firstChild
}
return G
}).append(this)
}
return this
},
wrapInner : function(E) {
return this.each(function() {
o(this).contents().wrapAll(E)
})
},
wrap : function(E) {
return this.each(function() {
o(this).wrapAll(E)
})
},
append : function() {
return this.domManip(arguments, true, function(E) {
if (this.nodeType == 1) {
this.appendChild(E)
}
})
},
prepend : function() {
return this.domManip(arguments, true, function(E) {
if (this.nodeType == 1) {
this.insertBefore(E, this.firstChild)
}
})
},
before : function() {
return this.domManip(arguments, false, function(E) {
this.parentNode.insertBefore(E, this)
})
},
after : function() {
return this.domManip(arguments, false, function(E) {
this.parentNode.insertBefore(E, this.nextSibling)
})
},
end : function() {
return this.prevObject || o([])
},
push : [].push,
find : function(E) {
if (this.length === 1 && !/,/.test(E)) {
var G = this.pushStack([], "find", E);
G.length = 0;
o.find(E, this[0], G);
return G
} else {
var F = o.map(this, function(H) {
return o.find(E, H)
});
return this.pushStack(/[^+>] [^+>]/.test(E) ? o.unique(F) : F,
"find", E)
}
},
clone : function(F) {
var E = this.map(function() {
if (!o.support.noCloneEvent && !o.isXMLDoc(this)) {
var I = this.cloneNode(true), H = document
.createElement("div");
H.appendChild(I);
return o.clean([ H.innerHTML ])[0]
} else {
return this.cloneNode(true)
}
});
var G = E.find("*").andSelf().each(function() {
if (this[h] !== g) {
this[h] = null
}
});
if (F === true) {
this.find("*").andSelf().each(function(I) {
if (this.nodeType == 3) {
return
}
var H = o.data(this, "events");
for ( var K in H) {
for ( var J in H[K]) {
o.event.add(G[I], K, H[K][J], H[K][J].data)
}
}
})
}
return E
},
filter : function(E) {
return this.pushStack(o.isFunction(E)
&& o.grep(this, function(G, F) {
return E.call(G, F)
}) || o.multiFilter(E, o.grep(this, function(F) {
return F.nodeType === 1
})), "filter", E)
},
closest : function(E) {
var F = o.expr.match.POS.test(E) ? o(E) : null;
return this.map(function() {
var G = this;
while (G && G.ownerDocument) {
if (F ? F.index(G) > -1 : o(G).is(E)) {
return G
}
G = G.parentNode
}
})
},
not : function(E) {
if (typeof E === "string") {
if (f.test(E)) {
return this.pushStack(o.multiFilter(E, this, true), "not",
E)
} else {
E = o.multiFilter(E, this)
}
}
var F = E.length && E[E.length - 1] !== g && !E.nodeType;
return this.filter(function() {
return F ? o.inArray(this, E) < 0 : this != E
})
},
add : function(E) {
return this.pushStack(o.unique(o.merge(this.get(),
typeof E === "string" ? o(E) : o.makeArray(E))))
},
is : function(E) {
return !!E && o.multiFilter(E, this).length > 0
},
hasClass : function(E) {
return !!E && this.is("." + E)
},
val : function(K) {
if (K === g) {
var E = this[0];
if (E) {
if (o.nodeName(E, "option")) {
return (E.attributes.value || {}).specified ? E.value
: E.text
}
if (o.nodeName(E, "select")) {
var I = E.selectedIndex, L = [], M = E.options, H = E.type == "select-one";
if (I < 0) {
return null
}
for (var F = H ? I : 0, J = H ? I + 1 : M.length; F < J; F++) {
var G = M[F];
if (G.selected) {
K = o(G).val();
if (H) {
return K
}
L.push(K)
}
}
return L
}
return (E.value || "").replace(/\r/g, "")
}
return g
}
if (typeof K === "number") {
K += ""
}
return this
.each(function() {
if (this.nodeType != 1) {
return
}
if (o.isArray(K) && /radio|checkbox/.test(this.type)) {
this.checked = (o.inArray(this.value, K) >= 0 || o
.inArray(this.name, K) >= 0)
} else {
if (o.nodeName(this, "select")) {
var N = o.makeArray(K);
o("option", this)
.each(
function() {
this.selected = (o.inArray(
this.value, N) >= 0 || o
.inArray(this.text,
N) >= 0)
});
if (!N.length) {
this.selectedIndex = -1
}
} else {
this.value = K
}
}
})
},
html : function(E) {
return E === g ? (this[0] ? this[0].innerHTML : null) : this
.empty().append(E)
},
replaceWith : function(E) {
return this.after(E).remove()
},
eq : function(E) {
return this.slice(E, +E + 1)
},
slice : function() {
return this.pushStack(Array.prototype.slice.apply(this, arguments),
"slice", Array.prototype.slice.call(arguments).join(","))
},
map : function(E) {
return this.pushStack(o.map(this, function(G, F) {
return E.call(G, F, G)
}))
},
andSelf : function() {
return this.add(this.prevObject)
},
domManip : function(K, N, M) {
if (this[0]) {
var J = (this[0].ownerDocument || this[0])
.createDocumentFragment(), G = o.clean(K,
(this[0].ownerDocument || this[0]), J), I = J.firstChild, E = this.length > 1 ? J
.cloneNode(true)
: J;
if (I) {
for (var H = 0, F = this.length; H < F; H++) {
M.call(L(this[H], I), H > 0 ? E.cloneNode(true) : J)
}
}
if (G) {
o.each(G, z)
}
}
return this;
function L(O, P) {
return N && o.nodeName(O, "table") && o.nodeName(P, "tr") ? (O
.getElementsByTagName("tbody")[0] || O
.appendChild(O.ownerDocument.createElement("tbody")))
: O
}
}
};
o.fn.init.prototype = o.fn;
function z(E, F) {
if (F.src) {
o.ajax({
url : F.src,
async : false,
dataType : "script"
})
} else {
o.globalEval(F.text || F.textContent || F.innerHTML || "")
}
if (F.parentNode) {
F.parentNode.removeChild(F)
}
}
function e() {
return +new Date
}
o.extend = o.fn.extend = function() {
var J = arguments[0] || {}, H = 1, I = arguments.length, E = false, G;
if (typeof J === "boolean") {
E = J;
J = arguments[1] || {};
H = 2
}
if (typeof J !== "object" && !o.isFunction(J)) {
J = {}
}
if (I == H) {
J = this;
--H
}
for (; H < I; H++) {
if ((G = arguments[H]) != null) {
for ( var F in G) {
var K = J[F], L = G[F];
if (J === L) {
continue
}
if (E && L && typeof L === "object" && !L.nodeType) {
J[F] = o
.extend(E, K || (L.length != null ? [] : {}), L)
} else {
if (L !== g) {
J[F] = L
}
}
}
}
}
return J
};
var b = /z-?index|font-?weight|opacity|zoom|line-?height/i, q = document.defaultView
|| {}, s = Object.prototype.toString;
o
.extend({
noConflict : function(E) {
l.$ = p;
if (E) {
l.jQuery = y
}
return o
},
isFunction : function(E) {
return s.call(E) === "[object Function]"
},
isArray : function(E) {
return s.call(E) === "[object Array]"
},
isXMLDoc : function(E) {
return E.nodeType === 9
&& E.documentElement.nodeName !== "HTML"
|| !!E.ownerDocument && o.isXMLDoc(E.ownerDocument)
},
globalEval : function(G) {
G = o.trim(G);
if (G) {
var F = document.getElementsByTagName("head")[0]
|| document.documentElement, E = document
.createElement("script");
E.type = "text/javascript";
if (o.support.scriptEval) {
E.appendChild(document.createTextNode(G))
} else {
E.text = G
}
F.insertBefore(E, F.firstChild);
F.removeChild(E)
}
},
nodeName : function(F, E) {
return F.nodeName
&& F.nodeName.toUpperCase() == E.toUpperCase()
},
each : function(G, K, F) {
var E, H = 0, I = G.length;
if (F) {
if (I === g) {
for (E in G) {
if (K.apply(G[E], F) === false) {
break
}
}
} else {
for (; H < I;) {
if (K.apply(G[H++], F) === false) {
break
}
}
}
} else {
if (I === g) {
for (E in G) {
if (K.call(G[E], E, G[E]) === false) {
break
}
}
} else {
for (var J = G[0]; H < I
&& K.call(J, H, J) !== false; J = G[++H]) {
}
}
}
return G
},
prop : function(H, I, G, F, E) {
if (o.isFunction(I)) {
I = I.call(H, F)
}
return typeof I === "number" && G == "curCSS" && !b.test(E) ? I
+ "px"
: I
},
className : {
add : function(E, F) {
o.each((F || "").split(/\s+/), function(G, H) {
if (E.nodeType == 1
&& !o.className.has(E.className, H)) {
E.className += (E.className ? " " : "") + H
}
})
},
remove : function(E, F) {
if (E.nodeType == 1) {
E.className = F !== g ? o.grep(
E.className.split(/\s+/), function(G) {
return !o.className.has(F, G)
}).join(" ") : ""
}
},
has : function(F, E) {
return F
&& o.inArray(E, (F.className || F).toString()
.split(/\s+/)) > -1
}
},
swap : function(H, G, I) {
var E = {};
for ( var F in G) {
E[F] = H.style[F];
H.style[F] = G[F]
}
I.call(H);
for ( var F in G) {
H.style[F] = E[F]
}
},
css : function(G, E, I) {
if (E == "width" || E == "height") {
var K, F = {
position : "absolute",
visibility : "hidden",
display : "block"
}, J = E == "width" ? [ "Left", "Right" ] : [ "Top",
"Bottom" ];
function H() {
K = E == "width" ? G.offsetWidth : G.offsetHeight;
var M = 0, L = 0;
o.each(J, function() {
M += parseFloat(o.curCSS(G, "padding" + this,
true)) || 0;
L += parseFloat(o.curCSS(G, "border" + this
+ "Width", true)) || 0
});
K -= Math.round(M + L)
}
if (o(G).is(":visible")) {
H()
} else {
o.swap(G, F, H)
}
return Math.max(0, K)
}
return o.curCSS(G, E, I)
},
curCSS : function(I, F, G) {
var L, E = I.style;
if (F == "opacity" && !o.support.opacity) {
L = o.attr(E, "opacity");
return L == "" ? "1" : L
}
if (F.match(/float/i)) {
F = w
}
if (!G && E && E[F]) {
L = E[F]
} else {
if (q.getComputedStyle) {
if (F.match(/float/i)) {
F = "float"
}
F = F.replace(/([A-Z])/g, "-$1").toLowerCase();
var M = q.getComputedStyle(I, null);
if (M) {
L = M.getPropertyValue(F)
}
if (F == "opacity" && L == "") {
L = "1"
}
} else {
if (I.currentStyle) {
var J = F.replace(/\-(\w)/g, function(N, O) {
return O.toUpperCase()
});
L = I.currentStyle[F] || I.currentStyle[J];
if (!/^\d+(px)?$/i.test(L) && /^\d/.test(L)) {
var H = E.left, K = I.runtimeStyle.left;
I.runtimeStyle.left = I.currentStyle.left;
E.left = L || 0;
L = E.pixelLeft + "px";
E.left = H;
I.runtimeStyle.left = K
}
}
}
}
return L
},
clean : function(F, K, I) {
K = K || document;
if (typeof K.createElement === "undefined") {
K = K.ownerDocument || K[0] && K[0].ownerDocument
|| document
}
if (!I && F.length === 1 && typeof F[0] === "string") {
var H = /^<(\w+)\s*\/?>$/.exec(F[0]);
if (H) {
return [ K.createElement(H[1]) ]
}
}
var G = [], E = [], L = K.createElement("div");
o
.each(
F,
function(P, R) {
if (typeof R === "number") {
R += ""
}
if (!R) {
return
}
if (typeof R === "string") {
R = R
.replace(
/(<(\w+)[^>]*?)\/>/g,
function(T, U, S) {
return S
.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i) ? T
: U
+ "></"
+ S
+ ">"
});
var O = o.trim(R).toLowerCase();
var Q = !O.indexOf("<opt")
&& [
1,
"<select multiple='multiple'>",
"</select>" ]
|| !O.indexOf("<leg")
&& [ 1, "<fieldset>",
"</fieldset>" ]
|| O
.match(/^<(thead|tbody|tfoot|colg|cap)/)
&& [ 1, "<table>",
"</table>" ]
|| !O.indexOf("<tr")
&& [ 2, "<table><tbody>",
"</tbody></table>" ]
|| (!O.indexOf("<td") || !O
.indexOf("<th"))
&& [
3,
"<table><tbody><tr>",
"</tr></tbody></table>" ]
|| !O.indexOf("<col")
&& [
2,
"<table><tbody></tbody><colgroup>",
"</colgroup></table>" ]
|| !o.support.htmlSerialize
&& [ 1, "div<div>",
"</div>" ]
|| [ 0, "", "" ];
L.innerHTML = Q[1] + R + Q[2];
while (Q[0]--) {
L = L.lastChild
}
if (!o.support.tbody) {
var N = !O.indexOf("<table")
&& O.indexOf("<tbody") < 0 ? L.firstChild
&& L.firstChild.childNodes
: Q[1] == "<table>"
&& O
.indexOf("<tbody") < 0 ? L.childNodes
: [];
for (var M = N.length - 1; M >= 0; --M) {
if (o.nodeName(N[M],
"tbody")
&& !N[M].childNodes.length) {
N[M].parentNode
.removeChild(N[M])
}
}
}
if (!o.support.leadingWhitespace
&& /^\s/.test(R)) {
L
.insertBefore(
K
.createTextNode(R
.match(/^\s*/)[0]),
L.firstChild)
}
R = o.makeArray(L.childNodes)
}
if (R.nodeType) {
G.push(R)
} else {
G = o.merge(G, R)
}
});
if (I) {
for (var J = 0; G[J]; J++) {
if (o.nodeName(G[J], "script")
&& (!G[J].type || G[J].type.toLowerCase() === "text/javascript")) {
E.push(G[J].parentNode ? G[J].parentNode
.removeChild(G[J]) : G[J])
} else {
if (G[J].nodeType === 1) {
G.splice
.apply(
G,
[ J + 1, 0 ]
.concat(o
.makeArray(G[J]
.getElementsByTagName("script"))))
}
I.appendChild(G[J])
}
}
return E
}
return G
},
attr : function(J, G, K) {
if (!J || J.nodeType == 3 || J.nodeType == 8) {
return g
}
var H = !o.isXMLDoc(J), L = K !== g;
G = H && o.props[G] || G;
if (J.tagName) {
var F = /href|src|style/.test(G);
if (G == "selected" && J.parentNode) {
J.parentNode.selectedIndex
}
if (G in J && H && !F) {
if (L) {
if (G == "type" && o.nodeName(J, "input")
&& J.parentNode) {
throw "type property can't be changed"
}
J[G] = K
}
if (o.nodeName(J, "form") && J.getAttributeNode(G)) {
return J.getAttributeNode(G).nodeValue
}
if (G == "tabIndex") {
var I = J.getAttributeNode("tabIndex");
return I && I.specified ? I.value
: J.nodeName
.match(/(button|input|object|select|textarea)/i) ? 0
: J.nodeName
.match(/^(a|area)$/i)
&& J.href ? 0 : g
}
return J[G]
}
if (!o.support.style && H && G == "style") {
return o.attr(J.style, "cssText", K)
}
if (L) {
J.setAttribute(G, "" + K)
}
var E = !o.support.hrefNormalized && H && F ? J
.getAttribute(G, 2) : J.getAttribute(G);
return E === null ? g : E
}
if (!o.support.opacity && G == "opacity") {
if (L) {
J.zoom = 1;
J.filter = (J.filter || "").replace(
/alpha\([^)]*\)/, "")
+ (parseInt(K) + "" == "NaN" ? ""
: "alpha(opacity=" + K * 100 + ")")
}
return J.filter && J.filter.indexOf("opacity=") >= 0 ? (parseFloat(J.filter
.match(/opacity=([^)]*)/)[1]) / 100)
+ ""
: ""
}
G = G.replace(/-([a-z])/ig, function(M, N) {
return N.toUpperCase()
});
if (L) {
J[G] = K
}
return J[G]
},
trim : function(E) {
return (E || "").replace(/^\s+|\s+$/g, "")
},
makeArray : function(G) {
var E = [];
if (G != null) {
var F = G.length;
if (F == null || typeof G === "string"
|| o.isFunction(G) || G.setInterval) {
E[0] = G
} else {
while (F) {
E[--F] = G[F]
}
}
}
return E
},
inArray : function(G, H) {
for (var E = 0, F = H.length; E < F; E++) {
if (H[E] === G) {
return E
}
}
return -1
},
merge : function(H, E) {
var F = 0, G, I = H.length;
if (!o.support.getAll) {
while ((G = E[F++]) != null) {
if (G.nodeType != 8) {
H[I++] = G
}
}
} else {
while ((G = E[F++]) != null) {
H[I++] = G
}
}
return H
},
unique : function(K) {
var F = [], E = {};
try {
for (var G = 0, H = K.length; G < H; G++) {
var J = o.data(K[G]);
if (!E[J]) {
E[J] = true;
F.push(K[G])
}
}
} catch (I) {
F = K
}
return F
},
grep : function(F, J, E) {
var G = [];
for (var H = 0, I = F.length; H < I; H++) {
if (!E != !J(F[H], H)) {
G.push(F[H])
}
}
return G
},
map : function(E, J) {
var F = [];
for (var G = 0, H = E.length; G < H; G++) {
var I = J(E[G], G);
if (I != null) {
F[F.length] = I
}
}
return F.concat.apply([], F)
}
});
var C = navigator.userAgent.toLowerCase();
o.browser = {
version : (C.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/) || [ 0, "0" ])[1],
safari : /webkit/.test(C),
opera : /opera/.test(C),
msie : /msie/.test(C) && !/opera/.test(C),
mozilla : /mozilla/.test(C) && !/(compatible|webkit)/.test(C)
};
o.each({
parent : function(E) {
return E.parentNode
},
parents : function(E) {
return o.dir(E, "parentNode")
},
next : function(E) {
return o.nth(E, 2, "nextSibling")
},
prev : function(E) {
return o.nth(E, 2, "previousSibling")
},
nextAll : function(E) {
return o.dir(E, "nextSibling")
},
prevAll : function(E) {
return o.dir(E, "previousSibling")
},
siblings : function(E) {
return o.sibling(E.parentNode.firstChild, E)
},
children : function(E) {
return o.sibling(E.firstChild)
},
contents : function(E) {
return o.nodeName(E, "iframe") ? E.contentDocument
|| E.contentWindow.document : o.makeArray(E.childNodes)
}
}, function(E, F) {
o.fn[E] = function(G) {
var H = o.map(this, F);
if (G && typeof G == "string") {
H = o.multiFilter(G, H)
}
return this.pushStack(o.unique(H), E, G)
}
});
o.each({
appendTo : "append",
prependTo : "prepend",
insertBefore : "before",
insertAfter : "after",
replaceAll : "replaceWith"
}, function(E, F) {
o.fn[E] = function() {
var G = arguments;
return this.each(function() {
for (var H = 0, I = G.length; H < I; H++) {
o(G[H])[F](this)
}
})
}
});
o.each({
removeAttr : function(E) {
o.attr(this, E, "");
if (this.nodeType == 1) {
this.removeAttribute(E)
}
},
addClass : function(E) {
o.className.add(this, E)
},
removeClass : function(E) {
o.className.remove(this, E)
},
toggleClass : function(F, E) {
if (typeof E !== "boolean") {
E = !o.className.has(this, F)
}
o.className[E ? "add" : "remove"](this, F)
},
remove : function(E) {
if (!E || o.filter(E, [ this ]).length) {
o("*", this).add([ this ]).each(function() {
o.event.remove(this);
o.removeData(this)
});
if (this.parentNode) {
this.parentNode.removeChild(this)
}
}
},
empty : function() {
o(">*", this).remove();
while (this.firstChild) {
this.removeChild(this.firstChild)
}
}
}, function(E, F) {
o.fn[E] = function() {
return this.each(F, arguments)
}
});
function j(E, F) {
return E[0] && parseInt(o.curCSS(E[0], F, true), 10) || 0
}
var h = "jQuery" + e(), v = 0, A = {};
o.extend({
cache : {},
data : function(F, E, G) {
F = F == l ? A : F;
var H = F[h];
if (!H) {
H = F[h] = ++v
}
if (E && !o.cache[H]) {
o.cache[H] = {}
}
if (G !== g) {
o.cache[H][E] = G
}
return E ? o.cache[H][E] : H
},
removeData : function(F, E) {
F = F == l ? A : F;
var H = F[h];
if (E) {
if (o.cache[H]) {
delete o.cache[H][E];
E = "";
for (E in o.cache[H]) {
break
}
if (!E) {
o.removeData(F)
}
}
} else {
try {
delete F[h]
} catch (G) {
if (F.removeAttribute) {
F.removeAttribute(h)
}
}
delete o.cache[H]
}
},
queue : function(F, E, H) {
if (F) {
E = (E || "fx") + "queue";
var G = o.data(F, E);
if (!G || o.isArray(H)) {
G = o.data(F, E, o.makeArray(H))
} else {
if (H) {
G.push(H)
}
}
}
return G
},
dequeue : function(H, G) {
var E = o.queue(H, G), F = E.shift();
if (!G || G === "fx") {
F = E[0]
}
if (F !== g) {
F.call(H)
}
}
});
o.fn.extend({
data : function(E, G) {
var H = E.split(".");
H[1] = H[1] ? "." + H[1] : "";
if (G === g) {
var F = this.triggerHandler("getData" + H[1] + "!", [ H[0] ]);
if (F === g && this.length) {
F = o.data(this[0], E)
}
return F === g && H[1] ? this.data(H[0]) : F
} else {
return this.trigger("setData" + H[1] + "!", [ H[0], G ]).each(
function() {
o.data(this, E, G)
})
}
},
removeData : function(E) {
return this.each(function() {
o.removeData(this, E)
})
},
queue : function(E, F) {
if (typeof E !== "string") {
F = E;
E = "fx"
}
if (F === g) {
return o.queue(this[0], E)
}
return this.each(function() {
var G = o.queue(this, E, F);
if (E == "fx" && G.length == 1) {
G[0].call(this)
}
})
},
dequeue : function(E) {
return this.each(function() {
o.dequeue(this, E)
})
}
});
/*
* Sizzle CSS Selector Engine - v0.9.3 Copyright 2009, The Dojo Foundation
* Released under the MIT, BSD, and GPL Licenses. More information:
* http://sizzlejs.com/
*/
(function() {
var Q = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]+['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[]+)+|[>+~])(\s*,\s*)?/g, K = 0, G = Object.prototype.toString;
var F = function(X, T, aa, ab) {
aa = aa || [];
T = T || document;
if (T.nodeType !== 1 && T.nodeType !== 9) {
return []
}
if (!X || typeof X !== "string") {
return aa
}
var Y = [], V, ae, ah, S, ac, U, W = true;
Q.lastIndex = 0;
while ((V = Q.exec(X)) !== null) {
Y.push(V[1]);
if (V[2]) {
U = RegExp.rightContext;
break
}
}
if (Y.length > 1 && L.exec(X)) {
if (Y.length === 2 && H.relative[Y[0]]) {
ae = I(Y[0] + Y[1], T)
} else {
ae = H.relative[Y[0]] ? [ T ] : F(Y.shift(), T);
while (Y.length) {
X = Y.shift();
if (H.relative[X]) {
X += Y.shift()
}
ae = I(X, ae)
}
}
} else {
var ad = ab ? {
expr : Y.pop(),
set : E(ab)
} : F
.find(Y.pop(),
Y.length === 1 && T.parentNode ? T.parentNode
: T, P(T));
ae = F.filter(ad.expr, ad.set);
if (Y.length > 0) {
ah = E(ae)
} else {
W = false
}
while (Y.length) {
var ag = Y.pop(), af = ag;
if (!H.relative[ag]) {
ag = ""
} else {
af = Y.pop()
}
if (af == null) {
af = T
}
H.relative[ag](ah, af, P(T))
}
}
if (!ah) {
ah = ae
}
if (!ah) {
throw "Syntax error, unrecognized expression: " + (ag || X)
}
if (G.call(ah) === "[object Array]") {
if (!W) {
aa.push.apply(aa, ah)
} else {
if (T.nodeType === 1) {
for (var Z = 0; ah[Z] != null; Z++) {
if (ah[Z]
&& (ah[Z] === true || ah[Z].nodeType === 1
&& J(T, ah[Z]))) {
aa.push(ae[Z])
}
}
} else {
for (var Z = 0; ah[Z] != null; Z++) {
if (ah[Z] && ah[Z].nodeType === 1) {
aa.push(ae[Z])
}
}
}
}
} else {
E(ah, aa)
}
if (U) {
F(U, T, aa, ab)
}
return aa
};
F.matches = function(S, T) {
return F(S, null, null, T)
};
F.find = function(Z, S, aa) {
var Y, W;
if (!Z) {
return []
}
for (var V = 0, U = H.order.length; V < U; V++) {
var X = H.order[V], W;
if ((W = H.match[X].exec(Z))) {
var T = RegExp.leftContext;
if (T.substr(T.length - 1) !== "\\") {
W[1] = (W[1] || "").replace(/\\/g, "");
Y = H.find[X](W, S, aa);
if (Y != null) {
Z = Z.replace(H.match[X], "");
break
}
}
}
}
if (!Y) {
Y = S.getElementsByTagName("*")
}
return {
set : Y,
expr : Z
}
};
F.filter = function(ab, aa, ae, V) {
var U = ab, ag = [], Y = aa, X, S;
while (ab && aa.length) {
for ( var Z in H.filter) {
if ((X = H.match[Z].exec(ab)) != null) {
var T = H.filter[Z], af, ad;
S = false;
if (Y == ag) {
ag = []
}
if (H.preFilter[Z]) {
X = H.preFilter[Z](X, Y, ae, ag, V);
if (!X) {
S = af = true
} else {
if (X === true) {
continue
}
}
}
if (X) {
for (var W = 0; (ad = Y[W]) != null; W++) {
if (ad) {
af = T(ad, X, W, Y);
var ac = V ^ !!af;
if (ae && af != null) {
if (ac) {
S = true
} else {
Y[W] = false
}
} else {
if (ac) {
ag.push(ad);
S = true
}
}
}
}
}
if (af !== g) {
if (!ae) {
Y = ag
}
ab = ab.replace(H.match[Z], "");
if (!S) {
return []
}
break
}
}
}
ab = ab.replace(/\s*,\s*/, "");
if (ab == U) {
if (S == null) {
throw "Syntax error, unrecognized expression: " + ab
} else {
break
}
}
U = ab
}
return Y
};
var H = F.selectors = {
order : [ "ID", "NAME", "TAG" ],
match : {
ID : /#((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,
CLASS : /\.((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,
NAME : /\[name=['"]*((?:[\w\u00c0-\uFFFF_-]|\\.)+)['"]*\]/,
ATTR : /\[\s*((?:[\w\u00c0-\uFFFF_-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,
TAG : /^((?:[\w\u00c0-\uFFFF\*_-]|\\.)+)/,
CHILD : /:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,
POS : /:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,
PSEUDO : /:((?:[\w\u00c0-\uFFFF_-]|\\.)+)(?:\((['"]*)((?:\([^\)]+\)|[^\2\(\)]*)+)\2\))?/
},
attrMap : {
"class" : "className",
"for" : "htmlFor"
},
attrHandle : {
href : function(S) {
return S.getAttribute("href")
}
},
relative : {
"+" : function(W, T) {
for (var U = 0, S = W.length; U < S; U++) {
var V = W[U];
if (V) {
var X = V.previousSibling;
while (X && X.nodeType !== 1) {
X = X.previousSibling
}
W[U] = typeof T === "string" ? X || false : X === T
}
}
if (typeof T === "string") {
F.filter(T, W, true)
}
},
">" : function(X, T, Y) {
if (typeof T === "string" && !/\W/.test(T)) {
T = Y ? T : T.toUpperCase();
for (var U = 0, S = X.length; U < S; U++) {
var W = X[U];
if (W) {
var V = W.parentNode;
X[U] = V.nodeName === T ? V : false
}
}
} else {
for (var U = 0, S = X.length; U < S; U++) {
var W = X[U];
if (W) {
X[U] = typeof T === "string" ? W.parentNode
: W.parentNode === T
}
}
if (typeof T === "string") {
F.filter(T, X, true)
}
}
},
"" : function(V, T, X) {
var U = "done" + (K++), S = R;
if (!T.match(/\W/)) {
var W = T = X ? T : T.toUpperCase();
S = O
}
S("parentNode", T, U, V, W, X)
},
"~" : function(V, T, X) {
var U = "done" + (K++), S = R;
if (typeof T === "string" && !T.match(/\W/)) {
var W = T = X ? T : T.toUpperCase();
S = O
}
S("previousSibling", T, U, V, W, X)
}
},
find : {
ID : function(T, U, V) {
if (typeof U.getElementById !== "undefined" && !V) {
var S = U.getElementById(T[1]);
return S ? [ S ] : []
}
},
NAME : function(S, T, U) {
if (typeof T.getElementsByName !== "undefined" && !U) {
return T.getElementsByName(S[1])
}
},
TAG : function(S, T) {
return T.getElementsByTagName(S[1])
}
},
preFilter : {
CLASS : function(V, T, U, S, Y) {
V = " " + V[1].replace(/\\/g, "") + " ";
var X;
for (var W = 0; (X = T[W]) != null; W++) {
if (X) {
if (Y ^ (" " + X.className + " ").indexOf(V) >= 0) {
if (!U) {
S.push(X)
}
} else {
if (U) {
T[W] = false
}
}
}
}
return false
},
ID : function(S) {
return S[1].replace(/\\/g, "")
},
TAG : function(T, S) {
for (var U = 0; S[U] === false; U++) {
}
return S[U] && P(S[U]) ? T[1] : T[1].toUpperCase()
},
CHILD : function(S) {
if (S[1] == "nth") {
var T = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(S[2] == "even"
&& "2n" || S[2] == "odd" && "2n+1"
|| !/\D/.test(S[2]) && "0n+" + S[2] || S[2]);
S[2] = (T[1] + (T[2] || 1)) - 0;
S[3] = T[3] - 0
}
S[0] = "done" + (K++);
return S
},
ATTR : function(T) {
var S = T[1].replace(/\\/g, "");
if (H.attrMap[S]) {
T[1] = H.attrMap[S]
}
if (T[2] === "~=") {
T[4] = " " + T[4] + " "
}
return T
},
PSEUDO : function(W, T, U, S, X) {
if (W[1] === "not") {
if (W[3].match(Q).length > 1) {
W[3] = F(W[3], null, null, T)
} else {
var V = F.filter(W[3], T, U, true ^ X);
if (!U) {
S.push.apply(S, V)
}
return false
}
} else {
if (H.match.POS.test(W[0])) {
return true
}
}
return W
},
POS : function(S) {
S.unshift(true);
return S
}
},
filters : {
enabled : function(S) {
return S.disabled === false && S.type !== "hidden"
},
disabled : function(S) {
return S.disabled === true
},
checked : function(S) {
return S.checked === true
},
selected : function(S) {
S.parentNode.selectedIndex;
return S.selected === true
},
parent : function(S) {
return !!S.firstChild
},
empty : function(S) {
return !S.firstChild
},
has : function(U, T, S) {
return !!F(S[3], U).length
},
header : function(S) {
return /h\d/i.test(S.nodeName)
},
text : function(S) {
return "text" === S.type
},
radio : function(S) {
return "radio" === S.type
},
checkbox : function(S) {
return "checkbox" === S.type
},
file : function(S) {
return "file" === S.type
},
password : function(S) {
return "password" === S.type
},
submit : function(S) {
return "submit" === S.type
},
image : function(S) {
return "image" === S.type
},
reset : function(S) {
return "reset" === S.type
},
button : function(S) {
return "button" === S.type
|| S.nodeName.toUpperCase() === "BUTTON"
},
input : function(S) {
return /input|select|textarea|button/i.test(S.nodeName)
}
},
setFilters : {
first : function(T, S) {
return S === 0
},
last : function(U, T, S, V) {
return T === V.length - 1
},
even : function(T, S) {
return S % 2 === 0
},
odd : function(T, S) {
return S % 2 === 1
},
lt : function(U, T, S) {
return T < S[3] - 0
},
gt : function(U, T, S) {
return T > S[3] - 0
},
nth : function(U, T, S) {
return S[3] - 0 == T
},
eq : function(U, T, S) {
return S[3] - 0 == T
}
},
filter : {
CHILD : function(S, V) {
var Y = V[1], Z = S.parentNode;
var X = V[0];
if (Z && (!Z[X] || !S.nodeIndex)) {
var W = 1;
for (var T = Z.firstChild; T; T = T.nextSibling) {
if (T.nodeType == 1) {
T.nodeIndex = W++
}
}
Z[X] = W - 1
}
if (Y == "first") {
return S.nodeIndex == 1
} else {
if (Y == "last") {
return S.nodeIndex == Z[X]
} else {
if (Y == "only") {
return Z[X] == 1
} else {
if (Y == "nth") {
var ab = false, U = V[2], aa = V[3];
if (U == 1 && aa == 0) {
return true
}
if (U == 0) {
if (S.nodeIndex == aa) {
ab = true
}
} else {
if ((S.nodeIndex - aa) % U == 0
&& (S.nodeIndex - aa) / U >= 0) {
ab = true
}
}
return ab
}
}
}
}
},
PSEUDO : function(Y, U, V, Z) {
var T = U[1], W = H.filters[T];
if (W) {
return W(Y, V, U, Z)
} else {
if (T === "contains") {
return (Y.textContent || Y.innerText || "")
.indexOf(U[3]) >= 0
} else {
if (T === "not") {
var X = U[3];
for (var V = 0, S = X.length; V < S; V++) {
if (X[V] === Y) {
return false
}
}
return true
}
}
}
},
ID : function(T, S) {
return T.nodeType === 1 && T.getAttribute("id") === S
},
TAG : function(T, S) {
return (S === "*" && T.nodeType === 1) || T.nodeName === S
},
CLASS : function(T, S) {
return S.test(T.className)
},
ATTR : function(W, U) {
var S = H.attrHandle[U[1]] ? H.attrHandle[U[1]](W)
: W[U[1]] || W.getAttribute(U[1]), X = S + "", V = U[2], T = U[4];
return S == null ? V === "!="
: V === "=" ? X === T
: V === "*=" ? X.indexOf(T) >= 0
: V === "~=" ? (" " + X + " ")
.indexOf(T) >= 0
: !U[4] ? S
: V === "!=" ? X != T
: V === "^=" ? X
.indexOf(T) === 0
: V === "$=" ? X
.substr(X.length
- T.length) === T
: V === "|=" ? X === T
|| X
.substr(
0,
T.length + 1) === T
+ "-"
: false
},
POS : function(W, T, U, X) {
var S = T[2], V = H.setFilters[S];
if (V) {
return V(W, U, T, X)
}
}
}
};
var L = H.match.POS;
for ( var N in H.match) {
H.match[N] = RegExp(H.match[N].source
+ /(?![^\[]*\])(?![^\(]*\))/.source)
}
var E = function(T, S) {
T = Array.prototype.slice.call(T);
if (S) {
S.push.apply(S, T);
return S
}
return T
};
try {
Array.prototype.slice.call(document.documentElement.childNodes)
} catch (M) {
E = function(W, V) {
var T = V || [];
if (G.call(W) === "[object Array]") {
Array.prototype.push.apply(T, W)
} else {
if (typeof W.length === "number") {
for (var U = 0, S = W.length; U < S; U++) {
T.push(W[U])
}
} else {
for (var U = 0; W[U]; U++) {
T.push(W[U])
}
}
}
return T
}
}
(function() {
var T = document.createElement("form"), U = "script"
+ (new Date).getTime();
T.innerHTML = "<input name='" + U + "'/>";
var S = document.documentElement;
S.insertBefore(T, S.firstChild);
if (!!document.getElementById(U)) {
H.find.ID = function(W, X, Y) {
if (typeof X.getElementById !== "undefined" && !Y) {
var V = X.getElementById(W[1]);
return V ? V.id === W[1]
|| typeof V.getAttributeNode !== "undefined"
&& V.getAttributeNode("id").nodeValue === W[1] ? [ V ]
: g
: []
}
};
H.filter.ID = function(X, V) {
var W = typeof X.getAttributeNode !== "undefined"
&& X.getAttributeNode("id");
return X.nodeType === 1 && W && W.nodeValue === V
}
}
S.removeChild(T)
})();
(function() {
var S = document.createElement("div");
S.appendChild(document.createComment(""));
if (S.getElementsByTagName("*").length > 0) {
H.find.TAG = function(T, X) {
var W = X.getElementsByTagName(T[1]);
if (T[1] === "*") {
var V = [];
for (var U = 0; W[U]; U++) {
if (W[U].nodeType === 1) {
V.push(W[U])
}
}
W = V
}
return W
}
}
S.innerHTML = "<a href='#'></a>";
if (S.firstChild && S.firstChild.getAttribute("href") !== "#") {
H.attrHandle.href = function(T) {
return T.getAttribute("href", 2)
}
}
})();
if (document.querySelectorAll) {
(function() {
var S = F, T = document.createElement("div");
T.innerHTML = "<p class='TEST'></p>";
if (T.querySelectorAll
&& T.querySelectorAll(".TEST").length === 0) {
return
}
F = function(X, W, U, V) {
W = W || document;
if (!V && W.nodeType === 9 && !P(W)) {
try {
return E(W.querySelectorAll(X), U)
} catch (Y) {
}
}
return S(X, W, U, V)
};
F.find = S.find;
F.filter = S.filter;
F.selectors = S.selectors;
F.matches = S.matches
})()
}
if (document.getElementsByClassName
&& document.documentElement.getElementsByClassName) {
H.order.splice(1, 0, "CLASS");
H.find.CLASS = function(S, T) {
return T.getElementsByClassName(S[1])
}
}
function O(T, Z, Y, ac, aa, ab) {
for (var W = 0, U = ac.length; W < U; W++) {
var S = ac[W];
if (S) {
S = S[T];
var X = false;
while (S && S.nodeType) {
var V = S[Y];
if (V) {
X = ac[V];
break
}
if (S.nodeType === 1 && !ab) {
S[Y] = W
}
if (S.nodeName === Z) {
X = S;
break
}
S = S[T]
}
ac[W] = X
}
}
}
function R(T, Y, X, ab, Z, aa) {
for (var V = 0, U = ab.length; V < U; V++) {
var S = ab[V];
if (S) {
S = S[T];
var W = false;
while (S && S.nodeType) {
if (S[X]) {
W = ab[S[X]];
break
}
if (S.nodeType === 1) {
if (!aa) {
S[X] = V
}
if (typeof Y !== "string") {
if (S === Y) {
W = true;
break
}
} else {
if (F.filter(Y, [ S ]).length > 0) {
W = S;
break
}
}
}
S = S[T]
}
ab[V] = W
}
}
}
var J = document.compareDocumentPosition ? function(T, S) {
return T.compareDocumentPosition(S) & 16
} : function(T, S) {
return T !== S && (T.contains ? T.contains(S) : true)
};
var P = function(S) {
return S.nodeType === 9 && S.documentElement.nodeName !== "HTML"
|| !!S.ownerDocument && P(S.ownerDocument)
};
var I = function(S, Z) {
var V = [], W = "", X, U = Z.nodeType ? [ Z ] : Z;
while ((X = H.match.PSEUDO.exec(S))) {
W += X[0];
S = S.replace(H.match.PSEUDO, "")
}
S = H.relative[S] ? S + "*" : S;
for (var Y = 0, T = U.length; Y < T; Y++) {
F(S, U[Y], V)
}
return F.filter(W, V)
};
o.find = F;
o.filter = F.filter;
o.expr = F.selectors;
o.expr[":"] = o.expr.filters;
F.selectors.filters.hidden = function(S) {
return "hidden" === S.type || o.css(S, "display") === "none"
|| o.css(S, "visibility") === "hidden"
};
F.selectors.filters.visible = function(S) {
return "hidden" !== S.type && o.css(S, "display") !== "none"
&& o.css(S, "visibility") !== "hidden"
};
F.selectors.filters.animated = function(S) {
return o.grep(o.timers, function(T) {
return S === T.elem
}).length
};
o.multiFilter = function(U, S, T) {
if (T) {
U = ":not(" + U + ")"
}
return F.matches(U, S)
};
o.dir = function(U, T) {
var S = [], V = U[T];
while (V && V != document) {
if (V.nodeType == 1) {
S.push(V)
}
V = V[T]
}
return S
};
o.nth = function(W, S, U, V) {
S = S || 1;
var T = 0;
for (; W; W = W[U]) {
if (W.nodeType == 1 && ++T == S) {
break
}
}
return W
};
o.sibling = function(U, T) {
var S = [];
for (; U; U = U.nextSibling) {
if (U.nodeType == 1 && U != T) {
S.push(U)
}
}
return S
};
return;
l.Sizzle = F
})();
o.event = {
add : function(I, F, H, K) {
if (I.nodeType == 3 || I.nodeType == 8) {
return
}
if (I.setInterval && I != l) {
I = l
}
if (!H.guid) {
H.guid = this.guid++
}
if (K !== g) {
var G = H;
H = this.proxy(G);
H.data = K
}
var E = o.data(I, "events") || o.data(I, "events", {}), J = o.data(
I, "handle")
|| o
.data(
I,
"handle",
function() {
return typeof o !== "undefined"
&& !o.event.triggered ? o.event.handle
.apply(arguments.callee.elem,
arguments)
: g
});
J.elem = I;
o
.each(F.split(/\s+/),
function(M, N) {
var O = N.split(".");
N = O.shift();
H.type = O.slice().sort().join(".");
var L = E[N];
if (o.event.specialAll[N]) {
o.event.specialAll[N].setup.call(I, K, O)
}
if (!L) {
L = E[N] = {};
if (!o.event.special[N]
|| o.event.special[N].setup.call(I,
K, O) === false) {
if (I.addEventListener) {
I.addEventListener(N, J, false)
} else {
if (I.attachEvent) {
I.attachEvent("on" + N, J)
}
}
}
}
L[H.guid] = H;
o.event.global[N] = true
});
I = null
},
guid : 1,
global : {},
remove : function(K, H, J) {
if (K.nodeType == 3 || K.nodeType == 8) {
return
}
var G = o.data(K, "events"), F, E;
if (G) {
if (H === g || (typeof H === "string" && H.charAt(0) == ".")) {
for ( var I in G) {
this.remove(K, I + (H || ""))
}
} else {
if (H.type) {
J = H.handler;
H = H.type
}
o.each(H.split(/\s+/), function(M, O) {
var Q = O.split(".");
O = Q.shift();
var N = RegExp("(^|\\.)"
+ Q.slice().sort().join(".*\\.") + "(\\.|$)");
if (G[O]) {
if (J) {
delete G[O][J.guid]
} else {
for ( var P in G[O]) {
if (N.test(G[O][P].type)) {
delete G[O][P]
}
}
}
if (o.event.specialAll[O]) {
o.event.specialAll[O].teardown.call(K, Q)
}
for (F in G[O]) {
break
}
if (!F) {
if (!o.event.special[O]
|| o.event.special[O].teardown.call(K,
Q) === false) {
if (K.removeEventListener) {
K.removeEventListener(O, o.data(K,
"handle"), false)
} else {
if (K.detachEvent) {
K.detachEvent("on" + O, o.data(K,
"handle"))
}
}
}
F = null;
delete G[O]
}
}
})
}
for (F in G) {
break
}
if (!F) {
var L = o.data(K, "handle");
if (L) {
L.elem = null
}
o.removeData(K, "events");
o.removeData(K, "handle")
}
}
},
trigger : function(I, K, H, E) {
var G = I.type || I;
if (!E) {
I = typeof I === "object" ? I[h] ? I : o.extend(o.Event(G), I)
: o.Event(G);
if (G.indexOf("!") >= 0) {
I.type = G = G.slice(0, -1);
I.exclusive = true
}
if (!H) {
I.stopPropagation();
if (this.global[G]) {
o.each(o.cache, function() {
if (this.events && this.events[G]) {
o.event.trigger(I, K, this.handle.elem)
}
})
}
}
if (!H || H.nodeType == 3 || H.nodeType == 8) {
return g
}
I.result = g;
I.target = H;
K = o.makeArray(K);
K.unshift(I)
}
I.currentTarget = H;
var J = o.data(H, "handle");
if (J) {
J.apply(H, K)
}
if ((!H[G] || (o.nodeName(H, "a") && G == "click")) && H["on" + G]
&& H["on" + G].apply(H, K) === false) {
I.result = false
}
if (!E && H[G] && !I.isDefaultPrevented()
&& !(o.nodeName(H, "a") && G == "click")) {
this.triggered = true;
try {
H[G]()
} catch (L) {
}
}
this.triggered = false;
if (!I.isPropagationStopped()) {
var F = H.parentNode || H.ownerDocument;
if (F) {
o.event.trigger(I, K, F, true)
}
}
},
handle : function(K) {
var J, E;
K = arguments[0] = o.event.fix(K || l.event);
var L = K.type.split(".");
K.type = L.shift();
J = !L.length && !K.exclusive;
var I = RegExp("(^|\\.)" + L.slice().sort().join(".*\\.")
+ "(\\.|$)");
E = (o.data(this, "events") || {})[K.type];
for ( var G in E) {
var H = E[G];
if (J || I.test(H.type)) {
K.handler = H;
K.data = H.data;
var F = H.apply(this, arguments);
if (F !== g) {
K.result = F;
if (F === false) {
K.preventDefault();
K.stopPropagation()
}
}
if (K.isImmediatePropagationStopped()) {
break
}
}
}
},
props : "altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which"
.split(" "),
fix : function(H) {
if (H[h]) {
return H
}
var F = H;
H = o.Event(F);
for (var G = this.props.length, J; G;) {
J = this.props[--G];
H[J] = F[J]
}
if (!H.target) {
H.target = H.srcElement || document
}
if (H.target.nodeType == 3) {
H.target = H.target.parentNode
}
if (!H.relatedTarget && H.fromElement) {
H.relatedTarget = H.fromElement == H.target ? H.toElement
: H.fromElement
}
if (H.pageX == null && H.clientX != null) {
var I = document.documentElement, E = document.body;
H.pageX = H.clientX
+ (I && I.scrollLeft || E && E.scrollLeft || 0)
- (I.clientLeft || 0);
H.pageY = H.clientY
+ (I && I.scrollTop || E && E.scrollTop || 0)
- (I.clientTop || 0)
}
if (!H.which
&& ((H.charCode || H.charCode === 0) ? H.charCode
: H.keyCode)) {
H.which = H.charCode || H.keyCode
}
if (!H.metaKey && H.ctrlKey) {
H.metaKey = H.ctrlKey
}
if (!H.which && H.button) {
H.which = (H.button & 1 ? 1 : (H.button & 2 ? 3
: (H.button & 4 ? 2 : 0)))
}
return H
},
proxy : function(F, E) {
E = E || function() {
return F.apply(this, arguments)
};
E.guid = F.guid = F.guid || E.guid || this.guid++;
return E
},
special : {
ready : {
setup : B,
teardown : function() {
}
}
},
specialAll : {
live : {
setup : function(E, F) {
o.event.add(this, F[0], c)
},
teardown : function(G) {
if (G.length) {
var E = 0, F = RegExp("(^|\\.)" + G[0] + "(\\.|$)");
o.each((o.data(this, "events").live || {}), function() {
if (F.test(this.type)) {
E++
}
});
if (E < 1) {
o.event.remove(this, G[0], c)
}
}
}
}
}
};
o.Event = function(E) {
if (!this.preventDefault) {
return new o.Event(E)
}
if (E && E.type) {
this.originalEvent = E;
this.type = E.type
} else {
this.type = E
}
this.timeStamp = e();
this[h] = true
};
function k() {
return false
}
function u() {
return true
}
o.Event.prototype = {
preventDefault : function() {
this.isDefaultPrevented = u;
var E = this.originalEvent;
if (!E) {
return
}
if (E.preventDefault) {
E.preventDefault()
}
E.returnValue = false
},
stopPropagation : function() {
this.isPropagationStopped = u;
var E = this.originalEvent;
if (!E) {
return
}
if (E.stopPropagation) {
E.stopPropagation()
}
E.cancelBubble = true
},
stopImmediatePropagation : function() {
this.isImmediatePropagationStopped = u;
this.stopPropagation()
},
isDefaultPrevented : k,
isPropagationStopped : k,
isImmediatePropagationStopped : k
};
var a = function(F) {
var E = F.relatedTarget;
while (E && E != this) {
try {
E = E.parentNode
} catch (G) {
E = this
}
}
if (E != this) {
F.type = F.data;
o.event.handle.apply(this, arguments)
}
};
o.each({
mouseover : "mouseenter",
mouseout : "mouseleave"
}, function(F, E) {
o.event.special[E] = {
setup : function() {
o.event.add(this, F, a, E)
},
teardown : function() {
o.event.remove(this, F, a)
}
}
});
o.fn.extend({
bind : function(F, G, E) {
return F == "unload" ? this.one(F, G, E) : this.each(function() {
o.event.add(this, F, E || G, E && G)
})
},
one : function(G, H, F) {
var E = o.event.proxy(F || H, function(I) {
o(this).unbind(I, E);
return (F || H).apply(this, arguments)
});
return this.each(function() {
o.event.add(this, G, E, F && H)
})
},
unbind : function(F, E) {
return this.each(function() {
o.event.remove(this, F, E)
})
},
trigger : function(E, F) {
return this.each(function() {
o.event.trigger(E, F, this)
})
},
triggerHandler : function(E, G) {
if (this[0]) {
var F = o.Event(E);
F.preventDefault();
F.stopPropagation();
o.event.trigger(F, G, this[0]);
return F.result
}
},
toggle : function(G) {
var E = arguments, F = 1;
while (F < E.length) {
o.event.proxy(G, E[F++])
}
return this.click(o.event.proxy(G, function(H) {
this.lastToggle = (this.lastToggle || 0) % F;
H.preventDefault();
return E[this.lastToggle++].apply(this, arguments) || false
}))
},
hover : function(E, F) {
return this.mouseenter(E).mouseleave(F)
},
ready : function(E) {
B();
if (o.isReady) {
E.call(document, o)
} else {
o.readyList.push(E)
}
return this
},
live : function(G, F) {
var E = o.event.proxy(F);
E.guid += this.selector + G;
o(document).bind(i(G, this.selector), this.selector, E);
return this
},
die : function(F, E) {
o(document).unbind(i(F, this.selector), E ? {
guid : E.guid + this.selector + F
} : null);
return this
}
});
function c(H) {
var E = RegExp("(^|\\.)" + H.type + "(\\.|$)"), G = true, F = [];
o.each(o.data(this, "events").live || [], function(I, J) {
if (E.test(J.type)) {
var K = o(H.target).closest(J.data)[0];
if (K) {
F.push({
elem : K,
fn : J
})
}
}
});
o.each(F, function() {
if (this.fn.call(this.elem, H, this.fn.data) === false) {
G = false
}
});
return G
}
function i(F, E) {
return [ "live", F, E.replace(/\./g, "`").replace(/ /g, "|") ]
.join(".")
}
o.extend({
isReady : false,
readyList : [],
ready : function() {
if (!o.isReady) {
o.isReady = true;
if (o.readyList) {
o.each(o.readyList, function() {
this.call(document, o)
});
o.readyList = null
}
o(document).triggerHandler("ready")
}
}
});
var x = false;
function B() {
if (x) {
return
}
x = true;
if (document.addEventListener) {
document.addEventListener("DOMContentLoaded", function() {
document.removeEventListener("DOMContentLoaded",
arguments.callee, false);
o.ready()
}, false)
} else {
if (document.attachEvent) {
document.attachEvent("onreadystatechange", function() {
if (document.readyState === "complete") {
document.detachEvent("onreadystatechange",
arguments.callee);
o.ready()
}
});
if (document.documentElement.doScroll
&& typeof l.frameElement === "undefined") {
(function() {
if (o.isReady) {
return
}
try {
document.documentElement.doScroll("left")
} catch (E) {
setTimeout(arguments.callee, 0);
return
}
o.ready()
})()
}
}
}
o.event.add(l, "load", o.ready)
}
o
.each(
("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error")
.split(","), function(F, E) {
o.fn[E] = function(G) {
return G ? this.bind(E, G) : this.trigger(E)
}
});
o(l).bind("unload", function() {
for ( var E in o.cache) {
if (E != 1 && o.cache[E].handle) {
o.event.remove(o.cache[E].handle.elem)
}
}
});
(function() {
o.support = {};
var F = document.documentElement, G = document.createElement("script"), K = document
.createElement("div"), J = "script" + (new Date).getTime();
K.style.display = "none";
K.innerHTML = ' <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>';
var H = K.getElementsByTagName("*"), E = K.getElementsByTagName("a")[0];
if (!H || !H.length || !E) {
return
}
o.support = {
leadingWhitespace : K.firstChild.nodeType == 3,
tbody : !K.getElementsByTagName("tbody").length,
objectAll : !!K.getElementsByTagName("object")[0]
.getElementsByTagName("*").length,
htmlSerialize : !!K.getElementsByTagName("link").length,
style : /red/.test(E.getAttribute("style")),
hrefNormalized : E.getAttribute("href") === "/a",
opacity : E.style.opacity === "0.5",
cssFloat : !!E.style.cssFloat,
scriptEval : false,
noCloneEvent : true,
boxModel : null
};
G.type = "text/javascript";
try {
G.appendChild(document.createTextNode("window." + J + "=1;"))
} catch (I) {
}
F.insertBefore(G, F.firstChild);
if (l[J]) {
o.support.scriptEval = true;
delete l[J]
}
F.removeChild(G);
if (K.attachEvent && K.fireEvent) {
K.attachEvent("onclick", function() {
o.support.noCloneEvent = false;
K.detachEvent("onclick", arguments.callee)
});
K.cloneNode(true).fireEvent("onclick")
}
o(function() {
var L = document.createElement("div");
L.style.width = "1px";
L.style.paddingLeft = "1px";
document.body.appendChild(L);
o.boxModel = o.support.boxModel = L.offsetWidth === 2;
document.body.removeChild(L)
})
})();
var w = o.support.cssFloat ? "cssFloat" : "styleFloat";
o.props = {
"for" : "htmlFor",
"class" : "className",
"float" : w,
cssFloat : w,
styleFloat : w,
readonly : "readOnly",
maxlength : "maxLength",
cellspacing : "cellSpacing",
rowspan : "rowSpan",
tabindex : "tabIndex"
};
o.fn
.extend({
_load : o.fn.load,
load : function(G, J, K) {
if (typeof G !== "string") {
return this._load(G)
}
var I = G.indexOf(" ");
if (I >= 0) {
var E = G.slice(I, G.length);
G = G.slice(0, I)
}
var H = "GET";
if (J) {
if (o.isFunction(J)) {
K = J;
J = null
} else {
if (typeof J === "object") {
J = o.param(J);
H = "POST"
}
}
}
var F = this;
o
.ajax({
url : G,
type : H,
dataType : "html",
data : J,
complete : function(M, L) {
if (L == "success" || L == "notmodified") {
F
.html(E ? o("<div/>")
.append(
M.responseText
.replace(
/<script(.|\s)*?\/script>/g,
""))
.find(E)
: M.responseText)
}
if (K) {
F.each(K, [ M.responseText, L, M ])
}
}
});
return this
},
serialize : function() {
return o.param(this.serializeArray())
},
serializeArray : function() {
return this
.map(
function() {
return this.elements ? o
.makeArray(this.elements)
: this
})
.filter(
function() {
return this.name
&& !this.disabled
&& (this.checked
|| /select|textarea/i
.test(this.nodeName) || /text|hidden|password/i
.test(this.type))
}).map(
function(E, F) {
var G = o(this).val();
return G == null ? null
: o.isArray(G) ? o.map(G,
function(I, H) {
return {
name : F.name,
value : I
}
}) : {
name : F.name,
value : G
}
}).get()
}
});
o.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend"
.split(","), function(E, F) {
o.fn[F] = function(G) {
return this.bind(F, G)
}
});
var r = e();
o
.extend({
get : function(E, G, H, F) {
if (o.isFunction(G)) {
H = G;
G = null
}
return o.ajax({
type : "GET",
url : E,
data : G,
success : H,
dataType : F
})
},
getScript : function(E, F) {
return o.get(E, null, F, "script")
},
getJSON : function(E, F, G) {
return o.get(E, F, G, "json")
},
post : function(E, G, H, F) {
if (o.isFunction(G)) {
H = G;
G = {}
}
return o.ajax({
type : "POST",
url : E,
data : G,
success : H,
dataType : F
})
},
ajaxSetup : function(E) {
o.extend(o.ajaxSettings, E)
},
ajaxSettings : {
url : location.href,
global : true,
type : "GET",
contentType : "application/x-www-form-urlencoded",
processData : true,
async : true,
xhr : function() {
return l.ActiveXObject ? new ActiveXObject(
"Microsoft.XMLHTTP") : new XMLHttpRequest()
},
accepts : {
xml : "application/xml, text/xml",
html : "text/html",
script : "text/javascript, application/javascript",
json : "application/json, text/javascript",
text : "text/plain",
_default : "*/*"
}
},
lastModified : {},
ajax : function(M) {
M = o
.extend(true, M, o.extend(true, {}, o.ajaxSettings,
M));
var W, F = /=\?(&|$)/g, R, V, G = M.type.toUpperCase();
if (M.data && M.processData && typeof M.data !== "string") {
M.data = o.param(M.data)
}
if (M.dataType == "jsonp") {
if (G == "GET") {
if (!M.url.match(F)) {
M.url += (M.url.match(/\?/) ? "&" : "?")
+ (M.jsonp || "callback") + "=?"
}
} else {
if (!M.data || !M.data.match(F)) {
M.data = (M.data ? M.data + "&" : "")
+ (M.jsonp || "callback") + "=?"
}
}
M.dataType = "json"
}
if (M.dataType == "json"
&& (M.data && M.data.match(F) || M.url.match(F))) {
W = "jsonp" + r++;
if (M.data) {
M.data = (M.data + "").replace(F, "=" + W + "$1")
}
M.url = M.url.replace(F, "=" + W + "$1");
M.dataType = "script";
l[W] = function(X) {
V = X;
I();
L();
l[W] = g;
try {
delete l[W]
} catch (Y) {
}
if (H) {
H.removeChild(T)
}
}
}
if (M.dataType == "script" && M.cache == null) {
M.cache = false
}
if (M.cache === false && G == "GET") {
var E = e();
var U = M.url.replace(/(\?|&)_=.*?(&|$)/, "$1_=" + E
+ "$2");
M.url = U
+ ((U == M.url) ? (M.url.match(/\?/) ? "&"
: "?")
+ "_=" + E : "")
}
if (M.data && G == "GET") {
M.url += (M.url.match(/\?/) ? "&" : "?") + M.data;
M.data = null
}
if (M.global && !o.active++) {
o.event.trigger("ajaxStart")
}
var Q = /^(\w+:)?\/\/([^\/?#]+)/.exec(M.url);
if (M.dataType == "script"
&& G == "GET"
&& Q
&& (Q[1] && Q[1] != location.protocol || Q[2] != location.host)) {
var H = document.getElementsByTagName("head")[0];
var T = document.createElement("script");
T.src = M.url;
if (M.scriptCharset) {
T.charset = M.scriptCharset
}
if (!W) {
var O = false;
T.onload = T.onreadystatechange = function() {
if (!O
&& (!this.readyState
|| this.readyState == "loaded" || this.readyState == "complete")) {
O = true;
I();
L();
H.removeChild(T)
}
}
}
H.appendChild(T);
return g
}
var K = false;
var J = M.xhr();
if (M.username) {
J.open(G, M.url, M.async, M.username, M.password)
} else {
J.open(G, M.url, M.async)
}
try {
if (M.data) {
J.setRequestHeader("Content-Type", M.contentType)
}
if (M.ifModified) {
J.setRequestHeader("If-Modified-Since",
o.lastModified[M.url]
|| "Thu, 01 Jan 1970 00:00:00 GMT")
}
J
.setRequestHeader("X-Requested-With",
"XMLHttpRequest");
J
.setRequestHeader(
"Accept",
M.dataType && M.accepts[M.dataType] ? M.accepts[M.dataType]
+ ", */*"
: M.accepts._default)
} catch (S) {
}
if (M.beforeSend && M.beforeSend(J, M) === false) {
if (M.global && !--o.active) {
o.event.trigger("ajaxStop")
}
J.abort();
return false
}
if (M.global) {
o.event.trigger("ajaxSend", [ J, M ])
}
var N = function(X) {
if (J.readyState == 0) {
if (P) {
clearInterval(P);
P = null;
if (M.global && !--o.active) {
o.event.trigger("ajaxStop")
}
}
} else {
if (!K && J
&& (J.readyState == 4 || X == "timeout")) {
K = true;
if (P) {
clearInterval(P);
P = null
}
R = X == "timeout" ? "timeout"
: !o.httpSuccess(J) ? "error"
: M.ifModified
&& o.httpNotModified(J,
M.url) ? "notmodified"
: "success";
if (R == "success") {
try {
V = o.httpData(J, M.dataType, M)
} catch (Z) {
R = "parsererror"
}
}
if (R == "success") {
var Y;
try {
Y = J
.getResponseHeader("Last-Modified")
} catch (Z) {
}
if (M.ifModified && Y) {
o.lastModified[M.url] = Y
}
if (!W) {
I()
}
} else {
o.handleError(M, J, R)
}
L();
if (X) {
J.abort()
}
if (M.async) {
J = null
}
}
}
};
if (M.async) {
var P = setInterval(N, 13);
if (M.timeout > 0) {
setTimeout(function() {
if (J && !K) {
N("timeout")
}
}, M.timeout)
}
}
try {
J.send(M.data)
} catch (S) {
o.handleError(M, J, null, S)
}
if (!M.async) {
N()
}
function I() {
if (M.success) {
M.success(V, R)
}
if (M.global) {
o.event.trigger("ajaxSuccess", [ J, M ])
}
}
function L() {
if (M.complete) {
M.complete(J, R)
}
if (M.global) {
o.event.trigger("ajaxComplete", [ J, M ])
}
if (M.global && !--o.active) {
o.event.trigger("ajaxStop")
}
}
return J
},
handleError : function(F, H, E, G) {
if (F.error) {
F.error(H, E, G)
}
if (F.global) {
o.event.trigger("ajaxError", [ H, F, G ])
}
},
active : 0,
httpSuccess : function(F) {
try {
return !F.status && location.protocol == "file:"
|| (F.status >= 200 && F.status < 300)
|| F.status == 304 || F.status == 1223
} catch (E) {
}
return false
},
httpNotModified : function(G, E) {
try {
var H = G.getResponseHeader("Last-Modified");
return G.status == 304 || H == o.lastModified[E]
} catch (F) {
}
return false
},
httpData : function(J, H, G) {
var F = J.getResponseHeader("content-type"), E = H == "xml"
|| !H && F && F.indexOf("xml") >= 0, I = E ? J.responseXML
: J.responseText;
if (E && I.documentElement.tagName == "parsererror") {
throw "parsererror"
}
if (G && G.dataFilter) {
I = G.dataFilter(I, H)
}
if (typeof I === "string") {
if (H == "script") {
o.globalEval(I)
}
if (H == "json") {
I = l["eval"]("(" + I + ")")
}
}
return I
},
param : function(E) {
var G = [];
function H(I, J) {
G[G.length] = encodeURIComponent(I) + "="
+ encodeURIComponent(J)
}
if (o.isArray(E) || E.jquery) {
o.each(E, function() {
H(this.name, this.value)
})
} else {
for ( var F in E) {
if (o.isArray(E[F])) {
o.each(E[F], function() {
H(F, this)
})
} else {
H(F, o.isFunction(E[F]) ? E[F]() : E[F])
}
}
}
return G.join("&").replace(/%20/g, "+")
}
});
var m = {}, n, d = [
[ "height", "marginTop", "marginBottom", "paddingTop",
"paddingBottom" ],
[ "width", "marginLeft", "marginRight", "paddingLeft",
"paddingRight" ], [ "opacity" ] ];
function t(F, E) {
var G = {};
o.each(d.concat.apply([], d.slice(0, E)), function() {
G[this] = F
});
return G
}
o.fn.extend({
show : function(J, L) {
if (J) {
return this.animate(t("show", 3), J, L)
} else {
for (var H = 0, F = this.length; H < F; H++) {
var E = o.data(this[H], "olddisplay");
this[H].style.display = E || "";
if (o.css(this[H], "display") === "none") {
var G = this[H].tagName, K;
if (m[G]) {
K = m[G]
} else {
var I = o("<" + G + " />").appendTo("body");
K = I.css("display");
if (K === "none") {
K = "block"
}
I.remove();
m[G] = K
}
this[H].style.display = o
.data(this[H], "olddisplay", K)
}
}
return this
}
},
hide : function(H, I) {
if (H) {
return this.animate(t("hide", 3), H, I)
} else {
for (var G = 0, F = this.length; G < F; G++) {
var E = o.data(this[G], "olddisplay");
if (!E && E !== "none") {
o
.data(this[G], "olddisplay", o.css(this[G],
"display"))
}
this[G].style.display = "none"
}
return this
}
},
_toggle : o.fn.toggle,
toggle : function(G, F) {
var E = typeof G === "boolean";
return o.isFunction(G) && o.isFunction(F) ? this._toggle.apply(
this, arguments) : G == null || E ? this.each(function() {
var H = E ? G : o(this).is(":hidden");
o(this)[H ? "show" : "hide"]()
}) : this.animate(t("toggle", 3), G, F)
},
fadeTo : function(E, G, F) {
return this.animate({
opacity : G
}, E, F)
},
animate : function(I, F, H, G) {
var E = o.speed(F, H, G);
return this[E.queue === false ? "each" : "queue"](function() {
var K = o.extend({}, E), M, L = this.nodeType == 1
&& o(this).is(":hidden"), J = this;
for (M in I) {
if (I[M] == "hide" && L || I[M] == "show" && !L) {
return K.complete.call(this)
}
if ((M == "height" || M == "width") && this.style) {
K.display = o.css(this, "display");
K.overflow = this.style.overflow
}
}
if (K.overflow != null) {
this.style.overflow = "hidden"
}
K.curAnim = o.extend({}, I);
o.each(I,
function(O, S) {
var R = new o.fx(J, K, O);
if (/toggle|show|hide/.test(S)) {
R[S == "toggle" ? L ? "show" : "hide" : S](I)
} else {
var Q = S.toString().match(
/^([+-]=)?([\d+-.]+)(.*)$/), T = R
.cur(true) || 0;
if (Q) {
var N = parseFloat(Q[2]), P = Q[3] || "px";
if (P != "px") {
J.style[O] = (N || 1) + P;
T = ((N || 1) / R.cur(true)) * T;
J.style[O] = T + P
}
if (Q[1]) {
N = ((Q[1] == "-=" ? -1 : 1) * N) + T
}
R.custom(T, N, P)
} else {
R.custom(T, S, "")
}
}
});
return true
})
},
stop : function(F, E) {
var G = o.timers;
if (F) {
this.queue([])
}
this.each(function() {
for (var H = G.length - 1; H >= 0; H--) {
if (G[H].elem == this) {
if (E) {
G[H](true)
}
G.splice(H, 1)
}
}
});
if (!E) {
this.dequeue()
}
return this
}
});
o.each({
slideDown : t("show", 1),
slideUp : t("hide", 1),
slideToggle : t("toggle", 1),
fadeIn : {
opacity : "show"
},
fadeOut : {
opacity : "hide"
}
}, function(E, F) {
o.fn[E] = function(G, H) {
return this.animate(F, G, H)
}
});
o.extend({
speed : function(G, H, F) {
var E = typeof G === "object" ? G : {
complete : F || !F && H || o.isFunction(G) && G,
duration : G,
easing : F && H || H && !o.isFunction(H) && H
};
E.duration = o.fx.off ? 0
: typeof E.duration === "number" ? E.duration
: o.fx.speeds[E.duration] || o.fx.speeds._default;
E.old = E.complete;
E.complete = function() {
if (E.queue !== false) {
o(this).dequeue()
}
if (o.isFunction(E.old)) {
E.old.call(this)
}
};
return E
},
easing : {
linear : function(G, H, E, F) {
return E + F * G
},
swing : function(G, H, E, F) {
return ((-Math.cos(G * Math.PI) / 2) + 0.5) * F + E
}
},
timers : [],
fx : function(F, E, G) {
this.options = E;
this.elem = F;
this.prop = G;
if (!E.orig) {
E.orig = {}
}
}
});
o.fx.prototype = {
update : function() {
if (this.options.step) {
this.options.step.call(this.elem, this.now, this)
}
(o.fx.step[this.prop] || o.fx.step._default)(this);
if ((this.prop == "height" || this.prop == "width")
&& this.elem.style) {
this.elem.style.display = "block"
}
},
cur : function(F) {
if (this.elem[this.prop] != null
&& (!this.elem.style || this.elem.style[this.prop] == null)) {
return this.elem[this.prop]
}
var E = parseFloat(o.css(this.elem, this.prop, F));
return E && E > -10000 ? E : parseFloat(o.curCSS(this.elem,
this.prop)) || 0
},
custom : function(I, H, G) {
this.startTime = e();
this.start = I;
this.end = H;
this.unit = G || this.unit || "px";
this.now = this.start;
this.pos = this.state = 0;
var E = this;
function F(J) {
return E.step(J)
}
F.elem = this.elem;
if (F() && o.timers.push(F) == 1) {
n = setInterval(function() {
var K = o.timers;
for (var J = 0; J < K.length; J++) {
if (!K[J]()) {
K.splice(J--, 1)
}
}
if (!K.length) {
clearInterval(n)
}
}, 13)
}
},
show : function() {
this.options.orig[this.prop] = o.attr(this.elem.style, this.prop);
this.options.show = true;
this.custom(this.prop == "width" || this.prop == "height" ? 1 : 0,
this.cur());
o(this.elem).show()
},
hide : function() {
this.options.orig[this.prop] = o.attr(this.elem.style, this.prop);
this.options.hide = true;
this.custom(this.cur(), 0)
},
step : function(H) {
var G = e();
if (H || G >= this.options.duration + this.startTime) {
this.now = this.end;
this.pos = this.state = 1;
this.update();
this.options.curAnim[this.prop] = true;
var E = true;
for ( var F in this.options.curAnim) {
if (this.options.curAnim[F] !== true) {
E = false
}
}
if (E) {
if (this.options.display != null) {
this.elem.style.overflow = this.options.overflow;
this.elem.style.display = this.options.display;
if (o.css(this.elem, "display") == "none") {
this.elem.style.display = "block"
}
}
if (this.options.hide) {
o(this.elem).hide()
}
if (this.options.hide || this.options.show) {
for ( var I in this.options.curAnim) {
o.attr(this.elem.style, I, this.options.orig[I])
}
}
this.options.complete.call(this.elem)
}
return false
} else {
var J = G - this.startTime;
this.state = J / this.options.duration;
this.pos = o.easing[this.options.easing
|| (o.easing.swing ? "swing" : "linear")](this.state,
J, 0, 1, this.options.duration);
this.now = this.start + ((this.end - this.start) * this.pos);
this.update()
}
return true
}
};
o.extend(o.fx, {
speeds : {
slow : 600,
fast : 200,
_default : 400
},
step : {
opacity : function(E) {
o.attr(E.elem.style, "opacity", E.now)
},
_default : function(E) {
if (E.elem.style && E.elem.style[E.prop] != null) {
E.elem.style[E.prop] = E.now + E.unit
} else {
E.elem[E.prop] = E.now
}
}
}
});
if (document.documentElement.getBoundingClientRect) {
o.fn.offset = function() {
if (!this[0]) {
return {
top : 0,
left : 0
}
}
if (this[0] === this[0].ownerDocument.body) {
return o.offset.bodyOffset(this[0])
}
var G = this[0].getBoundingClientRect(), J = this[0].ownerDocument, F = J.body, E = J.documentElement, L = E.clientTop
|| F.clientTop || 0, K = E.clientLeft || F.clientLeft || 0, I = G.top
+ (self.pageYOffset || o.boxModel && E.scrollTop || F.scrollTop)
- L, H = G.left
+ (self.pageXOffset || o.boxModel && E.scrollLeft || F.scrollLeft)
- K;
return {
top : I,
left : H
}
}
} else {
o.fn.offset = function() {
if (!this[0]) {
return {
top : 0,
left : 0
}
}
if (this[0] === this[0].ownerDocument.body) {
return o.offset.bodyOffset(this[0])
}
o.offset.initialized || o.offset.initialize();
var J = this[0], G = J.offsetParent, F = J, O = J.ownerDocument, M, H = O.documentElement, K = O.body, L = O.defaultView, E = L
.getComputedStyle(J, null), N = J.offsetTop, I = J.offsetLeft;
while ((J = J.parentNode) && J !== K && J !== H) {
M = L.getComputedStyle(J, null);
N -= J.scrollTop, I -= J.scrollLeft;
if (J === G) {
N += J.offsetTop, I += J.offsetLeft;
if (o.offset.doesNotAddBorder
&& !(o.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i
.test(J.tagName))) {
N += parseInt(M.borderTopWidth, 10) || 0,
I += parseInt(M.borderLeftWidth, 10) || 0
}
F = G, G = J.offsetParent
}
if (o.offset.subtractsBorderForOverflowNotVisible
&& M.overflow !== "visible") {
N += parseInt(M.borderTopWidth, 10) || 0, I += parseInt(
M.borderLeftWidth, 10) || 0
}
E = M
}
if (E.position === "relative" || E.position === "static") {
N += K.offsetTop, I += K.offsetLeft
}
if (E.position === "fixed") {
N += Math.max(H.scrollTop, K.scrollTop), I += Math.max(
H.scrollLeft, K.scrollLeft)
}
return {
top : N,
left : I
}
}
}
o.offset = {
initialize : function() {
if (this.initialized) {
return
}
var L = document.body, F = document.createElement("div"), H, G, N, I, M, E, J = L.style.marginTop, K = '<div style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"><div></div></div><table style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;" cellpadding="0" cellspacing="0"><tr><td></td></tr></table>';
M = {
position : "absolute",
top : 0,
left : 0,
margin : 0,
border : 0,
width : "1px",
height : "1px",
visibility : "hidden"
};
for (E in M) {
F.style[E] = M[E]
}
F.innerHTML = K;
L.insertBefore(F, L.firstChild);
H = F.firstChild, G = H.firstChild,
I = H.nextSibling.firstChild.firstChild;
this.doesNotAddBorder = (G.offsetTop !== 5);
this.doesAddBorderForTableAndCells = (I.offsetTop === 5);
H.style.overflow = "hidden", H.style.position = "relative";
this.subtractsBorderForOverflowNotVisible = (G.offsetTop === -5);
L.style.marginTop = "1px";
this.doesNotIncludeMarginInBodyOffset = (L.offsetTop === 0);
L.style.marginTop = J;
L.removeChild(F);
this.initialized = true
},
bodyOffset : function(E) {
o.offset.initialized || o.offset.initialize();
var G = E.offsetTop, F = E.offsetLeft;
if (o.offset.doesNotIncludeMarginInBodyOffset) {
G += parseInt(o.curCSS(E, "marginTop", true), 10) || 0,
F += parseInt(o.curCSS(E, "marginLeft", true), 10) || 0
}
return {
top : G,
left : F
}
}
};
o.fn
.extend({
position : function() {
var I = 0, H = 0, F;
if (this[0]) {
var G = this.offsetParent(), J = this.offset(), E = /^body|html$/i
.test(G[0].tagName) ? {
top : 0,
left : 0
} : G.offset();
J.top -= j(this, "marginTop");
J.left -= j(this, "marginLeft");
E.top += j(G, "borderTopWidth");
E.left += j(G, "borderLeftWidth");
F = {
top : J.top - E.top,
left : J.left - E.left
}
}
return F
},
offsetParent : function() {
var E = this[0].offsetParent || document.body;
while (E
&& (!/^body|html$/i.test(E.tagName) && o.css(E,
"position") == "static")) {
E = E.offsetParent
}
return o(E)
}
});
o.each([ "Left", "Top" ], function(F, E) {
var G = "scroll" + E;
o.fn[G] = function(H) {
if (!this[0]) {
return null
}
return H !== g ? this.each(function() {
this == l || this == document ? l.scrollTo(!F ? H : o(l)
.scrollLeft(), F ? H : o(l).scrollTop()) : this[G] = H
}) : this[0] == l || this[0] == document ? self[F ? "pageYOffset"
: "pageXOffset"]
|| o.boxModel
&& document.documentElement[G]
|| document.body[G] : this[0][G]
}
});
o.each([ "Height", "Width" ], function(H, F) {
var E = H ? "Left" : "Top", G = H ? "Right" : "Bottom";
o.fn["inner" + F] = function() {
return this[F.toLowerCase()]() + j(this, "padding" + E)
+ j(this, "padding" + G)
};
o.fn["outer" + F] = function(J) {
return this["inner" + F]() + j(this, "border" + E + "Width")
+ j(this, "border" + G + "Width")
+ (J ? j(this, "margin" + E) + j(this, "margin" + G) : 0)
};
var I = F.toLowerCase();
o.fn[I] = function(J) {
return this[0] == l ? document.compatMode == "CSS1Compat"
&& document.documentElement["client" + F]
|| document.body["client" + F] : this[0] == document ? Math
.max(document.documentElement["client" + F],
document.body["scroll" + F],
document.documentElement["scroll" + F],
document.body["offset" + F],
document.documentElement["offset" + F])
: J === g ? (this.length ? o.css(this[0], I) : null) : this
.css(I, typeof J === "string" ? J : J + "px")
}
})
})();
jQuery Pagination分页插件的更多相关文章
- jQuery Pagination分页插件--刷新
源码地址:https://github.com/SeaLee02/FunctionModule/blob/master/UploadFiles/WebDemo/FenYE/FenYeDemo.aspx ...
- JQuery Pagination 分页插件 增加了首页尾页以及跳转功能
JQuery分页插件 挺好用的 但是官方是没有提供首页尾页以及跳转功能 我觉得这个功能可以有,于是就改进了一下 一个js一个css从连接里面下 链接:http://pan.baidu.com/s/1n ...
- Jquery Pagination分页插件使用
JqueryPagination是个简单轻量级的分页插件,使用起来很容易,只要初始化一个实例,并设置总数量.翻页回调函数.其它参数就可以实现无刷新分页功能了. 准备工作 下载jquery.min.js ...
- jQuery Pagination分页插件--无刷新
源码:https://github.com/SeaLee02/FunctionModule/blob/master/UploadFiles/WebDemo/FenYE/FenYeAjax.aspx 代 ...
- jQuery Pagination分页插件的使用
一.引用CSS和JS: <link href="/Content/Plugins/jQuery.Pagination_v2.2/pagination.css" rel=&qu ...
- Jquery前端分页插件pagination使用
插件描述:JqueryPagination是一个轻量级的jquery分页插件.只需几个简单的配置就可以生成分页控件.并且支持ajax获取数据,自定义请求参数,提供多种方法,事件和回调函数,功能全面的分 ...
- Slider 滚动条 Pagination分页插件 JS Ajax 数据范围筛选 加载 翻页 笔记
入职以后的第二个任务 根据用户所选的价格范围 筛选数据 修复BUG - 筛选数据后 总数没有更新.列表显示错误.翻页加载错误 用到的一些知识点 jquery插件系列之 - Slider滑块 max ...
- Jquery前端分页插件pagination同步加载和异步加载
上一篇文章介绍了Jquery前端分页插件pagination的基本使用方法和使用案例,大致原理就是一次性加载所有的数据再分页.https://www.jianshu.com/p/a1b8b1db025 ...
- 转:精心挑选的12款优秀 jQuery Ajax 分页插件和教程
在这篇文章中,我为大家收集了12个基于 jQuery 框架的 Ajax 分页插件,这些插件都提供了详细的使用教程和演示.Ajax 技术的出现使得 Web 项目的用户体验有了极大的提高,如今借助优秀的 ...
随机推荐
- 小白学习安全测试(三)——扫描工具-Nikto使用
扫描工具-Nikto #基于WEB的扫描工具,基本都支持两种扫描模式.代理截断模式,主动扫描模式 手动扫描:作为用户操作发现页面存在的问题,但可能会存在遗漏 自动扫描:基于字典,提高速度,但存在误报和 ...
- Google-Guice入门介绍
原地址:http://blog.csdn.net/derekjiang/article/details/7231490 一. 概述 Guice是一个轻量级的DI框架.本文对Guice的基本用法作以介绍 ...
- [转] Web移动端Fixed布局的解决方案
移动端业务开发,iOS 下经常会有 fixed 元素和输入框(input 元素)同时存在的情况. 但是 fixed 元素在有软键盘唤起的情况下,会出现许多莫名其妙的问题. 这篇文章里就提供一个简单的有 ...
- CentOS6下Jenkins连接Git服务器出错的问题
今天研究GitLab+Jenkins自动集成时,出现Failed to connect to repository : Command "git config --local credent ...
- NET WebAPi之断点续传下载(下)
NET WebAPi之断点续传下载(下) 前言 上一篇我们穿插了C#的内容,本篇我们继续来讲讲webapi中断点续传的其他情况以及利用webclient来实现断点续传,至此关于webapi断点续传下载 ...
- 操作数组不要只会for循环
很多时候,我们在操作数组的时候往往就是一个for循环干到底,对数组提供的其它方法视而不见.看完本文,希望你可以换种思路处理数组,然后可以写出更加漂亮.简洁.函数式的代码. reduce 数组里所有值的 ...
- 支付宝app支付服务端流程
支付宝APP支付服务端详解 前面接了微信支付,相比微信支付,支付宝APP支付提供了支付封装类,下面将实现支付宝APP支付.订单查询.支付结果异步通知.APP支付申请参数说明,以及服务端返回APP端发起 ...
- C#并行编程(4):基于任务的并行
C#中的任务Task 在C#编程中,实现并行可以直接使用线程,但使用起来很繁琐:也可以使用线程池,线程池很大程度上简化了线程的使用,但是也有着一些局限,比如我们不知道作业什么时候完成,也取不到作业的返 ...
- Android 短信拦截及用途分析
监听系统短信这个只能作为一个技术点来研究下,读者可能在工作中可能不会哦涉及到,一般的应用软件也不会有这个需求 但是作为程序员呢,多了解一下也是好的. Android 监听系统短信有什么用? 1.对系统 ...
- Orleans介绍
一.介绍 Orleans是一个框架,提供了一个直接的方法来构建分布式高规模计算应用程序 默认可扩展 -> Orleans处理构建分布式系统的复杂性,使您的应用程序能够扩展到数百台服务器.低延迟 ...