下载完成后先加载到文档中,然后我们来看个简单的例子!
上边的效果是点击文档中所有a标签时将弹出对话框,$("a") 是一个jQuery选择器,$本身表示一个jQuery类,所有$()是构造一个jQuery对象,click()是这个对象的方法,同理$(document)也是一个jQuery对象,ready(fn)是$(document)的方法,表示当document全部下载完毕时执行函数。
在进行下面内容之前我还要说明一点$("p")和$("#p")的区别,$("p")表示取所有p标签()的元素,$("#p")表示取id为"p"()的元素.
我将从以下几个内容来讲解jQuery的使用:
1:核心部分
2:DOM操作
3:css操作
4:javascript处理
5:动态效果
6:event事件
7:ajax支持
8:插件程序
一:核心部分
$(expr)
说明:该函数可以通过css选择器,Xpath或html代码来匹配目标元素,所有的jQuery操作都以此为基础
参数:expr:字符串,一个查询表达式或一段html字符串
例子:
未执行jQuery前:
Hello
Hello
标签的内容
标签的内容
的对象,有两个,add("span")是在("p")的基础上加上匹配的对象,所有一共有3个,从上面的函数运行结果可以看到$("p").add("span")是3个对象的集合,分别是[ Hello Hello Again one one This is just a test. Hello Again And Again And Again one one Hello Hello Again Hello Hello Again test test 最终效果是当鼠标点击id为a的层上时图层增加一个red样式, 用于UI事件 用get方式向ajax.aspx页面传参数,并将返回内容负给id为a的对象。 $.get(url, params, callback) 用get方式向远程页面传递参数,请求完成后处理函数,除了url外,其它参数任意选择!
add(el) 在匹配对象的基础上在附加指定的dom元素。
$("p").add(document.getElementById("a"));
add(els) 在匹配对象的基础上在附加指定的一组对象,els是一个数组。
var
f
=
$(
"
p
"
).add([document.getElementById(
"
a
"
), document.getElementById(
"
b
"
)])
for
(
var
i
=
0
;i
<
$(f).size();i
++
){
alert($(f).eq(i).html());}
}
ancestors () 一依次以匹配结点的父节点的内容为对象,根节点除外(有点不好理解,看看下面例子就明白了)
<
p
>
one
p
>
<
span
>
<
u
>
two
u
>
span
>
div
>
var
f
=
$(
"
u
"
).ancestors();
for
(
var
i
=
0
;i
<
$(f).size();i
++
){
alert($(f).eq(i).html());}
}
第一个对象是以的父节点的父节点(div)的内容为对象,[
一般一个文档还有和,依次类推下去。
ancestors (expr) 在ancestors()的基础上之取符合表达式的对象
如上各例子讲var f改为var f= $("u").ancestors(“div”),则只返回一个对象:
[
children() 返回匹配对象的子介点
<
div
id
="ch"
>
<
span
>
two
span
>
div
>
alert($(
"
#ch
"
).children().html());
}
children(expr) 返回匹配对象的子介点中符合表达式的节点
<
span
>
two
span
>
<
span
id
="sp"
>
three
span
>
div
>
alert($(
"
#ch
"
).children(“#sp”).html());
}
$("#ch").children(“#sp”)过滤得到[three ]
parent () parent (expr)取匹配对象父节点的。参照children帮助理解
contains(str) 返回匹配对象中包含字符串str的对象
alert($(
"
p
"
).contains(
"
test
"
).html());
}
end() 结束操作,返回到匹配元素清单上操作前的状态.
filter(expr) filter(exprs) 过滤现实匹配符合表达式的对象 exprs为数组,注意添加“[ ]”
alert($(
"
p
"
).filter(
"
.selected
"
).html())
}
find(expr) 在匹配的对象中继续查找符合表达式的对象
alert($(
"
p
"
).find(
"
#a
"
).html())
}
is(expr) 判断对象是否符合表达式,返回boolen值
alert($(
"
#a
"
).is(
"
p
"
));
}
大家可以用$("#a").is("div"); ("#a").is("#a")多来测试一下
next() next(expr) 返回匹配对象剩余的兄弟节点
alert($(
"
p
"
).next().html());
alert($(
"
p
"
).next(
"
.selected
"
).html());
}
$("p").next(".selected)只返回 [
prev () prev (expr) 参照next理解
not(el) not(expr) 从jQuery对象中移出匹配的对象,el为dom元素,expr为jQuery表达式。
<
a
href
="#"
onclick
="js()"
>
jQuery
a
>
alert($(
"
p
"
).not(document.getElementById(
"
a
"
)).html());
alert($(
"
p
"
).not(“#a”).html());
}
siblings () siblings (expr) jquery匹配对象中其它兄弟级别的对象
<
div
>
<
p
id
="a"
>
two
p
>
div
>
<
a
href
="#"
onclick
="js()"
>
jQuery
a
>
alert($(
"
div
"
).siblings().eq(
1
).html());
}
alert($("div").siblings(“a”)返回一个对象[jQuery ]
其他
addClass(class) 为匹配对象添加一个class样式
removeClass (class) 将第一个匹配对象的某个class样式移出
attr (name) 获取第一个匹配对象的属性
alert($("img").attr("src"));
}
attr (prop) 为第一个匹配对象的设置属性,prop为hash对象,用于为某对象批量添加众多属性
$("img").attr({ src: "test.jpg", alt: "Test Image" });
}
attr (key,value) 为第一个匹配对象的设置属性,key为属性名,value为属性值
jQuery代码及功能
$("img").attr(“src”,”test.jpg”);
}
removeAttr (name) 将第一个匹配对象的某个属性移出
$("img"). removeAttr("alt");
}
toggleClass (class) 将当前对象添加一个样式,不是当前对象则移出此样式,返回的是处理后的对象
$("p").toggleClass("selected")的结果是实返回对象 [
三:CSS操作
传统javascript对css的操作相当繁琐,比如
$("#a")得到jQuery对象[
$("#a").background()将取出该对象的background样式。
$("#a").background(“red”)将该对象的background样式设为red
jQuery提供了以下方法,来操作css
background () background (val) color() color(val) css(name) css(prop)
css(key, value) float() float(val) height() height(val) width() width(val)
left() left(val) overflow() overflow(val) position() position(val) top() top(val)
这里需要讲解一下css(name) css(prop) css(key, value),其他的看名字都知道什么作用了!
css(name) 获取样式名为name的样式
$("#a").css("color") 将得到样式中color值red,("#a").css("background ")将得到blue
css(prop) prop是一个hash对象,用于设置大量的css样式
$("#b").css({ color: "red", background: "blue" });
最终效果是
css(key, value) 用于设置一个单独得css样式
$("#b").css("color","red");最终效果是
四:JavaScript处理
$.browser() 判断浏览器类型,返回boolen值
if
($.browser.msie) {
alert(
"
这是一个IE浏览器
"
);}
else
if
($.browser.opera) {
alert(
"
这是一个opera浏览器
"
);}
})
$.each(obj, fn) obj为对象或数组,fn为在obj上依次执行的函数,注意区分$().each()
$.extend(obj, prop) 用第二个对象扩展第一个对象
var
options
=
{ validate:
true
, name:
"
bar
"
};
$.extend(settings, options);
可以用下面函数来测试
var
settings
=
{ validate:
false
, limit:
5
, name:
"
foo
"
};
var
options
=
{ validate:
true
, name:
"
bar
"
};
$.extend(settings, options);
$.each(settings,
function
(i){ alert( i
+
"
=
"
+
this
); });
})
$.grep(array,fn) 通过函数fn来过滤array,将array中的元素依次传给fn,fn必须返回一个boolen,如fn返回true,将被过滤
var
arr
=
$.grep( [
0
,
1
,
2
,
3
,
4
],
function
(i){
return
i
>
2
; });
$.each(arr,
function
(i){ alert(i); });
})
$.merge(first, second) 两个参数都是数组,排出第二个数组中与第一个相同的,再将两个数组合并
var
arr
=
$.merge( [
0
,
1
,
2
], [
2
,
3
,
4
] )
$.each(arr,
function
(i){ alert(i); });
})
$.trim(str) 移出字符串两端的空格
$.trim(" hello, how are you? ")的结果是"hello, how are you?"
五:动态效果
在将这部分之前我们先看个例子,相信做网页的朋友都遇到n级菜单的情景,但点击某菜单按钮时,如果它的子菜单是显示的,则隐藏子菜单,如果子菜单隐藏,则显示出来,传统的javascript做法是先用getElementById取出子菜单所在容器的id,在判断该容器的style.display是否等于none,如果等于则设为block,如果不等于这设为none,如果在将效果设置复杂一点,当点击按钮时,不是忽然隐藏和显示子菜单,而是高度平滑的转变,这时就要通过setTimeout来设置子菜单的height了,再复杂一点透明度也平滑的消失和显现,这时显现下来需要编写很多代码,如果js基础不好的朋友可能只能从别人写好的代码拿过来修改了!jQuery实现上面效果只需要1句话就行,$("#a").toggle("slow"),,学完jQuery后还需要抄袭修改别人的代码吗?下面我们逐个介绍jQuery用于效果处理的方法。
hide() 隐藏匹配对象
show() 显示匹配对象
hide(speed) 以一定的速度隐藏匹配对象,其大小(长宽)和透明度都逐渐变化到0,speed有3级("slow", "normal", "fast"),也可以是自定义的速度。
show(speed) 以一定的速度显示匹配对象,其大小(长宽)和透明度都由0逐渐变化到正常
hide(speed, callback) show(speed, callback) 当显示和隐藏变化结束后执行函数callback
toggle() toggle(speed) 如果当前匹配对象隐藏,则显示他们,如果当前是显示的,就隐藏,toggle(speed),其大小(长宽)和透明度都随之逐渐变化。
<a href="#" onClick='$("img").toggle("slow")'>jQuerya>
fadeIn(speeds) fadeOut(speeds) 根据速度调整透明度来显示或隐藏匹配对象,注意有别于hide(speed)和show(speed),fadeIn和fadeOut都只调整透明度,不调整大小
fadeIn(speed, callback) fadeOut(speed, callback) callback为函数,先通过调整透明度来显示或隐藏匹配对象,当调整结束后执行callback函数
<a href="#" onClick='$("img ").fadeIn("slow",function(){ alert("Animation Done."); })'> jQuery a>
fadeTo(speed, opacity, callback) 将匹配对象以speed速度调整倒透明度opacity,然后执行函数callback。Opacity为最终显示的透明度(0-1).
<a href="#" onClick='$("img ").fadeTo("slow",0.55,function(){ alert("Animation Done."); })'> jQuery a>
slideDown(speeds) 将匹配对象的高度由0以指定速率平滑的变化到正常!
<a href="#" onClick='$("img ").slideDown("slow")'>jQuerya>
slideDown(speeds,callback) 将匹配对象的高度由0变化到正常!变化结束后执行函数callback
slideUp("slow") slideUp(speed, callback) 匹配对象的高度由正常变化到0
slideToggle("slow") 如果匹配对象的高度正常则逐渐变化到0,若为0,则逐渐变化到正常
六:事件处理
hover(Function, Function) 当鼠标move over时触发第一个function,当鼠标move out时触发第二个function
样式:
Html代码:
jQuery代码及效果
$(
"
#a
"
).hover(
function
(){$(
this
).addClass(
"
red
"
);},
function
(){ $(
this
).removeClass(
"
red
"
);
});
})
toggle(Function, Function) 当匹配元素第一次被点击时触发第一个函数,当第二次被点击时触发第二个函数
样式:
Html代码:
jQuery代码及效果
$(
"
#a
"
). toggle (
function
(){$(
this
).addClass(
"
red
"
);},
function
(){ $(
this
).removeClass(
"
red
"
);
});
})
bind(type, fn) 用户将一个事件和触发事件的方式绑定到匹配对象上。
trigger(type) 用户触发type形式的事件。$("p").trigger("click")
还有:
unbind() unbind(type) unbind(type, fn)
Dynamic event(Function) 绑定和取消绑定提供函数的简捷方式
例:
$(
this
).addClass(
"
red
"
);
})
$(
this
).addClass(
"
red
"
);
});
jQuery提供的函数
用于browers事件
error(fn) load(fn) unload(fn) resize(fn) scroll(fn)
用于form事件
change(fn) select(fn) submit(fn)
用于keyboard事件
keydown(fn) keypress(fn) keyup(fn)
用于mouse事件
click(fn) dblclick(fn) mousedown(fn) mousemove(fn)
mouseout(fn) mouseover(fn) mouseup(fn)
blur(fn) focus(fn)
以上事件的扩展再扩展为5类
举例,click(fn) 扩展 click() unclick() oneclick(fn) unclick(fn)
click(fn):增加一个点击时触发某函数的事件
click():可以在其他事件中执行匹配对象的click事件。
unclick ():不执行匹配对象的click事件。
oneclick(fn):只增加可以执行一次的click事件。
unclick (fn):增加一个点击时不触发某函数的事件。
上面列举的用于browers、form、keyboard、mouse、UI的事件都可以按以上方法扩展。
七:Ajax支持
通用方式:
$.ajax(prop) 通过一个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代码及说明
success:
function
(msg){
$(div
"
#a
"
).html(msg);
}
});
type:
"
get
"
,
dataType:
"
html
"
,
data:
"
name=John&location=Boston
"
,
success:
function
(msg){
$(
"
#a
"
).html(msg);
}
});
$.ajaxTimeout(time) 设置请求结束时间
$.ajaxTimeout( 5000 )
其它简化方式:
{ name:
"
young
"
, age:
"
25
"
},
function
(data){ alert(
"
Data Loaded:
"
+
data); }
)
$.getJSON(url, params, callback) 用get方式向远程json对象传递参数,请求完成后处理函数callback。
$.getScript(url, callback) 用get方式载入并运行一个远程javascript文件。请求完成后处理函数callback。
$.post(url, params, callback) 用post方式向远程页面传递参数,请求完成后处理函数callback
load(url, params, callback) 载入一个远程文件并载入页面DOM中,并执行函数callback
loadIfModified(url, params, callback) 用get方式向远程页面传递参数,从最后一次请求后如果数据有变化才作出响应,将返回结果载入页面DOM中,并执行函数callback
ajaxStart(callback) 当ajax请求发生错误是时执行函数callback
ajaxComplete(callback) 当ajax请求完成时执行函数callback
ajaxError(callback) 当ajax请求发生错误时执行函数callback
ajaxStop(callback) 当ajax请求停止时执行函数callback
ajaxSuccess(callback) 当ajax请求成功时执行函数callback
八:jQuery插件
随着jQuery的广泛使用,已经出现了大量jQuery插件,如thickbox,iFX,jQuery-googleMap等,简单的引用这些源文件就可以方便的使用这些插件。这里我简单的介绍一些网址供大家参考,这些网站头提供了大量的demo,并且使用及其简单,及时E文不好,也能快速掌握!
http://jquery.com/plugins 官方推荐
http://interface.eyecon.ro/demos 效果超级棒,使用更简单,一定有你喜欢的!
http://www.dyve.net/jquery/
http://bassistance.de/jquery-plugins
还有其它很多插件,大家可以google以下,如果大家发现好的了,可以留言共享以下!
——————————————————————————————————————————————
至此jQuery已经介绍完毕,并合并整理提供给大家 下载 ,更多详细的使用请大家参考官方网站,下面我再推荐一些jQuery的学习网站方便大家更好的掌握这项工具!
http://keel.sike.googlepages.com/jQuery_getting_started.html 中文入门介绍,Keel翻译
http://jquery.com/api jquery提供全部基本方法的介绍及demo,方便大家查询!