<?xml version="1.0" encoding="gb2312"?>
<rss version="2.0">
	<channel>
		<title>金麦网络</title>
		<link>http://www.kingmx.com</link>
		<copyright>Copyright (C) 2006 金麦网络-Kingmx.com All Rights Reserved.</copyright>
		<item>
			<title>JS 正则 详解</title>
			<link>http://www.kingmx.com/article.php?id=16833</link>
			<pubDate>2007-5-12</pubDate>
			<description><![CDATA[正则表达式是regular expression，看来英文比中文要好理解多了，就是检查表达式符不符合规定。
正则表达式有一个功能十分强大而又十分复杂的对象RegExp，在javascript1.2 版本以上提供。
有关正则表达式的介绍：
正则表达式对象用来规范一个规范的表达式(也就是表达式符不符合特定的要求，比如是不是Email地址格式等)，它具有用来检查给出的字符串是否符合规则的属性和方法。
除此之外，你用RegExp构造器建立的个别正则表达式对象的属性，就已经预先定义好了正则表达式对象的静态属性，你可以随时使用它们。
核心对象：
在javascript 1.2, NES 3.0以上版本提供。
在javascript 1.3以后版本增加了toSource方法。
建立方法：
文字格式或RegExp构造器函数。
文字建立格式使用以下格式：
/pattern/flags即/模式/标记
构造器函数方法使用方法如下：
new RegExp("pattern"[, "flags"])即new RegExp("模式"[,"标记"])
参数：
pattern(模式)
表示正则表达式的文本
flags(标记)
如果指定此项，flags可以是下面值之一：
g: global match(全定匹配)
i: ignore case(忽略大小写)
gi: both global match and ignore case(匹配所有可能的值，也忽略大小写)
注意：文本格式中的参数不要使用引号标记，而构造器函数的参数则要使用引号标记。所以下面的
表达式建立同样的正则表达式：
/ab+c/i
new RegExp("ab+c", "i")
描述：
当使用构造函数的时候，必须使用正常的字符串避开规则(在字符串中加入前导字符\ )是必须的。
例如，下面的两条语句是等价的：
re = new RegExp("\\w+")
re = /\w+/
下面的提供了在正则表达式中能够使用的完整对特殊字符的一个完整的列表和描述。
表1.3：正则表达式中的特殊字符：
字符\
意义：对于字符，通常表示按字面意义，指出接着的字符为特殊字符，\不作解释。
例如：/b/匹配字符'b',通过在b 前面加一个反斜杠\，也就是/\b/，则该字符变成特殊字符，表示
匹配一个单词的分界线。
或者： 
对于几个字符，通常说明是特殊的，指出紧接着的字符不是特殊的，而应该按字面解释。
例如：*是一个特殊字符，匹配任意个字符(包括0个字符)；例如：/a*/意味匹配0个或多个a。
为了匹配字面上的*，在a前面加一个反斜杠；例如：/a\*/匹配'a*'。
字符^
意义：表示匹配的字符必须在最前边。
例如：/^A/不匹配"an A,"中的'A'，但匹配"An A."中最前面的'A'。
字符$
意义：与^类似，匹配最末的字符。
例如：/t$/不匹配"eater"中的't'，但匹配"eat"中的't'。
字符*
意义：匹配*前面的字符0次或n次。
例如:/bo*/匹配"A ghost booooed"中的'boooo'或"A bird warbled"中的'b'，但不匹配"A goat g
runted"中的任何字符。
字符+
意义：匹配+号前面的字符1次或n次。等价于{1,}。
例如：/a+/匹配"candy"中的'a'和"caaaaaaandy."中的所有'a'。
字符?
意义：匹配?前面的字符0次或1次。
例如：/e?le?/匹配"angel"中的'el'和"angle."中的'le'。
字符.
意义：(小数点)匹配除换行符外的所有单个的字符。
例如：/.n/匹配"nay, an apple is on the tree"中的'an'和'on'，但不匹配'nay'。
字符(x)
意义：匹配'x'并记录匹配的值。
例如：/(foo)/匹配和记录"foo bar."中的'foo'。匹配子串能被结果数组中的素[1], ..., [n] 返
回，或被RegExp对象的属性$1, ..., $9返回。
字符x|y
意义：匹配'x'或者'y'。
例如：/green|red/匹配"green apple"中的'green'和"red apple."中的'red'。
字符{n}
意义：这里的n是一个正整数。匹配前面的n个字符。
例如：/a{2}/不匹配"candy,"中的'a'，但匹配"caandy," 中的所有'a'和"caaandy."中前面的两个
'a'。
字符{n,}
意义：这里的n是一个正整数。匹配至少n个前面的字符。
例如：/a{2,}不匹配"candy"中的'a'，但匹配"caandy"中的所有'a'和"caaaaaaandy."中的所有'a'
字符{n,m}
意义：这里的n和m都是正整数。匹配至少n个最多m个前面的字符。
例如：/a{1,3}/不匹配"cndy"中的任何字符，但匹配 "candy,"中的'a'，"caandy," 中的前面两个
'a'和"caaaaaaandy"中前面的三个'a'，注意：即使"caaaaaaandy" 中有很多个'a'，但只匹配前面的三
个'a'即"aaa"。
字符[xyz]
意义：一字符列表，匹配列出中的任一字符。你可以通过连字符-指出一个字符范围。
例如：[abcd]跟[a-c]一样。它们匹配"brisket"中的'b'和"ache"中的'c'。
字符[^xyz]
意义：一字符补集，也就是说，它匹配除了列出的字符外的所有东西。 你可以使用连字符-指出一
字符范围。
例如：[^abc]和[^a-c]等价，它们最早匹配"brisket"中的'r'和"chop."中的'h'。
字符[\b]
意义：匹配一个空格(不要与\b混淆)
字符\b
意义：匹配一个单词的分界线，比如一个空格(不要与[\b]混淆)
例如：/\bn\w/匹配"noonday"中的'no'，/\wy\b/匹配"possibly yesterday."中的'ly'。
字符\B
意义：匹配一个单词的非分界线
例如：/\w\Bn/匹配"noonday"中的'on'，/y\B\w/匹配"possibly yesterday."中的'ye'。
字符\cX
意义：这里的X是一个控制字符。匹配一个字符串的控制字符。
例如：/\cM/匹配一个字符串中的control-M。
字符\d
意义：匹配一个数字，等价于[0-9]。
例如：/\d/或/[0-9]/匹配"B2 is the suite number."中的'2'。
字符\D
意义：匹配任何的非数字，等价于[^0-9]。
例如：/\D/或/[^0-9]/匹配"B2 is the suite number."中的'B'。
字符\f
意义：匹配一个表单符
字符\n
意义：匹配一个换行符
字符\r
意义：匹配一个回车符
字符\s
意义：匹配一个单个white空格符，包括空格，tab，form feed，换行符，等价于[ \f\n\r\t\v]。
例如：/\s\w*/匹配"foo bar."中的' bar'。
字符\S
意义：匹配除white空格符以外的一个单个的字符，等价于[^ \f\n\r\t\v]。
例如：/\S/\w*匹配"foo bar."中的'foo'。
字符\t
意义：匹配一个制表符
字符\v
意义：匹配一个顶头制表符
字符\w
意义：匹配所有的数字和字母以及下划线，等价于[A-Za-z0-9_]。
例如：/\w/匹配"apple,"中的'a'，"$5.28,"中的'5'和"3D."中的'3'。
字符\W 
意义：匹配除数字、字母外及下划线外的其它字符，等价于[^A-Za-z0-9_]。
例如：/\W/或者/[^$A-Za-z0-9_]/匹配"50%."中的'%'。
字符\n
意义：这里的n是一个正整数。匹配一个正则表达式的最后一个子串的n的值(计数左圆括号)。
例如：/apple(,)\sorange\1/匹配"apple, orange, cherry, peach."中的'apple, orange'，下面
有一个更加完整的例子。
注意：如果左圆括号中的数字比\n指定的数字还小，则\n取下一行的八进制escape作为描述。
字符\ooctal和\xhex
意义：这里的\ooctal是一个八进制的escape值，而\xhex是一个十六进制的escape值，允许在一个
正则表达式中嵌入ASCII码。
当表达式被检查的时候，文字符号提供了编辑正则表达式的方法。利用文字符号可以使到正则表达式保持为常数。
例如，如果你在一个循环中使用文字符号来构造一个正则表达式，正则表达式不需进行反复编译。
正则表达式对象构造器，例如，new RegExp("ab+c")，提供正则表达式的运行时编译。当你知道正则表达式的模式会变化的时候，应该使用构造函数，或者你不知道正则表达式的模式，而它们是从另外的源获得的时候，比如由用户输入时。一旦你定义好了正则表达式，该正则表达式可在任何地方使用，并且可以改变，你可以使用编译方法来编译一个新的正则表达式以便重新使用。
一个分离预先定义的RegExp对象可以在每个窗口中使用；也就是说，每个分离的javascript线程运行以获得自己的RegExp对象。因为每个脚本在一个线程中是不可中断的，这就确保了不同的脚本不会覆盖RegExp对象的值。
预定义的RegExp对象包含的静态属性：input, multiline, lastMatch,lastParen, leftContext, rightContext, 以及从$1到$9。
input和multiline属性能被预设。其它静态属性的值是在执行个别正则表达式对象的exec和test方法后，且在执行字符串的match和replace方法后设置的。
属性
注意RegExp对象的几个属性既有长名字又有短名字(象Perl)。这些名字都是指向相同的值。Perl是一种编程语言，而javascript模仿了它的正则表达式。
属性$1, ..., $9
取得匹配的子串，如果有的话
属性$_
参考input
属性$*
参考multiline
属性$&amp;
参考lastMatch
属性$+
参考lastParen
属性$`
参考leftContext
属性$'
参考rightContext
属性constructor
指定用来建立对象原型函
属性global
决定是否测试正则表达式是否不能匹配所有的字符串，或者只是与最先的冲突。
属性ignoreCase
决定试图匹配字符串的时候是否忽略大小写
属性input
当正则表达式被匹配的时候，为相反的字符串。
属性lastIndex
决定下一次匹配从那里开始
属性lastMatch
最后一个匹配的字符
属性lastParen
子串匹配的时候，最后一个parenthesized，如果有的话。
属性leftContext
最近一次匹配前的子串。
属性multiline
是否在串的多行中搜索。
属性prototype
允许附加属性到所有的对象
属性rightContext
最近一次匹配后的的子串。
属性source
模式文本
方法
compile方法
编译一个正则表达式对象
exec方法
运行正则表达式匹配
test方法
测试正则达式匹配
toSource方法
返回一个对象的文字描述指定的对象；你可以使用这个值来建立一个新的对象。不考虑Object.toS
ource方法。
toString方法
返回一个字符串描述指定的对象，不考虑Object.toString对象。
valueOf方法
返回指定对角的原始值。不考虑Object.valueOf方法。
另外，这个对象继承了对象的watch和unwatch方法
例子
例1、下述示例脚本使用replace方法来转换串中的单词。在替换的文本中，脚本使用全局 RegExp对象的$1和$2属性的值。注意，在作为第二个参数传递给replace方法的时候，RegExp对象的$属性的名称。
&lt;SCRIPT LANGUAGE="javascript1.2"&gt;
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr=str.replace(re,"$2, $1");
document.write(newstr)
&lt;/SCRIPT&gt;
显示结果："Smith, John". 
例2、下述示例脚本中，RegExp.input由Change事件处理句柄设置。在getInfo函数中，exec 方法使用RegExp.input的值作为它的参数，注意RegExp预置了$属性。
&lt;SCRIPT LANGUAGE="javascript1.2"&gt;
function getInfo(abc)
{
re = /(\w+)\s(\d+)/;
re.exec(abc.value);
window.alert(RegExp.$1 + ", your age is " + RegExp.$2);
}
&lt;/SCRIPT&gt;
请输入你的姓和年龄，输入完后按回车键。
&lt;FORM&gt;&lt;INPUT TYPE="TEXT" NAME="NameAge" onChange="getInfo(this);"&gt;&lt;/FORM&gt;
&lt;/HTML&gt;
$1, ..., $9属性
用圆括号括着的匹配子串，如果有的话。
是RegExp的属性静态，只读
在javascript 1.2, NES 3.0以上版本提供
描述：因为input是静态属性，不是个别正则表达式对象的属性。你可以使用RegExp.input 访问该属性。
能加上圆括号的子串的数量不受限制，但正则表达式对象只能保留最后9 条。如果你要访问所有的圆括号内的匹配字串，你可以使用返回的数组。
这些属性能用在RegExp.replace方法替换后的字符串(输出结果)。当使用这种方式的时候，不用预先考虑RegExp对象。下面给出例子。当正则表达式中没有包含圆括号的时候，该脚本解释成$n的字面意义。(这里的n是一个正整数)。
例如
下例脚本使用replace 方法来交换串中单词的位置。在替换后的文本字串中，脚本使用正则表达式RegExp对象的$1和$2属性的值。注意：当它们向replace方法传递参数的时候，这里没有考虑 $ 属性的RegExp对象的名称。
&lt;SCRIPT LANGUAGE="javascript1.2"&gt;
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr=str.replace(re,"$2, $1");
document.write(newstr)
&lt;/SCRIPT&gt;
显示的输出结果为：Smith, John ]]></description>
		</item>
		<item>
			<title>解决Javascript由于编码不同造成乱码的问题</title>
			<link>http://www.kingmx.com/article.php?id=15247</link>
			<pubDate>2007-4-27</pubDate>
			<description><![CDATA[

&nbsp;在asp.net中时常需要调用js代码，如果js写在asp.net中，一般是不会出现乱码的问题。因为他们具有相同的编码。
如果需要引用外部的javascript代码就会有乱码的风险了。一般情况下Asp.net和Javascript的页面编码不是GB2312就是Utf-8 ，如果两者的编码不一致就会产生乱码。解决方法就是想两者的编码进行统一。

由于一般情况下Asp.net接受发送请求的编码是Utf-8的，javascript编码默认是Gb2312，故容易出现问题。

在Asp.net中可以在两个地方设置接受发送编码&nbsp;&nbsp;
&nbsp;1.Web.config中加入 

&lt;system.web&gt;
&nbsp;&nbsp;&nbsp;&nbsp;&lt;globalization&nbsp;requestEncoding="utf-8"&nbsp;responseEncoding="utf-8"&nbsp;/&gt;
&lt;/system.web&gt;

2.Aspx页面文件中加入

&nbsp;&lt;%@&nbsp;Page&nbsp;ContentType="text/html"&nbsp;ResponseEncoding="utf-8"&nbsp;%&gt;

在Javascript中的解决方法
1.将js的文件进行另存为指定编码，比如从ANSI转换为UTF-8。

2.在引用asp.net生成的js语句时 添加charset属性

&lt;script&nbsp;src='http://localhost/VARSHOP/ShopWelcome.aspx?code=48090001'&nbsp;language='JavaScript'&nbsp;charset='utf-8'&gt;&lt;/script&gt;

若还没有解决，还有个重要的原因就是浏览器缓存问题，需要清除浏览器的缓存。浏览器在载入最新的文件后，乱码就会消失了。
]]></description>
		</item>
		<item>
			<title>TextBox只能输入数字的最简洁方法</title>
			<link>http://www.kingmx.com/article.php?id=15244</link>
			<pubDate>2007-4-27</pubDate>
			<description><![CDATA[如下TextBox
&lt;asp:textbox&nbsp;onkeypress="isnum()"&nbsp;id="TextBox1"&nbsp;runat="server"&gt;&lt;/asp:textbox&gt;
1. 在页面中添加一段脚本：


&lt;script&nbsp;language="javascript"&gt;
&nbsp;&nbsp;&nbsp;&nbsp;function&nbsp;isnum()
&nbsp;&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if(event.keyCode&lt;45&nbsp;||&nbsp;event.keyCode&gt;57)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;event.keyCode=0;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&lt;/script&gt;
2. 在代码中添加：
try
{
&nbsp;&nbsp;&nbsp;&nbsp;Convert.ToDouble(TextBox1.Text.Trim());
}
catch
{
&nbsp;&nbsp;&nbsp;&nbsp;Response.Write("&lt;script&gt;alert('请输入正确的数字格式！');&lt;/script&gt;");
&nbsp;&nbsp;&nbsp;&nbsp;TextBox1.Text="";
&nbsp;&nbsp;&nbsp;&nbsp;Page.RegisterStartupScript("focus","&lt;script&gt;document.forms[0]['TextBox1'].focus();&lt;/script&gt;");
}
就ok了]]></description>
		</item>
		<item>
			<title>高亮闪烁某个元素</title>
			<link>http://www.kingmx.com/article.php?id=15232</link>
			<pubDate>2007-4-25</pubDate>
			<description><![CDATA[页面上有些重要内容需要提醒客户，可采用的方法有很多。提醒用户关注某一区域(div)，可以给该div加上边框闪烁的效果，达到吸引用户眼球的效果。


 HTML代码

&lt;script language="javascript" type="text/javascript"&gt;
&lt;!--
/*常用函数库---开始---*/
function $(objString){
	return document.getElementById(objString);
}
function addClass(elem,classString){
	if(typeof(elem)=="string")
	var obj = document.getElementById(elem);
	else if(typeof(elem)=="object")
	var obj = elem;

	obj.className = obj.className + " "+classString;
}
function removeClass(elem,classString){
	if(typeof(elem)=="string")
	var obj = document.getElementById(elem);
	else if(typeof(elem)=="object")
	var obj = elem;

	var classNameArray = obj.className.split(" ");
	for (i=0; j=classNameArray[i] ; i++){
	if(j==classString){
	classNameArray.splice(i,1);
	i--;
	}
	}
	obj.className = classNameArray.join(" ");
}
function hasClass(elem,classString){
	if (typeof(elem)=="string"){
	var obj = document.getElementById(elem);
	}else if(typeof(elem)=="object"){
	var obj = elem;
	}
	if (obj.className.indexOf(" ")!=-1){
	var cls = obj.className.replace(/ /g,"|");
	cls = "|"+cls+"|";
	if (cls.indexOf("|"+classString+"|")!=-1){
	return true;
	}else{return false}
	}else{
	if (obj.className == classString){
	return true;
	}else{
	return false;
	}
	}
}
/*常用函数库---结束---*/
function highLight(obj){
	if (obj.highlightHandel!=null)
	return;
	obj.highlightHandel = setInterval(function(){twinkle(obj)},250);
}
function twinkle(objBox){
	hasClass(objBox,"highLight")?removeClass(objBox,"highLight"):addClass(objBox,"highLight");
}
function stopTwinkle(obj){
	clearInterval(obj.highlightHandel);
	removeClass(obj,"highLight");
	obj.removeAttribute("highlightHandel");
}
//--&gt;
&lt;/script&gt;

&lt;style&gt;
.box {border:1px solid #ccc; height:100px; width:600px; text-align:center; line-height:100px; background-color:#f7f7f7}
.highLight {background-color:#ffffcc; border:1px solid #f30}
&lt;/style&gt;

&lt;div id="demo" class="box"&gt;
Box I
&lt;/div&gt;
&lt;br&gt;
&lt;input type="button" value="闪烁" onclick="highLight($('demo'))" /&gt;
&lt;input type="button" value="停止" onclick="stopTwinkle($('demo'))" /&gt;
&lt;br&gt;
&lt;br&gt;
&lt;div id="demo2" class="box"&gt;
Box II
&lt;/div&gt;
&lt;br&gt;
&lt;input type="button" value="闪烁" onclick="highLight($('demo2'))" /&gt;

&lt;input type="button" value="停止" onclick="stopTwinkle($('demo2'))" /&gt;   150){document.getElementById('temp34895').style.height=(parseInt(document.getElementById('temp34895').style.height)-150).toString()+'px'}" type=button value=↑>  &nbsp;&nbsp;代码长度:86行,2255个字符(其中2074个非空字符)

 
[Ctrl+A 全部选择 提示：你可先修改部分代码，再按运行]
代码里包含有几个常用函数(已用注释分割开)，可用&nbsp;prototype.js&nbsp;中的方法替换，下面的几个函数略作修改也可运行。]]></description>
		</item>
		<item>
			<title>探析JavaScript中令人困惑的变量赋值</title>
			<link>http://www.kingmx.com/article.php?id=15230</link>
			<pubDate>2007-4-25</pubDate>
			<description><![CDATA[Javascript是一门弱类型的语言，声明变量不需要声明其类型，var&nbsp;x&nbsp;就可以等于任何类型的值。
比如：


 程序代码

var&nbsp;str&nbsp;=&nbsp;"string....";
var&nbsp;arr&nbsp;=&nbsp;["this","is","array"];
var&nbsp;obj&nbsp;=&nbsp;{name:"caizhongqi",age:26,sex:"male"};
这些都是正确的，这似乎非常简单方便，但是这种方便也会带来一些令人难于捉摸的意外，看看下面的例子（例1）：


 HTML代码

&lt;script&gt;	var x = "this is string";
	var y = x;
	x="ni hao";
	alert(y)
&lt;/script&gt;   150){document.getElementById('temp24677').style.height=(parseInt(document.getElementById('temp24677').style.height)-150).toString()+'px'}" type=button value=↑>  &nbsp;&nbsp;代码长度:5行,83个字符(其中69个非空字符)

 
[Ctrl+A 全部选择 提示：你可先修改部分代码，再按运行]
你可能一下子知道alert出来的就是“this&nbsp;is&nbsp;string”，没错，但对于用Java语言的程序员来说，var&nbsp;y=x&nbsp;应该是把x在存储器中的地址（指针）赋给y变量才对，因此他们觉得应该alert出“ni&nbsp;hao”才会更符合Java语言的习惯，但JavaScript语言不是这样，字符串的赋值是直接量操作，直接把数据copy给y的存储空间。
再看看下面的例子（例2）：


 HTML代码

&lt;script&gt;
var x = ["hello"]  // 这是一个数组，只有一个元素，并且该元素为字符串类型
var y = x;
x[0] = "world";
alert(y[0]);
&lt;/script&gt;   150){document.getElementById('temp51380').style.height=(parseInt(document.getElementById('temp51380').style.height)-150).toString()+'px'}" type=button value=↑>  &nbsp;&nbsp;代码长度:6行,111个字符(其中96个非空字符)

 
[Ctrl+A 全部选择 提示：你可先修改部分代码，再按运行]
如果你还以为alert出来的是“hello”，那就错了。当&nbsp;var&nbsp;y&nbsp;=&nbsp;x&nbsp;时，x不是已经把它的数组给了y吗？但事实上却不是这样，&nbsp;当&nbsp;var&nbsp;y&nbsp;=&nbsp;x&nbsp;时，x传的是它在存储器中的地址（指针）！x[0]="world"&nbsp;修改了在原存储位置上的数据，因此alert(y[0])就是拿x的新值出来alert。混乱了吧？怎么一会儿是直接量一会儿是引用量呢？
不急，下面的例子将更加混乱（例3）：


 HTML代码

&lt;script&gt;
var x = ["hello"]  // 这是一个数组，只有一个元素，并且该元素为字符串类型
var y = x;
x = ["ni","hao"];  // x 将变成一个新的数组了。
alert(y[0]);
&lt;/script&gt;   150){document.getElementById('temp71270').style.height=(parseInt(document.getElementById('temp71270').style.height)-150).toString()+'px'}" type=button value=↑>  &nbsp;&nbsp;代码长度:6行,131个字符(其中113个非空字符)

 
[Ctrl+A 全部选择 提示：你可先修改部分代码，再按运行]
你的眼睛告诉你，alert出来的是“hello”！这让人捉摸不透古灵精怪的JavaScript！
[page]
周星驰的《国产零零漆》中有类似的一幕：
当星爷刚从深圳到香港执行任务时，袁咏仪从他的行李中发现一个吹头发的风筒，星爷说这其实是个须刨，把皮鞋拿出来一看却是一个风筒，一个貌似大哥大电话的玩意其实又是一个须刨。须刨与风筒把袁咏仪与观众都搞混乱了，哈哈哈哈，这是我很喜欢的一部片，第一次看时肚子都笑痛了。
回过头来再看看刚才的变量赋值，直接量与引用量的使用，就好像须刨与风筒换来换去，把我们都搞晕了。
其实问题出在对x的第二次赋值&nbsp;x&nbsp;=&nbsp;["ni","hao"]&nbsp;上，我们看看变量在存储器上变化以及JavaScript在对待字符串类型与对象类型的不同：
我们观察下面两种情况：
var&nbsp;x&nbsp;=&nbsp;"this&nbsp;is&nbsp;string...";
var&nbsp;y&nbsp;=&nbsp;["this","is","string"];
x与y不同之处在于类型，javascript的解析器把字符串直接赋值（其实就是copy）给x（直接量），却把数组的指针赋给y（引用量），这一切都是瞬间全自动的！结合下面的图，可能会更好地理解：

图中p1、p2...就是变量的指针，上面的&nbsp;var&nbsp;y&nbsp;中的y存的就是Object类型变量的指针p1（假设），而x存放的就是字符串本身。再分析一下例3，执行&nbsp;var&nbsp;x&nbsp;=&nbsp;["hello"]&nbsp;时，解析器就在内存上开辟一块存储空间放这个数组，而&nbsp;x&nbsp;就拿到了这个空间的地址（指针），再执行&nbsp;x&nbsp;=&nbsp;["ni","hao"]&nbsp;时，解析器又新开辟一块存储空间放这个新数组，而x就是这个新存储空间的指针，这也就是说，JavaScript&nbsp;里变量的重定义（或重新赋值）将会新开辟一块存储空间，而没有销毁原来的空间；回过头来再看例2，x[0]&nbsp;=&nbsp;"world"，这句没有给x新定义值，没有新开辟存储空间，只是修改了它存储空间里面的数据，因此例2最后alert出来的就是“world”；例1是字符串赋值，全过程是直接量操作。
从上面的分析可以看出，JavaScript&nbsp;的变量可以存储直接量也可以存储指针，这是没办法被人工干扰的，因此，在日常的编码中，就需要注意这些问题，比如大字符串连接，循环里面赋值等细节就能直接影响到程序的执行效率。
看看两个例子：


 程序代码

var&nbsp;_tmpStr="";
var&nbsp;str&nbsp;=&nbsp;"this&nbsp;is&nbsp;big&nbsp;string...";
for&nbsp;(i=0;&nbsp;i&lt;100;&nbsp;i++){
&nbsp;&nbsp;&nbsp;&nbsp;_tmpStr&nbsp;+=&nbsp;a;
}
a&nbsp;=&nbsp;_tmpStr;
因为是字符串操作，使用直接量，每次循环都要操作大字符串，非常笨重，效率低下。如果改用引用量操作，即通过数组：


 程序代码

var&nbsp;str&nbsp;=&nbsp;"this&nbsp;is&nbsp;big&nbsp;string...";
var&nbsp;_tmpArray&nbsp;=&nbsp;[];
for&nbsp;(i=0;&nbsp;i&lt;100;&nbsp;i++){
&nbsp;&nbsp;&nbsp;&nbsp;_tmpArray[i]=str;
}
str&nbsp;=&nbsp;_tmpArray.join("");
做个测试，假如有个100k的字符串，用直接量连接操作，我的机器上需要约2600毫秒，如果用数组连接，则需要150毫秒，效率相差十几倍。
好久没写这么长的文章了，花了我大半天的时间。 ]]></description>
		</item>
		<item>
			<title>jquery使用手册(16)</title>
			<link>http://www.kingmx.com/article.php?id=15183</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
其它简化方式：

$.get(url, params, callback)&nbsp; 

用get方式向远程页面传递参数，请求完成后处理函数，除了url外，其它参数任意选择！

$.get( "ajax.htm" , function(data){ $("#a").html(data)&nbsp; })$.get(&nbsp;&nbsp; "ajax.asp", 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; { name: "young", age: "25" },
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; function(data){ alert("Data Loaded: " + data); }
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ) 
$.getIfModified(url, params, callback)&nbsp; 

用get方式向远程页面传递参数，从最后一次请求后如果数据有变化才作出响应，执行函数callback
$.getJSON(url, params, callback)&nbsp; 

用get方式向远程json对象传递参数，请求完成后处理函数callback。

$.getScript(url, callback)&nbsp; 

用get方式载入并运行一个远程javascript文件。请求完成后处理函数callback。

$.post(url, params, callback)&nbsp; 

用post方式向远程页面传递参数，请求完成后处理函数callback
load(url, params, callback)&nbsp; 

载入一个远程文件并载入页面DOM中，并执行函数callback 

$("#a").load("ajax.htm", function() { alert("load is done"); } );
向ajax.htm页面发出请求，将返回结果装入id为a的内容中，然后再执行函数callback。
loadIfModified(url, params, callback)&nbsp; 

用get方式向远程页面传递参数，从最后一次请求后如果数据有变化才作出响应，将返回结果载入页面DOM中，并执行函数callback

ajaxStart(callback) 

当ajax请求发生错误是时执行函数callback

ajaxComplete(callback)&nbsp; 

当ajax请求完成时执行函数callback

ajaxError(callback)&nbsp; 

当ajax请求发生错误时执行函数callback

ajaxStop(callback)&nbsp; 

当ajax请求停止时执行函数callback

ajaxSuccess(callback)&nbsp; 

当ajax请求成功时执行函数callback

&nbsp;&nbsp; 

八：jQuery插件

随着jQuery的广泛使用，已经出现了大量jQuery插件，如thickbox，iFX，jQuery-googleMap等，简单的引用这些源文件就可以方便的使用这些插件。这里我简单的介绍一些网址供大家参考，这些网站头提供了大量的demo，并且使用及其简单，及时E文不好，也能快速掌握！
&nbsp;&nbsp;&nbsp; http://jquery.com/plugins&nbsp;&nbsp;&nbsp;&nbsp; 官方推荐
&nbsp;&nbsp;&nbsp; http://interface.eyecon.ro/demos&nbsp;&nbsp;&nbsp; 效果超级棒，使用更简单，一定有你喜欢的！
&nbsp;&nbsp;&nbsp; http://www.dyve.net/jquery/
&nbsp;&nbsp;&nbsp; http://bassistance.de/jquery-plugins

&nbsp;&nbsp; 还有其它很多插件，大家可以google以下，如果大家发现好的了，可以留言共享以下！
]]></description>
		</item>
		<item>
			<title>jquery使用手册(15)</title>
			<link>http://www.kingmx.com/article.php?id=15182</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
jQuery提供的函数 
用于browers事件
error(fn)&nbsp;&nbsp;&nbsp; load(fn)&nbsp;&nbsp;&nbsp;&nbsp; unload(fn)&nbsp;&nbsp;&nbsp; resize(fn)&nbsp;&nbsp;&nbsp; scroll(fn)

用于form事件
change(fn)&nbsp;&nbsp;&nbsp; select(fn)&nbsp;&nbsp;&nbsp; submit(fn)

用于keyboard事件
keydown(fn)&nbsp;&nbsp;&nbsp; keypress(fn)&nbsp;&nbsp;&nbsp; keyup(fn)

用于mouse事件
click(fn)&nbsp;&nbsp;&nbsp; dblclick(fn)&nbsp;&nbsp;&nbsp; mousedown(fn)&nbsp;&nbsp; mousemove(fn)&nbsp; mouseout(fn)&nbsp; mouseover(fn)&nbsp;&nbsp;&nbsp;&nbsp; mouseup(fn)

用于UI事件
blur(fn)&nbsp;&nbsp;&nbsp; focus(fn)

以上事件的扩展再扩展为5类
举例，click(fn) 扩展 click()&nbsp; unclick()&nbsp; oneclick(fn)&nbsp; unclick(fn)
click(fn)：增加一个点击时触发某函数的事件
click()：可以在其他事件中执行匹配对象的click事件。
unclick ()：不执行匹配对象的click事件。
oneclick(fn)：只增加可以执行一次的click事件。
unclick (fn)：增加一个点击时不触发某函数的事件。
上面列举的用于browers、form、keyboard、mouse、UI的事件都可以按以上方法扩展。

七：Ajax支持

&nbsp;通用方式：

$.ajax(prop)&nbsp;&nbsp;&nbsp; 

通过一个ajax请求，回去远程数据，prop是一个hash表，它可以传递的key/value有以下几种。
(String)type：数据传递方式(get或post)。
((String)url：数据请求页面的url
((String)data：传递数据的参数字符串，只适合post方式
((String)dataType：期待数据返回的数据格式(例如 "xml", "html", "script",或 "json")
((Boolean)ifModified： 当最后一次请求的相应有变化是才成功返回，默认值是false
((Number)timeout:设置时间延迟请求的时间。可以参考$.ajaxTimeout
((Boolean)global：是否为当前请求触发ajax全局事件，默认为true
((Function)error：当请求失败时触发的函数。
((Function)success：当请求成功时触发函数
((Function)complete：当请求完成后出发函数
jQuery代码及说明

$.ajax({url: "ajax.htm",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; success:function(msg){ 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $(div"#a").html(msg);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; } 
&nbsp;&nbsp;&nbsp; });
将ajax.htm返回的内容作为id为a的div内容 

$.ajax({ url: "ajax.aspx",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; type:"get",&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; dataType:"html",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; data: "name=John&amp;location=Boston",
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; success:function(msg){ 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $("#a").html(msg);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; } 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; });
用get方式向ajax.aspx页面传参数，并将返回内容负给id为a的对象。

$.ajaxTimeout(time) 

设置请求结束时间

$.ajaxTimeout( 5000 )
]]></description>
		</item>
		<item>
			<title>jquery使用手册(14)</title>
			<link>http://www.kingmx.com/article.php?id=15181</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
六：事件处理

hover(Function, Function)&nbsp;&nbsp;&nbsp; 

当鼠标move over时触发第一个function，当鼠标move out时触发第二个function
样式：&lt;style&gt;.red{color:#FF0000}&lt;/style&gt;
Html代码： &lt;div id="a"&gt;sdf&lt;/div&gt;
jQuery代码及效果 

$(function(){
&nbsp; $("#a").hover(function(){$(this).addClass("red");},
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; function(){ $(this).removeClass("red"); 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; });
})
最终效果是当鼠标移到id为a的层上时图层增加一个red样式，离开层时移出red样式

toggle(Function, Function)&nbsp;&nbsp;&nbsp; 

当匹配元素第一次被点击时触发第一个函数，当第二次被点击时触发第二个函数
样式：&lt;style&gt;.red{color:#FF0000}&lt;/style&gt;
Html代码： &lt;div id="a"&gt;sdf&lt;/div&gt;
jQuery代码及效果 

$(function(){
&nbsp; $("#a"). toggle (function(){$(this).addClass("red");},
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; function(){ $(this).removeClass("red"); 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; });
})
最终效果是当鼠标点击id为a的层上时图层增加一个red样式，离开层时移出red样式

bind(type, fn)&nbsp;&nbsp; 

用户将一个事件和触发事件的方式绑定到匹配对象上。
trigger(type)&nbsp;&nbsp; 

用户触发type形式的事件。$("p").trigger("click")
还有：unbind()&nbsp;&nbsp; unbind(type)&nbsp;&nbsp;&nbsp; unbind(type, fn)

Dynamic event(Function)&nbsp;&nbsp;&nbsp; 

绑定和取消绑定提供函数的简捷方式
例： 

$("#a").bind("click",function() { 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $(this).addClass("red");
})
也可以这样写： 

$("#a").click(function() { 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $(this).addClass("red");
});
最终效果是当鼠标点击id为a的层上时图层增加一个red样式，
]]></description>
		</item>
		<item>
			<title>jquery使用手册(13)</title>
			<link>http://www.kingmx.com/article.php?id=15180</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
toggle()&nbsp;&nbsp;&nbsp; toggle(speed) 

如果当前匹配对象隐藏，则显示他们，如果当前是显示的，就隐藏，toggle(speed),其大小（长宽）和透明度都随之逐渐变化。 

&lt;img src="1.jpg" style="width:150px"/&gt;
&lt;a href="#" onClick='$("img").toggle("slow")'&gt;jQuery&lt;/a&gt;

fadeIn(speeds)&nbsp;&nbsp; fadeOut(speeds)&nbsp; 

根据速度调整透明度来显示或隐藏匹配对象，注意有别于hide(speed)和show(speed)，fadeIn和fadeOut都只调整透明度，不调整大小 

&lt;img src="1.jpg" style="display:none"/&gt;&lt;a href="#" onClick='$("img ").fadeIn("slow")'&gt; jQuery &lt;/a&gt;
点击连接后可以看到图片逐渐显示。

fadeIn(speed, callback)&nbsp; fadeOut(speed, callback)&nbsp;&nbsp; 

callback为函数，先通过调整透明度来显示或隐藏匹配对象，当调整结束后执行callback函数 

&lt;img src="1.jpg"/&gt;
&lt;a href="#" onClick='$("img ").fadeIn("slow",function(){ alert("Animation Done."); })'&gt; jQuery &lt;/a&gt;
点击连接后可以看到图片逐渐显示,显示完全后弹出对话框

fadeTo(speed, opacity, callback)&nbsp; 

将匹配对象以speed速度调整倒透明度opacity，然后执行函数callback。Opacity为最终显示的透明度(0-1). 

&lt;img src="1.jpg"/&gt;&lt;br&gt;
&lt;a href="#" onClick='$("img ").fadeTo("slow",0.55,function(){ alert("Animation Done."); })'&gt; jQuery &lt;/a&gt;
大家可以看一下自己看看效果，如果不用jQuery，编写原始javascript脚本可能很多代码！

slideDown(speeds)&nbsp; 

将匹配对象的高度由0以指定速率平滑的变化到正常！ 

&lt;img src="1.jpg" style="display:none"/&gt;
&lt;a href="#" onClick='$("img ").slideDown("slow")'&gt;jQuery&lt;/a&gt;

slideDown(speeds,callback)&nbsp; 

将匹配对象的高度由0变化到正常！变化结束后执行函数callback

slideUp("slow")&nbsp; slideUp(speed, callback) 

匹配对象的高度由正常变化到0

slideToggle("slow") 

如果匹配对象的高度正常则逐渐变化到0，若为0，则逐渐变化到正常
]]></description>
		</item>
		<item>
			<title>jquery使用手册(12)</title>
			<link>http://www.kingmx.com/article.php?id=15179</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
$.grep(array,fn)&nbsp; 

通过函数fn来过滤array，将array中的元素依次传给fn，fn必须返回一个boolen，如fn返回true，将被过滤 

$(function(){
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; var arr= $.grep( [0,1,2,3,4], function(i){ return i &gt; 2; });
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $.each(arr, function(i){ alert(i); });
})
我们可以看待执行$.grep后数组[0,1,2,3,4]变成[0，1]

$.merge(first, second)&nbsp; 

两个参数都是数组，排出第二个数组中与第一个相同的，再将两个数组合并 

$(function(){ 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; var arr = $.merge( [0,1,2], [2,3,4] )
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $.each(arr,&nbsp; function(i){ alert(i); });
})
可以看出arr的结果为[0,1,2,3,4]

$.trim(str)&nbsp; 

移出字符串两端的空格
&nbsp;&nbsp;&nbsp; $.trim("&nbsp;&nbsp; hello, how are you?&nbsp;&nbsp; ")的结果是"hello, how are you?"

五：动态效果

在将这部分之前我们先看个例子，相信做网页的朋友都遇到n级菜单的情景，但点击某菜单按钮时，如果它的子菜单是显示的，则隐藏子菜单，如果子菜单隐藏，则显示出来，传统的javascript做法是先用getElementById取出子菜单所在容器的id，在判断该容器的style.display是否等于none，如果等于则设为block,如果不等于这设为none，如果在将效果设置复杂一点，当点击按钮时，不是忽然隐藏和显示子菜单，而是高度平滑的转变，这时就要通过setTimeout来设置子菜单的height了，再复杂一点透明度也平滑的消失和显现，这时显现下来需要编写很多代码，如果js基础不好的朋友可能只能从别人写好的代码拿过来修改了！jQuery实现上面效果只需要1句话就行，$("#a").toggle("slow"),,学完jQuery后还需要抄袭修改别人的代码吗？下面我们逐个介绍jQuery用于效果处理的方法。

hide()&nbsp; 

隐藏匹配对象 

&lt;p id="a"&gt;Hello Again&lt;/p&gt;&lt;a href="#" onClick=’ ("#a").hide()’&gt;jQuery&lt;/a&gt;
当点击连接时,id为a的对象的display变为none。

show() 

显示匹配对象

hide(speed)&nbsp; 

以一定的速度隐藏匹配对象，其大小（长宽）和透明度都逐渐变化到0，speed有3级("slow", "normal",&nbsp; "fast")，也可以是自定义的速度。

show(speed)&nbsp; 

以一定的速度显示匹配对象，其大小（长宽）和透明度都由0逐渐变化到正常

hide(speed, callback)&nbsp; show(speed, callback) 

当显示和隐藏变化结束后执行函数callback
]]></description>
		</item>
		<item>
			<title>jquery使用手册(11)</title>
			<link>http://www.kingmx.com/article.php?id=15178</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
css(prop)&nbsp; 

prop是一个hash对象，用于设置大量的css样式
$("#b").css({ color: "red", background: "blue" });
最终效果是&lt;p id="b" style="background:blue; color:red"&gt;test&lt;/p&gt;,{ color: "red", background: "blue" }，hash对象，color为key，"red"为value，

css(key, value)&nbsp; 

用于设置一个单独得css样式
$("#b").css("color","red");最终效果是&lt;p id="b" style="color:red"&gt;test&lt;/p&gt;

四：JavaScript处理

$.browser()&nbsp; 

判断浏览器类型，返回boolen值 

$(function(){
&nbsp;&nbsp;&nbsp; if($.browser.msie) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert("这是一个IE浏览器");}
&nbsp;&nbsp;&nbsp; else if($.browser.opera) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert("这是一个opera浏览器");}
})
当页面载入式判断浏览器类型，可判断的类型有msie、mozilla、opera、safari

$.each(obj, fn)&nbsp; 

obj为对象或数组，fn为在obj上依次执行的函数，注意区分$().each() 

$.each( [0,1,2], function(i){ alert( "Item #" + i + ": " + this ); });

分别将0，1，2为参数，传入到function(i)中 

$.each({ name: "John", lang: "JS" },&nbsp; function(i){ alert( "Name: " + i + ", Value: " + this );

{ name: "John", lang: "JS" }为一个hash对象，依次将hash中每组对象传入到函数中

$.extend(obj, prop)&nbsp; 

用第二个对象扩展第一个对象 

var settings = { validate: false, limit: 5, name: "foo" };
var options = { validate: true, name: "bar" };
$.extend(settings, options);
执行后settings对象为{ validate: true, limit: 5, name: "bar" }
可以用下面函数来测试 

$(function(){
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; var settings = { validate: false, limit: 5, name: "foo" };
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; var options = { validate: true, name: "bar" };
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $.extend(settings, options);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $.each(settings,&nbsp; function(i){ alert( i + "=" + this ); });
})
]]></description>
		</item>
		<item>
			<title>jquery使用手册(10)</title>
			<link>http://www.kingmx.com/article.php?id=15177</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
removeAttr (name)&nbsp;&nbsp; 

将第一个匹配对象的某个属性移出 

&lt;img alt="test"/&gt;&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function js(){
&nbsp;&nbsp;&nbsp;&nbsp; $("img"). removeAttr("alt"); 
}
运行结果相当于&lt;img /&gt;

toggleClass (class)&nbsp;&nbsp; 

将当前对象添加一个样式，不是当前对象则移出此样式，返回的是处理后的对象 

&lt;p&gt;Hello&lt;/p&gt;&lt;p class="selected"&gt;Hello Again&lt;/p&gt;&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt;
$("p")的结果是返回对象 [&lt;p&gt;Hello&lt;/p&gt;,&lt;p class="selected"&gt;Hello Again&lt;/p&gt; ]
$("p").toggleClass("selected")的结果是实返回对象 [ &lt;p class="selected"&gt;Hello&lt;/p&gt;, &lt;p&gt;Hello Again&lt;/p&gt; ] 

三：CSS操作

传统javascript对css的操作相当繁琐，比如&lt;div id="a" style="background:blue"&gt;css&lt;/div&gt;取它的background语法是 document.getElementById("a").style.background，而jQuery对css更方便的操作，$("#a").background()，$("#a").background(“red”)
$("#a")得到jQuery对象[ &lt;div id="a" … /div&gt; ]
$("#a").background()将取出该对象的background样式。
$("#a").background(“red”)将该对象的background样式设为redjQuery提供了以下方法，来操作css
background ()&nbsp;&nbsp; background (val)&nbsp;&nbsp;&nbsp;&nbsp; color()&nbsp;&nbsp;&nbsp; color(val)&nbsp;&nbsp;&nbsp;&nbsp; css(name)&nbsp;&nbsp;&nbsp; css(prop)&nbsp;&nbsp;&nbsp;css(key, value)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; float()&nbsp;&nbsp; float(val)&nbsp;&nbsp; height()&nbsp;&nbsp; height(val)&nbsp; width()&nbsp; width(val)&nbsp; left()&nbsp;&nbsp; left(val)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; overflow()&nbsp;&nbsp; overflow(val)&nbsp;&nbsp; position()&nbsp;&nbsp; position(val)&nbsp; top()&nbsp;&nbsp; top(val)

这里需要讲解一下css(name)&nbsp; css(prop)&nbsp; css(key, value)，其他的看名字都知道什么作用了！ 

&lt;div id="a" style="background:blue; color:red"&gt;css&lt;/div&gt;&lt;P id="b"&gt;test&lt;/P&gt;

css(name)&nbsp; 

获取样式名为name的样式 
$("#a").css("color") 将得到样式中color值red，("#a").css("background ")将得到blue
]]></description>
		</item>
		<item>
			<title>jquery使用手册(9)</title>
			<link>http://www.kingmx.com/article.php?id=15176</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
prev ()&nbsp; prev (expr)&nbsp; 

参照next理解

not(el)&nbsp; not(expr)&nbsp; 

从jQuery对象中移出匹配的对象，el为dom元素，expr为jQuery表达式。 

&lt;p&gt;one&lt;/p&gt;&lt;p id="a"&gt;two&lt;/p&gt;
&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function js(){
&nbsp;&nbsp;&nbsp;&nbsp; alert($("p").not(document.getElementById("a")).html());
&nbsp;&nbsp;&nbsp;&nbsp; alert($("p").not(“#a”).html());
}
$("p")由两个对象，排除后的对象为[&lt;p&gt;one&lt;/p&gt; ]

siblings ()&nbsp; siblings (expr)&nbsp; jquery

匹配对象中其它兄弟级别的对象 

&lt;p&gt;one&lt;/p&gt;
&lt;div&gt;
&nbsp; &lt;p id="a"&gt;two&lt;/p&gt;
&lt;/div&gt;
&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function js(){
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert($("div").siblings().eq(1).html());
}
$("div").siblings()的结果实返回两个对象[&lt;p&gt;one&lt;/p&gt;，&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt; ]
alert($("div").siblings(“a”)返回一个对象[&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt; ]

[page]

其他
addClass(class)&nbsp;&nbsp; 

为匹配对象添加一个class样式
removeClass (class)&nbsp;&nbsp; 

将第一个匹配对象的某个class样式移出

attr (name)&nbsp;&nbsp; 

获取第一个匹配对象的属性 

&lt;img src="test.jpg"/&gt;&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt; 
jQuery代码及功能： 

function js(){
&nbsp;&nbsp;&nbsp;&nbsp; alert($("img").attr("src"));
}
返回test.jpg

attr (prop)&nbsp;&nbsp; 

为第一个匹配对象的设置属性，prop为hash对象，用于为某对象批量添加众多属性 

&lt;img/&gt;&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function js(){
&nbsp;&nbsp;&nbsp;&nbsp; $("img").attr({ src: "test.jpg", alt: "Test Image" }); 
}
运行结果相当于&lt;img src="test.jpg" alt="Test Image"/&gt;

attr (key,value)&nbsp;&nbsp; 

为第一个匹配对象的设置属性，key为属性名，value为属性值 

&lt;img/&gt;&lt;a href="#" onclick="js()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能 

function js(){
&nbsp;&nbsp;&nbsp;&nbsp; $("img").attr(“src”,”test.jpg”); 
}
运行结果相当于&lt;img src="test.jpg"/&gt;
]]></description>
		</item>
		<item>
			<title>jquery使用手册(8)</title>
			<link>http://www.kingmx.com/article.php?id=15175</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
contains(str)&nbsp; 

返回匹配对象中包含字符串str的对象 

&lt;p&gt;This is just a test.&lt;/p&gt;&lt;p&gt;So is this&lt;/p&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("p").contains("test").html());
}
$("p")得到两个对象，而包含字符串”test”只有一个。所有$("p").contains("test")返回 [ &lt;p&gt;This is just a test.&lt;/p&gt; ]

end() 

结束操作,返回到匹配元素清单上操作前的状态.

filter(expr)&nbsp;&nbsp; filter(exprs)&nbsp;&nbsp; 

过滤现实匹配符合表达式的对象 exprs为数组，注意添加“[ ]” 

&lt;p&gt;Hello&lt;/p&gt;&lt;p&gt;Hello Again&lt;/p&gt;&lt;p class="selected"&gt;And Again&lt;/p&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("p").filter(".selected").html())
}
$("p")得到三个对象，$("p").contains("test")只返回class为selected的对象。

find(expr)&nbsp; 

在匹配的对象中继续查找符合表达式的对象 

&lt;p&gt;Hello&lt;/p&gt;&lt;p id="a"&gt;Hello Again&lt;/p&gt;&lt;p class="selected"&gt;And Again&lt;/p&gt;
Query代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("p").find("#a").html())
}
在$("p")对象中查找id为a的对象。

is(expr)&nbsp; 

判断对象是否符合表达式,返回boolen值 

&lt;p&gt;Hello&lt;/p&gt;&lt;p id="a"&gt;Hello Again&lt;/p&gt;&lt;p class="selected"&gt;And Again&lt;/p&gt;
Query代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("#a").is("p"));
}
在$("#a ")是否符合jquery表达式。
大家可以用$("#a").is("div");&nbsp; ("#a").is("#a")多来测试一下

next()&nbsp; next(expr)&nbsp; 

返回匹配对象剩余的兄弟节点 

&lt;p&gt;Hello&lt;/p&gt;&lt;p id="a"&gt;Hello Again&lt;/p&gt;&lt;p class="selected"&gt;And Again&lt;/p&gt;
jQuery代码及功能 

function jq(){
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert($("p").next().html());
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert($("p").next(".selected").html());
}
$("p").next()返回 [ &lt;p id="a"&gt;Hello Again&lt;/p&gt; , &lt;p class="selected"&gt;And Again&lt;/p&gt; ]两个对象
$("p").next(".selected)只返回 [&lt;p class="selected"&gt;And Again&lt;/p&gt; ]一个对象
]]></description>
		</item>
		<item>
			<title>jquery使用手册(7)</title>
			<link>http://www.kingmx.com/article.php?id=15174</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
ancestors ()&nbsp; 

一依次以匹配结点的父节点的内容为对象,根节点除外（有点不好理解，看看下面例子就明白了） 

&lt;div&gt;
&nbsp;&nbsp;&nbsp; &lt;p&gt;one&lt;/p&gt;
&nbsp;&nbsp;&nbsp; &lt;span&gt;
&nbsp;&nbsp;&nbsp; &lt;u&gt;two&lt;/u&gt;
&nbsp;&nbsp;&nbsp; &lt;/span&gt;
&lt;/div&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp;&nbsp; var f= $("u").ancestors();
&nbsp;&nbsp;&nbsp;&nbsp; for(var i=0;i &lt; $(f).size();i++){
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert($(f).eq(i).html());}
}
第一个对象是以&lt;u&gt;的父节点的内容为对象，[ &lt;u&gt;two&lt;/u&gt; ]
第一个对象是以&lt;u&gt;的父节点的父节点（div）的内容为对象，[&lt;p&gt;one&lt;/p&gt;&lt;span&gt;&lt;u&gt;two&lt;/u&gt;&lt;/span&gt; ]
一般一个文档还有&lt;body&gt;和&lt;html&gt;，依次类推下去。

ancestors (expr)&nbsp; 

在ancestors（）的基础上之取符合表达式的对象
如上各例子讲var f改为var f= $("u").ancestors(“div”),则只返回一个对象：
[ &lt;p&gt;one&lt;/p&gt;&lt;span&gt;&lt;u&gt;two&lt;/u&gt;&lt;/span&gt;&nbsp; ]

[page]

children()&nbsp; 

返回匹配对象的子介点 

&lt;p&gt;one&lt;/p&gt;
&lt;div id="ch"&gt;&nbsp;&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp; &lt;span&gt;two&lt;/span&gt;
&lt;/div&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("#ch").children().html());
}
$("#ch").children()得到对象[ &lt;span&gt;two&lt;/span&gt; ].所以.html()的结果是”two”

children(expr)&nbsp; 

返回匹配对象的子介点中符合表达式的节点 

&lt;div id="ch"&gt;&nbsp;&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;span&gt;two&lt;/span&gt;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;span id="sp"&gt;three&lt;/span&gt;
&lt;/div&gt;
jQuery代码及功能 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("#ch").children(“#sp”).html());
}
$("#ch").children()得到对象[&lt;span&gt;two&lt;/span&gt;&lt;span id="sp"&gt;three&lt;/span&gt; ].
$("#ch").children(“#sp”)过滤得到[&lt;span id="sp"&gt;three&lt;/span&gt; ]

parent ()&nbsp; parent (expr)

取匹配对象父节点的。参照children帮助理解
]]></description>
		</item>
		<item>
			<title>jquery使用手册(6)</title>
			<link>http://www.kingmx.com/article.php?id=15173</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
wrap(htm) 

将匹配对象包含在给出的html代码内 

&lt;p&gt;Test Paragraph.&lt;/p&gt; &lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能：

function jq(){&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $("p").wrap("&lt;div class='wrap'&gt;&lt;/div&gt;"); 
}
执行后相当于

&lt;div class='wrap'&gt;&lt;p&gt;Test Paragraph.&lt;/p&gt;&lt;/div&gt;

wrap(elem) 

将匹配对象包含在给出的对象内 

&lt;p&gt;Test Paragraph.&lt;/p&gt;&lt;div id="content"&gt;&lt;/div&gt;
&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $("p").wrap( document.getElementById('content') );
}
执行后相当于 

&lt;div id="content"&gt;&lt;p&gt;Test Paragraph.&lt;/p&gt;&lt;/div&gt;

遍历、组合

add(expr)&nbsp; 

在原对象的基础上在附加符合指定表达式的jquery对象 

&lt;p&gt;Hello&lt;/p&gt;&lt;p&gt;&lt;span&gt;Hello Again&lt;/span&gt;&lt;/p&gt;
&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp;&nbsp; var f=$("p").add("span");&nbsp;&nbsp;&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp; for(var i=0;i &lt; $(f).size();i++){
&nbsp;&nbsp;&nbsp;&nbsp; alert($(f).eq(i).html());}
}
执行$("p")得到匹配&lt;p&gt;的对象，有两个，add("span")是在("p")的基础上加上匹配&lt;span &gt;的对象，所有一共有3个，从上面的函数运行结果可以看到$("p").add("span")是3个对象的集合，分别是[&lt;p&gt;Hello&lt;/p&gt;]，[&lt;p&gt;&lt;span&gt;Hello Again&lt;/span&gt;&lt;/p&gt;]，[&lt;span&gt;Hello Again&lt;/span&gt;]。

add(el)&nbsp; 

在匹配对象的基础上在附加指定的dom元素。

$("p").add(document.getElementById("a"));

add(els)&nbsp; 

在匹配对象的基础上在附加指定的一组对象，els是一个数组。

&lt;p&gt;Hello&lt;/p&gt;&lt;p&gt;&lt;span&gt;Hello Again&lt;/span&gt;&lt;/p&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp;&nbsp; var f=$("p").add([document.getElementById("a"), document.getElementById("b")])
&nbsp;&nbsp;&nbsp;&nbsp; for(var i=0;i &lt; $(f).size();i++){
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert($(f).eq(i).html());}
}
注意els是一个数组，这里的[ ]不能漏掉。
]]></description>
		</item>
		<item>
			<title>jquery使用手册(5)</title>
			<link>http://www.kingmx.com/article.php?id=15172</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
clone() 

复制一个jQuery对象 

&lt;p id="test"&gt;after&lt;/p&gt;&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp; $("#test").clone().appendTo($("a"));&nbsp; 
}
复制$("#test")然后插入到&lt;a&gt;后,执行后相当于 

&lt;p id="test"&gt;after&lt;/p&gt;&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;&lt;p id="test"&gt;after&lt;/p&gt;

empty() 

删除匹配对象的所有子节点 

&lt;div id="test"&gt;
&nbsp; &lt;span&gt;span&lt;/span&gt;
&nbsp; &lt;p&gt;after&lt;/p&gt;
&lt;/div&gt;
&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){&nbsp; 
&nbsp;&nbsp;&nbsp; $("#test").empty();&nbsp; 
}
执行后相当于 

&lt;div id="test"&gt;&lt;/div&gt;&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;

[page]

insertAfter(expr)&nbsp;&nbsp; insertBefore(expr)

按照官方的解释和我的几个简单测试insertAfter(expr)相当于before(elem),insertBefore(expr)相当于after (elem)

prepend (html)&nbsp; prepend (elem)&nbsp; prepend (elems)&nbsp;&nbsp; 

在匹配元素的内部且开始出插入
通过下面例子区分append(elem)&nbsp; appendTo(expr)&nbsp; prepend (elem) 

&lt;p id="a"&gt;p&lt;/p&gt;
&lt;div&gt;div&lt;/div&gt;
执行$("#a").append($("div")) 后相当于 

&lt;p id="a"&gt;
&nbsp; P
&nbsp; &lt;div&gt;div&lt;/div&gt;
&lt;/p&gt;
执行$("#a").appendTo($("div")) 后 相当于 

&lt;div&gt;
&nbsp;&nbsp; div
&nbsp;&nbsp; &lt;p id="a"&gt;p&lt;/p&gt;
&lt;/div&gt;
执行$("#a").prepend ($("div")) 后 相当于 

&lt;p id="a"&gt;
&nbsp;&nbsp; &lt;div&gt;div&lt;/div&gt;
&nbsp;&nbsp; P
&lt;/p&gt;

remove()&nbsp; 

删除匹配对象
注意区分empty()，empty()移出匹配对象的子节点，remove()，移出匹配对象
]]></description>
		</item>
		<item>
			<title>jquery使用手册(4)</title>
			<link>http://www.kingmx.com/article.php?id=15171</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
二：DOM操作

属性
我们以&lt;img id="a" scr="5.jpg"/&gt;为例，在原始的javascript里面可以用var o=document.getElementById('a')取的id为a的节点对象，在用o.src来取得或修改该节点的scr属性，在jQuery里$("#a")将得到jQuery对象[ &lt;img id="a" scr="5.jpg"/&gt; ]，然后可以用jQuery提供的很多方法来进行操作，如$("#a").scr()将得到5.jpg,$("#a").scr("1.jpg")将该对象src属性改为1,jpg。下面我们来讲jQuery提供的众多jQuery方法，方便大家快速对DOM对象进行操作
herf()&nbsp;&nbsp; herf(val)
说明：对jQuery对象属性herf的操作。
例子：
未执行jQuery前 

&lt;a href="1.htm" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp; alert($("#test").href());
&nbsp;&nbsp; $("#test").href("2.html");
}
运行：先弹出对话框显示id为test的连接url，在将其url改为2.html，当弹出对话框后会看到转向到2.html
同理，jQuery还提供类似的其他方法，大家可以分别试验一下：
herf()&nbsp; herf(val)&nbsp;&nbsp; html()&nbsp; html(val)&nbsp;&nbsp; id()&nbsp; id (val)&nbsp; name()&nbsp; name (val)&nbsp;&nbsp; rel()&nbsp; rel (val) src()&nbsp;&nbsp;&nbsp; src (val)&nbsp;&nbsp; title()&nbsp; title (val)&nbsp;&nbsp; val()&nbsp; val(val)

操作
after(html)&nbsp;
在匹配元素后插入一段html 

&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $("#test").after("&lt;b&gt;Hello&lt;/b&gt;");&nbsp; 
}
执行后相当于： 

&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;&lt;b&gt;Hello&lt;/b&gt;

[page]

after(elem)&nbsp; after(elems)&nbsp;

&nbsp;将指定对象elem或对象组elems插入到在匹配元素后 

&lt;p id="test"&gt;after&lt;/p&gt;&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能 

function jq(){&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp; $("a").after($("#test"));&nbsp; 
}
执行后相当于 

&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;&lt;p id="test"&gt;after&lt;/p&gt;

append(html)

在匹配元素内部，且末尾插入指定html 

&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){ 
&nbsp;&nbsp;&nbsp;&nbsp; $("#test").append("&lt;b&gt;Hello&lt;/b&gt;");&nbsp; 
}
执行后相当于 

&lt;a href="#" onClick="jq()"&gt;jQuery&lt;b&gt;Hello&lt;/b&gt;&lt;/a&gt;
同理还有append(elem)&nbsp; append(elems) before(html) before(elem) before(elems)请执行参照append和after的方来测试、理解！

appendTo(expr)&nbsp;

与append(elem)相反 

&lt;p id="test"&gt;after&lt;/p&gt;&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能 

function jq(){&nbsp; 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; $("a"). appendTo ($("#test"));&nbsp; 
}
执行后相当于 

&lt;p id="test"&gt;after&lt;a href="#" onClick="jq()"&gt;jQuery&lt;/a&gt; &lt;/p&gt;
]]></description>
		</item>
		<item>
			<title>JQuery使用指南（3）</title>
			<link>http://www.kingmx.com/article.php?id=15170</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
eq(pos)
说明：减少匹配对象到一个单独得dom元素
参数：pos (Number): 期望限制的索引，从0 开始
例子：
未执行jQuery前： 

&lt;p&gt;This is just a test.&lt;/p&gt;
&lt;p&gt;So is this&lt;/p&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("p").eq(1).html())
}
运行：当点击id为test的元素时，alert对话框显示：So is this，即第二个&lt;p&gt;标签的内容

get() get(num)
说明：获取匹配元素，get(num)返回匹配元素中的某一个元素
参数：get (Number): 期望限制的索引，从0 开始
例子：
未执行jQuery前： 

&lt;p&gt;This is just a test.&lt;/p&gt;
&lt;p&gt;So is this&lt;/p&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("p").get(1).innerHTML);
}
运行：当点击id为test的元素时，alert对话框显示：So is this，即第二个&lt;p&gt;标签的内容
注意get和eq的区别，eq返回的是jQuery对象，get返回的是所匹配的dom对象，所有取$("p").eq(1)对象的内容用jQuery方法html()，而取$("p").get(1)的内容用innerHTML

[page]

index(obj)
说明：返回对象索引
参数：obj (Object): 要查找的对象
例子：
未执行jQuery前： 

&lt;div id="test1"&gt;&lt;/div&gt;
&lt;div id="test2"&gt;&lt;/div&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("div").index(document.getElementById('test1')));
&nbsp;&nbsp;&nbsp; alert($("div").index(document.getElementById('test2')));
}
运行：当点击id为test的元素时，两次弹出alert对话框分别显示0，1

size()&nbsp;&nbsp; Length
说明：当前匹配对象的数量，两者等价
例子：
未执行jQuery前： 

&lt;img src="test1.jpg"/&gt;
&lt;img src="test2.jpg"/&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($("img").length);
}
运行：当点击id为test的元素时，弹出alert对话框显示2，表示找到两个匹配对象 
]]></description>
		</item>
		<item>
			<title>JQuery使用指南（2）</title>
			<link>http://www.kingmx.com/article.php?id=15169</link>
			<pubDate>2007-4-11</pubDate>
			<description><![CDATA[
$(elem)

说明：限制jQuery作用于一个特定的dom元素，这个函数也接受xml文档和windows对象
参数： elem：通过jQuery对象压缩的DOM元素
例子：
未执行jQuery前： 

&lt;p&gt;one&lt;/p&gt;
&nbsp; &lt;div&gt;
&nbsp;&nbsp;&nbsp;&nbsp; &lt;p&gt;two&lt;/p&gt;
&nbsp; &lt;/div&gt;&lt;p&gt;three&lt;/p&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; alert($(document).find("div &gt; p").html());
}
运行：当点击id为test的元素时，弹出对话框文字为two，即div标签下p元素的内容 

function jq(){
&nbsp;&nbsp; $(document.body).background("black");
}
运行：当点击id为test的元素时，背景色变成黑色

$(elems)

说明：限制jQuery作用于一组特定的DOM元素
参数： elem：一组通过jQuery对象压缩的DOM元素
例子：
未执行jQuery前： 

&lt;form id="form1"&gt;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;input type="text" name="textfield"&gt;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;input type="submit" name="Submit" value="提交"&gt;
&lt;/form&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){ 
&nbsp;&nbsp; $(form1.elements ).hide(); 
}
运行：当点击id为test的元素时，隐藏form1表单中的所有元素。

[page]

$(fn)

说明：$(document).ready()的一个速记方式，当文档全部载入时执行函数。可以有多个$(fn)当文档载入时，同时执行所有函数！
参数：fn (Function):当文档载入时执行的函数！
例子： 

$( function(){
&nbsp;&nbsp;&nbsp; $(document.body).background("black");
})
运行：当文档载入时背景变成黑色，相当于onLoad。

$(obj)
说明：复制一个jQuery对象，
参数：obj (jQuery): 要复制的jQuery对象
例子：
未执行jQuery前： 

&lt;p&gt;one&lt;/p&gt;
&lt;div&gt;
&nbsp;&nbsp; &lt;p&gt;two&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;three&lt;/p&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp;&nbsp; var f = $("div"); 
&nbsp;&nbsp;&nbsp; alert($(f).find("p").html()) 
}
运行：当点击id为test的元素时，弹出对话框文字为two，即div标签下p元素的内容。

each(fn)
说明：将函数作用于所有匹配的对象上
参数：fn (Function): 需要执行的函数
例子：
未执行jQuery前： 

&lt;img src="1.jpg"/&gt;
&lt;img src="1.jpg"/&gt;
&lt;a href="#" id="test" onClick="jq()"&gt;jQuery&lt;/a&gt;
jQuery代码及功能： 

function jq(){
&nbsp;&nbsp; $("img").each(function(){ 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; this.src = "2.jpg"; });
}
运行：当点击id为test的元素时，img标签的src都变成了2.jpg。
]]></description>
		</item>
	</channel>
 </rss>
