`
zjx2388
  • 浏览: 1333990 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

jQuery 操作手册(4)

阅读更多

                                           JavaScript处理

$.browser()  判断浏览器类型,返回boolean

$(function(){
    
if($.browser.msie) {
        alert("
这是一个IE浏览器");}
    
else if($.browser.opera) {
        alert("
这是一个opera浏览器");}
})

当页面载入时判断浏览器类型,可判断的类型有msiemozillaoperasafari

$.each(obj, fn)  obj为对象或数组,fn为在obj上依次执行的函数,注意区分$().each()

$.each( [0,1,2], function(i){ alert( "Item #" + i + ": " + this ); });

    分别将012为参数,传入到function(i)

$.each({ name: "John", lang: "JS" },  function(i){ alert( "Name: " + i + ", Value: " + this );

    { name: "John", lang: "JS" }为一个hash对象,依次将hash中每组对象传入到函数中

$.extend(obj, prop)  用第二个对象扩展第一个对象

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(){
       
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中的元素依次传给fnfn必须返回一个boolen,如fn返回true,将被过滤

$(function(){
        
var arr= $.grep( [0,1,2,3,4], function(i){ return i > 2; });
        $.each(arr, 
function(i){ alert(i); });
})

我们可以看待执行$.grep后数组[0,1,2,3,4]变成[01]

$.merge(first, second)  两个参数都是数组,排出/除第二个数组中与第一个相同的,再将两个数组合并

$(function(){ 
        
var arr = $.merge( [0,1,2], [2,3,4] )
        $.each(arr,  
function(i){ alert(i); });
})

可以看出arr的结果为[0,1,2,3,4]

$.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()  隐藏匹配对象

<id="a">Hello Again</p><href="#" onClick=’$ ("#a").hide()’>jQuery</a>

当点击连接时,ida的对象的display变为none

show() 显示匹配对象

hide(speed)  以一定的速度隐藏匹配对象,其大小(长宽)和透明度都逐渐变化到0speed3("slow", "normal",  "fast"),也可以是自定义的速度。

show(speed)  以一定的速度显示匹配对象,其大小(长宽)和透明度都由0逐渐变化到正常

hide(speed, callback)  show(speed, callback) 当显示和隐藏变化结束后执行callback函数

toggle()    toggle(speed) 如果当前匹配对象隐藏,则显示他们,如果当前是显示的,就隐藏,toggle(speed),其大小(长宽)和透明度都随之逐渐变化。

<img src="1.jpg" style="width:150px"/>
<href="#" onClick='$("img").toggle("slow")'>jQuery</a>


fadeIn(speeds)   fadeOut(speeds)  根据速度调整透明度来显示或隐藏匹配对象,注意有别于hide(speed)show(speed)fadeInfadeOut都只调整透明度,不调整大小

<img src="1.jpg" style="display:none"/><href="#" onClick='$("img ").fadeIn("slow")'> jQuery </a>

点击连接后可以看到图片逐渐显示。

fadeIn(speed, callback)  fadeOut(speed, callback)   callback为函数,先通过调整透明度来显示或隐藏匹配对象,当调整结束后执行callback函数

<img src="1.jpg"/>
<href="#" onClick='$("img ").fadeIn("slow",function(){ alert("Animation Done."); })'> jQuery </a>

点击连接后可以看到图片逐渐显示,显示完全后弹出对话框

fadeTo(speed, opacity, callback)  将匹配对象以speed速度调整倒透明度opacity,然后执行函数callbackOpacity为最终显示的透明度(0-1).

<img src="1.jpg"/><br>
<href="#" onClick='$("img ").fadeTo("slow",0.55,function(){ alert("Animation Done."); })'> jQuery </a>

大家可以看一下自己看看效果,如果不用jQuery,编写原始javascript脚本可能很多代码!

slideDown(speeds)  将匹配对象的高度由0以指定速率平滑的变化到正常!

<img src="1.jpg" style="display:none"/>
<href="#" onClick='$("img ").slideDown("slow")'>jQuery</a>


slideDown(speeds,callback)  将匹配对象的高度由0变化到正常!变化结束后执行callback函数

slideUp(speed)  slideUp(speed, callback) 匹配对象的高度由正常变化到0
slideToggle(speed) 如果匹配对象的高度正常则逐渐变化到0,若为0,则逐渐变化到正常 
                                              六:事件处理
 hover(Function, Function)    当鼠标move over时触发第一个function,当鼠标move out时触发第二个function
样式:<style>.red{color:#FF0000}</style>
Html
代码: <div id="a">sdf</div>
jQuery
代码及效果

$(function(){
  $("#a").hover(
function(){$(this).addClass("red");},
                           
function(){ $(this).removeClass("red"); 
                          });
})

最终效果是当鼠标移到ida的层上时图层增加一个red样式,离开层时移出red样式
toggle(Function, Function)    当匹配元素第一次被点击时触发第一个函数,当第二次被点击时触发第二个函数
样式:<style>.red{color:#FF0000}</style>
Html
代码: <div id="a">sdf</div>
jQuery
代码及效果

$(function(){
  $("#a"). toggle (
function(){$(this).addClass("red");},
                             
function(){ $(this).removeClass("red"); 
                            });
})

最终效果是当鼠标点击ida的层上时图层增加一个red样式,离开层时移出red样式
bind(type, fn)   用户将一个事件和触发事件的方式绑定到匹配对象上。
trigger(type)   用户触发type形式的事件。$("p").trigger("click")
还有:unbind()   unbind(type)    unbind(type, fn)
Dynamic event(Function)    绑定和取消绑定提供函数的简捷方式
例:

$("#a").bind("click",function() { 
                                       $(
this).addClass("red");
})

也可以这样写:

$("#a").click(function() { 
                        $(
this).addClass("red");
});

最终效果是当鼠标点击ida的层上时图层增加一个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)

用于UI事件
blur(fn)    focus(fn)
以上事件的扩展再扩展为5
举例,click(fn) 扩展 click()  unclick()  oneclick(fn)  unclick(fn)
click(fn)
:增加一个点击时触发某函数的事件
click()
:可以在其他事件中执行匹配对象的click事件。
unclick ()
:不执行匹配对象的click事件。
oneclick(fn)
:只增加可以执行一次的click事件。
unclick (fn)
:增加一个点击时不触发某函数的事件。
上面列举的用于browersformkeyboardmouseUI的事件都可以按以上方法扩展。
                                       七:Ajax支持
 通用方式:
$.ajax(prop)    通过一个ajax请求,回去远程数据,prop是一个hash表,它可以传递的key/value有以下几种
         (String)type
:数据传递方式(getpost)
         ((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",
          success:
function(msg){ 
                         $(div"#a").html(msg);
                } 
    });

ajax.htm返回的内容作为idadiv内容

$.ajax({ url: "ajax.aspx",
              type:"get",           
             dataType:"html",
             data: "name=John&location=Boston",
             success:
function(msg){ 
                                 $("#a").html(msg);
                              } 
         });

get方式向ajax.aspx页面传参数,并将返回内容负给ida的对象。
$.ajaxTimeout(time) 设置请求结束时间
   $.ajaxTimeout( 5000 )
其它简化方式:

$.get(url, params, callback)  get方式向远程页面传递参数,请求完成后处理函数,除了url外,其它参数任意选择

$.get( "ajax.htm" , function(data){ $("#a").html(data)  })

$.get(   "ajax.asp", 
            { name: "young", age: "25" },
            function(data){ alert("Data Loaded: " + data); }
        ) 

$.getIfModified(url, params, callback)  get方式向远程页面传递参数,从最后一次请求后如果数据有变化才作出响应,执行函数callback
$.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

$("#a").load("ajax.htm", function() { alert("load is done"); } );

仰天一笑 徐羽 ajax.htm页面发出请求,将返回结果装入ida的内容中,然后再执行函数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插件,如thickboxiFXjQuery-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,方便大家查询!

分享到:
评论

相关推荐

    jQuery1.12.4+jQuery中文手册.rar

    `jQuery1.11.0_20140330.chm`可能是早期版本的jQuery API参考,而`jQueryAPI_CHM.CHM`则是针对jQuery 1.x系列的API手册,可能包含了1.12.4版本的相关信息。 在这些API文档中,你可以找到jQuery的函数、方法、选择器...

    jQuery使用手册.zip

    4. **动画效果**:jQuery的动画功能强大,`fadeIn()`, `fadeOut()`, `slideToggle()`等方法使得创建淡入淡出、滑动等效果轻松实现。同时,`animate()`方法允许自定义动画效果,控制CSS属性的变化。 5. **Ajax交互**...

    jQuery使用手册及实例

    结合提供的文档“2-jQuery使用手册.doc”、“4-jQuery技巧总结.doc”、“5-jQuery常用方法事件属性.doc”以及“3-使用 jQuery 简化 Ajax 开发.doc”,你将能够深入理解和实践jQuery的各种功能,成为jQuery的熟练使用...

    jquery操作手册中文版

    **jQuery 操作手册中文版** jQuery 是一个广泛应用于 Web 开发的 JavaScript 库,它极大地简化了 JavaScript 的操作,使得网页交互变得更加简单。这个“jQuery 操作手册中文版”是初学者入门和进阶的宝贵资源,包含...

    jQuery操作手册及源码

    **jQuery 操作手册及源码详解** jQuery 是一个广泛使用的 JavaScript 库,它极大地简化了网页中的 DOM 操作、事件处理、动画制作以及Ajax交互。本手册主要针对jQuery 1.10.3版本,这一版本在保持稳定性和兼容性的...

    jQuery api手册

    jQuery API手册是开发者的宝贵资源,涵盖了从基础操作到高级特性的详细指南。通过深入学习和实践,开发者能更高效地编写高性能的前端代码,提升用户体验。无论你是初学者还是经验丰富的开发者,这份手册都值得你常备...

    jQuery操作手册

    ### jQuery操作手册知识点详解 #### 一、jQuery简介 jQuery是一种快速、简洁的JavaScript库,其设计宗旨是为了简化HTML文档遍历、事件处理、动画以及Ajax交互等操作。通过简单的语法,开发者可以轻松地实现复杂的...

    jQuery参考手册(1.11.3).rar

    《jQuery参考手册(1.11.3)》是一份详尽的指南,旨在帮助开发者深入理解和高效使用jQuery库。jQuery是JavaScript中最受欢迎的库之一,它极大地简化了DOM操作、事件处理、动画效果和Ajax交互。在1.11.3版本中,...

    JavaScript和jquery实战手册

    使用jQuery简化DOM操作,提高代码可读性和效率;利用Ajax实现无刷新更新,提升用户体验。同时,了解最新的ES6+特性,如类、模块和迭代器,可以使JavaScript代码更加现代和简洁。 本手册将详细讲解这些概念,并通过...

    JQuery学习手册.rar

    4. **动画效果**:JQuery的`.animate()`方法允许创建复杂的动画效果,包括改变CSS属性如透明度、宽度、高度等。`.fadeIn()`、`.fadeOut()`、`.slideToggle()`等预定义动画则提供了更便捷的动画控制。 5. **插件扩展...

    jquery中文版离线手册

    4. **链式操作**:jQuery对象方法返回的是jQuery对象本身,允许连续调用多个方法,如`$("div").css("color", "red").fadeIn(1000);` 5. **动画效果**:jQuery的`animate()`方法可以创建平滑的动画效果,如改变元素的...

    JQuery手册大全全套20+本_全网最全_中文_完整_jquery最好学习资料

    《JQuery操作大图片》参考文档 《JQuery操作摄像头》参考文档 《JQuery操作网格》参考文档 《jQuery DataTables使用手册(精简版)和中文API》 《jQuery Validation学习手册》 《jQuery Validation中文API》参考手册 ...

    jquery离线手册

    **jQuery离线手册** jQuery,一个JavaScript库,是前端开发中的瑰宝,因其简洁的语法和强大的功能而受到广泛赞誉。对于前端开发者和后端程序员来说,熟悉jQuery API是提高工作效率的关键。本离线手册专注于jQuery的...

    jQuery入门手册1.3.2

    **jQuery入门手册1.3.2** jQuery是一个广泛使用的JavaScript库,它极大地简化了JavaScript的DOM操作、事件处理、动画制作以及Ajax交互。这个“jQuery入门手册1.3.2”是针对初学者的指导性资料,旨在帮助读者快速...

    JQuery中文手册(.CHM)

    **jQuery中文手册(.CHM)** jQuery是一款广泛应用于Web开发的JavaScript库,它极大地简化了JavaScript的使用,尤其是处理HTML文档对象模型(DOM)、事件处理、动画效果以及Ajax交互。这个`.CHM`(Microsoft Compiled...

    jquery最新手册 3合1

    - **DOM操作**:jQuery提供了方便的DOM操作方法,如`append()`在元素内部追加内容,`remove()`删除元素,`clone()`复制元素。 - **事件处理**:`.on()`、`.off()`、`.click()`等方法用于绑定和解绑事件,简化了...

    jquery参考手册jquery帮助文档

    jQuery的核心理念是“写得更少,做得更多”,它通过封装DOM操作、事件处理、动画效果和Ajax交互等常见任务,提供了一套优雅的API,让开发者能够以更少的代码实现更多的功能。** ### jQuery 基础概念 **1. 选择器...

    jquery文档JQuery API手册与JQuery UI API手册_1.2.rar

    4. **链式操作**: jQuery方法返回的是jQuery对象,因此可以进行链式调用,如`$("#element").addClass("active").css("color", "red")`。 5. **动画效果**: `$.fn.animate()`用于创建自定义动画,`fadeIn()`, `...

    jquery1.7.2中文手册

    《jQuery 1.7.2 中文手册》是前端开发者必备的参考资料,它详细阐述了jQuery库在1.7.2版本中的各项功能和用法。jQuery是一个强大的JavaScript库,它的核心理念是“Write Less, Do More”,通过简洁的API接口,让...

    jquery经典学习手册

    4. **事件处理**:jQuery简化了事件绑定和解绑的过程。 ```javascript $("#myButton").click(function() { alert("Button clicked!"); }); ``` 5. **DOM操作**:jQuery提供了便利的方法来操作DOM,如添加、删除和...

Global site tag (gtag.js) - Google Analytics