亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? jquery.js

?? jQuery即學即用
?? JS
?? 第 1 頁 / 共 5 頁
字號:
		// Compute a unique ID for the element		if ( !id ) { 			id = ++uuid;		}		// Avoid generating a new cache unless none exists and we		// want to manipulate it.		if ( typeof name === "object" ) {			elem[ expando ] = id;			thisCache = cache[ id ] = jQuery.extend(true, {}, name);		} else if ( !cache[ id ] ) {			elem[ expando ] = id;			cache[ id ] = {};		}		thisCache = cache[ id ];		// Prevent overriding the named cache with undefined values		if ( data !== undefined ) {			thisCache[ name ] = data;		}		return typeof name === "string" ? thisCache[ name ] : thisCache;	},	removeData: function( elem, name ) {		if ( elem.nodeName && jQuery.noData[elem.nodeName.toLowerCase()] ) {			return;		}		elem = elem == window ?			windowData :			elem;		var id = elem[ expando ], cache = jQuery.cache, thisCache = cache[ id ];		// If we want to remove a specific section of the element's data		if ( name ) {			if ( thisCache ) {				// Remove the section of cache data				delete thisCache[ name ];				// If we've removed all the data, remove the element's cache				if ( jQuery.isEmptyObject(thisCache) ) {					jQuery.removeData( elem );				}			}		// Otherwise, we want to remove all of the element's data		} else {			if ( jQuery.support.deleteExpando ) {				delete elem[ jQuery.expando ];			} else if ( elem.removeAttribute ) {				elem.removeAttribute( jQuery.expando );			}			// Completely remove the data cache			delete cache[ id ];		}	}});jQuery.fn.extend({	data: function( key, value ) {		if ( typeof key === "undefined" && this.length ) {			return jQuery.data( this[0] );		} else if ( typeof key === "object" ) {			return this.each(function() {				jQuery.data( this, key );			});		}		var parts = key.split(".");		parts[1] = parts[1] ? "." + parts[1] : "";		if ( value === undefined ) {			var data = this.triggerHandler("getData" + parts[1] + "!", [parts[0]]);			if ( data === undefined && this.length ) {				data = jQuery.data( this[0], key );			}			return data === undefined && parts[1] ?				this.data( parts[0] ) :				data;		} else {			return this.trigger("setData" + parts[1] + "!", [parts[0], value]).each(function() {				jQuery.data( this, key, value );			});		}	},	removeData: function( key ) {		return this.each(function() {			jQuery.removeData( this, key );		});	}});jQuery.extend({	queue: function( elem, type, data ) {		if ( !elem ) {			return;		}		type = (type || "fx") + "queue";		var q = jQuery.data( elem, type );		// Speed up dequeue by getting out quickly if this is just a lookup		if ( !data ) {			return q || [];		}		if ( !q || jQuery.isArray(data) ) {			q = jQuery.data( elem, type, jQuery.makeArray(data) );		} else {			q.push( data );		}		return q;	},	dequeue: function( elem, type ) {		type = type || "fx";		var queue = jQuery.queue( elem, type ), fn = queue.shift();		// If the fx queue is dequeued, always remove the progress sentinel		if ( fn === "inprogress" ) {			fn = queue.shift();		}		if ( fn ) {			// Add a progress sentinel to prevent the fx queue from being			// automatically dequeued			if ( type === "fx" ) {				queue.unshift("inprogress");			}			fn.call(elem, function() {				jQuery.dequeue(elem, type);			});		}	}});jQuery.fn.extend({	queue: function( type, data ) {		if ( typeof type !== "string" ) {			data = type;			type = "fx";		}		if ( data === undefined ) {			return jQuery.queue( this[0], type );		}		return this.each(function( i, elem ) {			var queue = jQuery.queue( this, type, data );			if ( type === "fx" && queue[0] !== "inprogress" ) {				jQuery.dequeue( this, type );			}		});	},	dequeue: function( type ) {		return this.each(function() {			jQuery.dequeue( this, type );		});	},	// Based off of the plugin by Clint Helfers, with permission.	// http://blindsignals.com/index.php/2009/07/jquery-delay/	delay: function( time, type ) {		time = jQuery.fx ? jQuery.fx.speeds[time] || time : time;		type = type || "fx";		return this.queue( type, function() {			var elem = this;			setTimeout(function() {				jQuery.dequeue( elem, type );			}, time );		});	},	clearQueue: function( type ) {		return this.queue( type || "fx", [] );	}});var rclass = /[\n\t]/g,	rspace = /\s+/,	rreturn = /\r/g,	rspecialurl = /href|src|style/,	rtype = /(button|input)/i,	rfocusable = /(button|input|object|select|textarea)/i,	rclickable = /^(a|area)$/i,	rradiocheck = /radio|checkbox/;jQuery.fn.extend({	attr: function( name, value ) {		return access( this, name, value, true, jQuery.attr );	},	removeAttr: function( name, fn ) {		return this.each(function(){			jQuery.attr( this, name, "" );			if ( this.nodeType === 1 ) {				this.removeAttribute( name );			}		});	},	addClass: function( value ) {		if ( jQuery.isFunction(value) ) {			return this.each(function(i) {				var self = jQuery(this);				self.addClass( value.call(this, i, self.attr("class")) );			});		}		if ( value && typeof value === "string" ) {			var classNames = (value || "").split( rspace );			for ( var i = 0, l = this.length; i < l; i++ ) {				var elem = this[i];				if ( elem.nodeType === 1 ) {					if ( !elem.className ) {						elem.className = value;					} else {						var className = " " + elem.className + " ", setClass = elem.className;						for ( var c = 0, cl = classNames.length; c < cl; c++ ) {							if ( className.indexOf( " " + classNames[c] + " " ) < 0 ) {								setClass += " " + classNames[c];							}						}						elem.className = jQuery.trim( setClass );					}				}			}		}		return this;	},	removeClass: function( value ) {		if ( jQuery.isFunction(value) ) {			return this.each(function(i) {				var self = jQuery(this);				self.removeClass( value.call(this, i, self.attr("class")) );			});		}		if ( (value && typeof value === "string") || value === undefined ) {			var classNames = (value || "").split(rspace);			for ( var i = 0, l = this.length; i < l; i++ ) {				var elem = this[i];				if ( elem.nodeType === 1 && elem.className ) {					if ( value ) {						var className = (" " + elem.className + " ").replace(rclass, " ");						for ( var c = 0, cl = classNames.length; c < cl; c++ ) {							className = className.replace(" " + classNames[c] + " ", " ");						}						elem.className = jQuery.trim( className );					} else {						elem.className = "";					}				}			}		}		return this;	},	toggleClass: function( value, stateVal ) {		var type = typeof value, isBool = typeof stateVal === "boolean";		if ( jQuery.isFunction( value ) ) {			return this.each(function(i) {				var self = jQuery(this);				self.toggleClass( value.call(this, i, self.attr("class"), stateVal), stateVal );			});		}		return this.each(function() {			if ( type === "string" ) {				// toggle individual class names				var className, i = 0, self = jQuery(this),					state = stateVal,					classNames = value.split( rspace );				while ( (className = classNames[ i++ ]) ) {					// check each className given, space seperated list					state = isBool ? state : !self.hasClass( className );					self[ state ? "addClass" : "removeClass" ]( className );				}			} else if ( type === "undefined" || type === "boolean" ) {				if ( this.className ) {					// store className if set					jQuery.data( this, "__className__", this.className );				}				// toggle whole className				this.className = this.className || value === false ? "" : jQuery.data( this, "__className__" ) || "";			}		});	},	hasClass: function( selector ) {		var className = " " + selector + " ";		for ( var i = 0, l = this.length; i < l; i++ ) {			if ( (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) > -1 ) {				return true;			}		}		return false;	},	val: function( value ) {		if ( value === undefined ) {			var elem = this[0];			if ( elem ) {				if ( jQuery.nodeName( elem, "option" ) ) {					return (elem.attributes.value || {}).specified ? elem.value : elem.text;				}				// We need to handle select boxes special				if ( jQuery.nodeName( elem, "select" ) ) {					var index = elem.selectedIndex,						values = [],						options = elem.options,						one = elem.type === "select-one";					// Nothing was selected					if ( index < 0 ) {						return null;					}					// Loop through all the selected options					for ( var i = one ? index : 0, max = one ? index + 1 : options.length; i < max; i++ ) {						var option = options[ i ];						if ( option.selected ) {							// Get the specifc value for the option							value = jQuery(option).val();							// We don't need an array for one selects							if ( one ) {								return value;							}							// Multi-Selects return an array							values.push( value );						}					}					return values;				}				// Handle the case where in Webkit "" is returned instead of "on" if a value isn't specified				if ( rradiocheck.test( elem.type ) && !jQuery.support.checkOn ) {					return elem.getAttribute("value") === null ? "on" : elem.value;				}								// Everything else, we just grab the value				return (elem.value || "").replace(rreturn, "");			}			return undefined;		}		var isFunction = jQuery.isFunction(value);		return this.each(function(i) {			var self = jQuery(this), val = value;			if ( this.nodeType !== 1 ) {				return;			}			if ( isFunction ) {				val = value.call(this, i, self.val());			}			// Typecast each time if the value is a Function and the appended			// value is therefore different each time.			if ( typeof val === "number" ) {				val += "";			}			if ( jQuery.isArray(val) && rradiocheck.test( this.type ) ) {				this.checked = jQuery.inArray( self.val(), val ) >= 0;			} else if ( jQuery.nodeName( this, "select" ) ) {				var values = jQuery.makeArray(val);				jQuery( "option", this ).each(function() {					this.selected = jQuery.inArray( jQuery(this).val(), values ) >= 0;				});				if ( !values.length ) {					this.selectedIndex = -1;				}			} else {				this.value = val;			}		});	}});jQuery.extend({	attrFn: {		val: true,		css: true,		html: true,		text: true,		data: true,		width: true,		height: true,		offset: true	},			attr: function( elem, name, value, pass ) {		// don't set attributes on text and comment nodes		if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 ) {			return undefined;		}		if ( pass && name in jQuery.attrFn ) {			return jQuery(elem)[name](value);		}		var notxml = elem.nodeType !== 1 || !jQuery.isXMLDoc( elem ),			// Whether we are setting (or getting)			set = value !== undefined;		// Try to normalize/fix the name		name = notxml && jQuery.props[ name ] || name;		// Only do all the following if this is a node (faster for style)		if ( elem.nodeType === 1 ) {			// These attributes require special treatment			var special = rspecialurl.test( name );			// Safari mis-reports the default selected property of an option			// Accessing the parent's selectedIndex property fixes it			if ( name === "selected" && !jQuery.support.optSelected ) {				var parent = elem.parentNode;				if ( parent ) {					parent.selectedIndex;						// Make sure that it also works with optgroups, see #5701					if ( parent.parentNode ) {						parent.parentNode.selectedIndex;					}				}			}			// If applicable, access the attribute via the DOM 0 way			if ( name in elem && notxml && !special ) {				if ( set ) {					// We can't allow the type property to be changed (since it causes problems in IE)					if ( name === "type" && rtype.test( elem.nodeName ) && elem.parentNode ) {						jQuery.error( "type property can't be changed" );					}					elem[ name ] = value;				}				// browsers index elements by id/name on forms, give priority to attributes.				if ( jQuery.nodeName( elem, "form" ) && elem.getAttributeNode(name) ) {					return elem.getAttributeNode( name ).nodeValue;				}				// elem.tabIndex doesn't always return the correct value when it hasn't been explicitly set				// http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/				if ( name === "tabIndex" ) {					var attributeNode = elem.getAttributeNode( "tabIndex" );					return attributeNode && attributeNode.specified ?						attributeNode.value :						rfocusable.test( elem.nodeName ) || rclickable.test( elem.nodeName ) && elem.href ?							0 :							undefined;				}				return elem[ name ];			}			if ( !jQuery.support.style && notxml && name === "style" ) {				if ( set ) {					elem.style.cssText = "" + value;				}				return elem.style.cssText;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性一二三区| 蜜桃久久av一区| 亚洲精品在线观看网站| 成人黄色免费短视频| 亚洲一区二区三区四区的| www国产精品av| 欧美日免费三级在线| 国产aⅴ综合色| 秋霞影院一区二区| 亚洲精品亚洲人成人网| 国产欧美日韩在线看| 宅男在线国产精品| 91官网在线免费观看| 成人免费毛片aaaaa**| 另类小说欧美激情| 午夜精彩视频在线观看不卡| 国产精品久久久久久久蜜臀 | 久久成人av少妇免费| 亚洲精品乱码久久久久久久久 | 国产99一区视频免费| 日一区二区三区| 一区二区三区毛片| 自拍偷自拍亚洲精品播放| 久久蜜桃香蕉精品一区二区三区| 欧美一区二区三区免费在线看 | 亚洲日本一区二区三区| 精品国产麻豆免费人成网站| 91精品国产综合久久精品app| 在线免费一区三区| 91小视频免费看| 99视频精品免费视频| 国产91精品一区二区| 国产精品一区2区| 国产自产高清不卡| 国模娜娜一区二区三区| 老司机精品视频导航| 麻豆91精品91久久久的内涵| 秋霞影院一区二区| 麻豆精品久久精品色综合| 三级一区在线视频先锋 | 日韩高清欧美激情| 日韩电影免费在线看| 日韩精品亚洲一区| 蜜桃视频免费观看一区| 日韩av一区二区三区| 蜜臀va亚洲va欧美va天堂| 亚洲人成在线播放网站岛国| 欧美日韩电影一区| 成人av免费在线播放| 久久精品国产77777蜜臀| 日韩电影免费在线看| 久久99在线观看| 国产精品中文有码| 国产福利一区在线| 97精品国产露脸对白| 91精品1区2区| 欧美妇女性影城| 欧美成人一区二区| 国产视频一区二区三区在线观看| 国产日韩欧美a| 亚洲视频免费观看| 亚洲1区2区3区视频| 麻豆国产一区二区| 国产大片一区二区| 色综合婷婷久久| 欧美日韩午夜精品| 精品噜噜噜噜久久久久久久久试看 | 成人国产一区二区三区精品| 99视频热这里只有精品免费| 欧美日韩国产电影| 日韩欧美一区二区不卡| 久久精品人人做| 亚洲精品久久久蜜桃| 日韩影院精彩在线| 成人午夜免费视频| 欧美日韩中字一区| www成人在线观看| 一区二区在线电影| 麻豆成人免费电影| 91免费精品国自产拍在线不卡| 欧美美女一区二区在线观看| 国产日产欧美一区二区视频| 亚洲综合色自拍一区| 国产一区在线看| 欧美自拍偷拍午夜视频| 精品久久人人做人人爰| 亚洲精品乱码久久久久久黑人 | 另类成人小视频在线| 丁香亚洲综合激情啪啪综合| 欧美三级欧美一级| 欧美韩国一区二区| 男人操女人的视频在线观看欧美 | 成人黄色一级视频| 午夜影院久久久| 高清久久久久久| 欧美另类一区二区三区| 亚洲午夜久久久久久久久久久| 男男视频亚洲欧美| 一本色道久久综合亚洲精品按摩| 日韩精品一区二区三区四区视频| 1024国产精品| 国产美女在线观看一区| 欧美日韩在线精品一区二区三区激情| 久久久久久久久久久电影| 日韩1区2区3区| 色婷婷av一区二区三区大白胸 | 欧美肥胖老妇做爰| 自拍偷拍国产精品| 国产福利91精品一区二区三区| 欧美日韩一区二区欧美激情| 国产精品久久久久久福利一牛影视 | 欧美久久久久久久久| 国产精品区一区二区三区| 亚洲在线免费播放| 欧美性一级生活| 高清不卡一二三区| 国产成人8x视频一区二区| 91精品免费在线观看| 亚洲黄色小说网站| 99久久er热在这里只有精品66| 欧美成人a视频| 蜜臀精品一区二区三区在线观看| 欧美三级一区二区| 一区二区欧美在线观看| a级高清视频欧美日韩| 日本一区二区三区电影| 黑人精品欧美一区二区蜜桃| 欧美一区二区播放| 全部av―极品视觉盛宴亚洲| 欧美日韩精品一区视频| 亚洲狠狠爱一区二区三区| 色婷婷精品久久二区二区蜜臂av | 日韩一区中文字幕| 成人免费看黄yyy456| 欧美激情中文不卡| 成人小视频在线| 国产日韩精品视频一区| 国产精品原创巨作av| 久久奇米777| 国产99久久久久| 国产精品久久毛片a| www.亚洲精品| 亚洲免费看黄网站| 欧美三级视频在线播放| 亚洲国产精品久久一线不卡| 欧美日韩一区国产| 日韩电影一二三区| 久久久久亚洲蜜桃| av动漫一区二区| 一区二区三区四区中文字幕| 欧美丝袜第三区| 美国一区二区三区在线播放| 久久综合久久综合九色| 国产精品911| 亚洲区小说区图片区qvod| 欧美在线免费视屏| 毛片av一区二区| 国产欧美中文在线| 色噜噜狠狠成人中文综合| 亚洲国产日韩av| 日韩午夜在线观看| 国产毛片精品视频| 国产精品国产成人国产三级| 成人av网站免费观看| 亚洲乱码日产精品bd| 91麻豆精品国产91久久久更新时间 | 在线观看中文字幕不卡| 日本在线不卡一区| 欧美va亚洲va香蕉在线| 国产精品18久久久久久久久| 欧美性淫爽ww久久久久无| 久久国产人妖系列| 欧美激情艳妇裸体舞| 91浏览器入口在线观看| 亚洲黄网站在线观看| 欧美酷刑日本凌虐凌虐| 免费人成网站在线观看欧美高清| 欧美成人乱码一区二区三区| av亚洲产国偷v产偷v自拍| 亚洲一卡二卡三卡四卡五卡| 欧美一级日韩免费不卡| 亚洲国产精品久久久男人的天堂| 日韩精品一区二区三区视频播放 | 国产电影一区二区三区| 最新国产精品久久精品| 欧美顶级少妇做爰| 成人国产精品免费观看视频| 亚洲成人黄色影院| 久久夜色精品一区| 色av综合在线| 国产一区二区精品久久99| 亚洲欧美偷拍三级| 日韩欧美一级特黄在线播放| 色综合亚洲欧洲| 国产在线视频一区二区三区| 亚洲桃色在线一区| 欧美日韩情趣电影| 91色九色蝌蚪| 精品一区二区久久| 亚洲影视在线播放|