<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    爪哇一角

    共同探討STRUTS#HIBERNATE#SPRING#EJB等技術
    posts - 3, comments - 6, trackbacks - 0, articles - 99
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    jQuery介紹(自我學習)

    Posted on 2009-08-04 17:48 非洲小白臉 閱讀(336) 評論(2)  編輯  收藏 所屬分類: AJAX + jQuery
    jQuery由美國人John Resig創建,至今已吸引了來自世界各地的眾多javascript高手加入其team,包括來自德國的J&ouml;rn Zaefferer,羅馬尼亞的Stefan Petre等等。
    jQuery是繼prototype之后又一個優秀的Javascrīpt框架。其宗旨是——WRITE LESS,DO MORE,寫更少的代碼,做更多的事情。
    它是輕量級的js庫(壓縮后只有21k) ,這是其它的js庫所不及的,它兼容CSS3,還兼容各種瀏覽器 (IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+)。
    jQuery是一個快速的,簡潔的javaScript庫,使用戶能更方便地處理HTML documents、events、實現動畫效果,并且方便地為網站提供AJAX交互。
    jQuery還有一個比較大的優勢是,它的文檔說明很全,而且各種應用也說得很詳細,同時還有許多成熟的插件可供選擇。
    jQuery能夠使用戶的html頁保持代碼和html內容分離,也就是說,不用再在html里面插入一堆js來調用命令了,只需定義id即可。
    Jquery是繼prototype之后又一個優秀的Javascrīpt框架。對 prototype我使用不多,簡單了解過。但使用上jquery之后,馬上被她的優雅吸引住了。有人使用這樣的一比喻來比較prototype和 jquery:prototype就像Java,而jquery就像ruby.實際上我比較喜歡java(少接觸Ruby 罷了)但是jquery的簡單的實用的確有相當大的吸引力啊!在項目里我把jquery作為自己唯一的框架類包。使用其間也有一點點心得,其實這些心得, 在jquery的文檔上面也可能有講,不過還是記下來,以備忘罷。

    一,找到你了!

    還記得$()這個東西吧?無論prototype還是DWR都使用了這個函數代替document.getElementById()。沒錯,jquery也跟風了。為達到document.getElementById()的目的,jquery是這樣寫的:
    代碼
    var someElement = $("#myId");
    看起來比其他兩個框架的要多了一個#,好,看看下面的用法:
    代碼
    $("div p"); // (1)
    $("div.container"); // (2)
    $("div #msg"); // (3)
    $("table a",context); // (4)
    在prototype里看過這樣的寫法嗎?第一行代碼得到所有標簽下的P元素。第二行代碼得到class 為container的元素,第三行代碼得到標簽下面id為msg的元素。第四行代碼得到context為上下文的table里面所有的連接元素。
    如果你熟悉CSS,你會覺得這些寫法很眼熟!對了。正是。看出奧妙了吧。jquery就是通過這樣的方式來找到Dom對象里面的元素。跟CSS的選擇器相類似。

    二,Jquery對象?

    jquery提供了很多便利的函數,如each(fn),但是使用這些函數的前提是:你使用的對象是Jquery對象。使一個Dom對象成為一個Jquery對象很簡單,通過下面一些方式(只是一部分):
    代碼
    var a = $("#cid");
    var b = $("hello");
    var c = document.createElement("table");
    var tb = $&copy;;

    三,代替body標簽的onload

    這個慣例,也許是除了$()之外,用得最多的地方了。下面一段代碼:
    代碼
    $(document).ready(function(){
    alert("hello");
    });(1)
    <body onload="alert('hello');">(2)
    上面兩段代碼是等價的。但代碼1的好處是做到表現和邏輯分離。并且可以在不同的js文件中做相 同的操作,即$(document).ready (fn)可以在一個頁面中重復出現,而不會沖突。基本上Jqeury的很多plugin都是利用這個特性,正因為這個特性,多個plugin共同使用起 來,在初始化時不會發生沖突。
    不管怎么說,這個慣例可以分離javascrīpt與HTML。推薦使用。

    四,事件機制

    我大量使用的事件可能就是button的onclick了。以前習慣在input 元素上寫onclick = "fn()",使用jquery可以使javascrīpt代碼與html代碼分離,保持HTML的清潔,還可以很輕松地綁定事件,甚至你可以不知道“事 件”這個名詞。
    代碼
    $(document).ready(function(){
    $("#clear").click(function(){
    alert("i am about to clear the table");
    });
    $("form[0]").submit(validate);
    });
    function validate(){
    //do some form validation
    }

    五,同一函數實現set

    代碼
    $("#msg").html();
    $("#msg").html("hello");
    上面兩行代碼,調用了同樣的函數。但結果卻差別很大。
    第一行是返回指定元素的HTML值,第二行則是將hello這串字符設置到指定元素中。jquery的函數大部分有這樣的特性。

    六,ajax

    這是一個ajax橫行的時代。多少人,了不了解ajax的都跟著用上一把。呵。使用jquery實現ajax同樣簡單異常
    代碼
    $.get("search.do",{id:1},rend);
    function rend(xml){
    alert(xml);
    } (1)
    $.post("search.do",{id:1},rend);
    function rend(xml){
    alert(xml);
    } (2)
    $("#msg").ajaxStart(function(){
    this.html("正在加載。。。。");
    });(3)
    $("#msg").ajaxSuccess(function(){
    this.html("加載完成!");
    });(4)
    這些都是較常用的方法,get和post用法一樣。第一個參數是異步請求的url,第二個為參數,第三個回調方法。
    3,4的方法會在指定的Dom對象上綁定響應ajax執行的事件。當然,jquery的AJAX相關的函數不僅是這些,有興趣可以去研究再多。

    七,漸入淡出

    代碼
    $("#msg").show("fast");
    $("#msg").hide("slow");
    沒錯,上面兩行代碼已經分別實現了一個id為Msg的jquery對象的漸入和淡出。做一個像Gmail一樣的動態加載通知條,用jquery就那么簡單。兩個函數接受的參數除了快慢等,還可以接收整型,作為漸入或淡出的完成時間,單位為MS。

    八,plugin

    這也是一個插件的時代。
    jquery插件給我的感覺清一色的清潔,簡單。如Jtip,要使用它的功能,只需要在你的元素的class上加上Jtip,并引入jtip.js及其樣式即可以了。其他事情插件全包。我喜歡jquery的一個重要原因是發現她已經有了很多很好,很精彩的插件。
    寫得很爛。可能大家看不出jquery的好處。嗯,光聽是沒用的,試用一下吧。你會發覺很有趣。
    暫時告一段落吧。待有新的發現再來分享。
    加一些Jquery的資源:
    http://www.visualjquery.com/index.xml 很好的API查詢站點
    http://jquery.com/demo/thickbox/ 知道lightBox吧,看看Jquery是怎樣實現相同的東西
    http://jquery.org.cn/visual/cn/index.xml //不錯的JQUERY 中文學習 推薦
    jquery來源
    jQuery由美國人John Resig創建,至今已吸引了來自世界各地的眾多javascript高手加入其team,包括來自德國的J&ouml;rn Zaefferer,羅馬尼亞的Stefan Petre等等。
    jQuery是繼prototype之后又一個優秀的Javascrīpt框架。其宗旨是——WRITE LESS,DO MORE,寫更少的代碼,做更多的事情。
    它是輕量級的js庫(壓縮后只有21k) ,這是其它的js庫所不及的,它兼容CSS3,還兼容各種瀏覽器 (IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+)。
    jQuery是一個快速的,簡潔的javaScript庫,使用戶能更方便地處理HTML documents、events、實現動畫效果,并且方便地為網站提供AJAX交互。
    jQuery還有一個比較大的優勢是,它的文檔說明很全,而且各種應用也說得很詳細,同時還有許多成熟的插件可供選擇。
    jQuery能夠使用戶的html頁保持代碼和html內容分離,也就是說,不用再在html里面插入一堆js來調用命令了,只需定義id即可。
    jQuery的最新release版本是1.2.6。
    官方下載地址為:http://jqueryjs.googlecode.com/files/jquery-1.2.6.min.js
    微軟的visual studio 2008 sp1支持對jquery的動態提示,只要在代碼頁導入對應的vsdoc腳本就可以。
    目前為止,jQuery的最新版本為1.3.2

    評論

    # re: jQuery介紹(自我學習)  回復  更多評論   

    2009-08-27 00:05 by 多個地方
    古典風格

    # re: jQuery介紹(自我學習)  回復  更多評論   

    2009-08-27 00:06 by 多個地方
    大鍋飯大范甘迪
    主站蜘蛛池模板: 久久九九兔免费精品6| 亚洲一区二区在线免费观看| 性做久久久久久久免费看| 亚洲AV永久青草无码精品| 亚洲欧洲免费视频| 国产精品亚洲а∨无码播放| 免费观看一区二区三区| 性色av免费观看| 亚洲一区中文字幕在线观看| 国产四虎免费精品视频| 亚洲免费视频网址| 亚洲精品视频免费| 国产偷国产偷亚洲清高动态图 | 国产美女被遭强高潮免费网站| 亚洲日韩中文字幕无码一区| 国产精品九九久久免费视频| 日日噜噜噜噜夜夜爽亚洲精品| 久久精品中文字幕免费| 亚洲最大免费视频网| 扒开双腿猛进入爽爽免费视频 | 色偷偷亚洲第一综合| 亚洲国产精品免费在线观看| 亚洲在成人网在线看| 处破痛哭A√18成年片免费| 成人免费网站久久久| 精品久久久久久久久免费影院| 亚洲 暴爽 AV人人爽日日碰| 日韩免费人妻AV无码专区蜜桃| 亚洲无线一二三四区| 日本一道综合久久aⅴ免费| jyzzjyzz国产免费观看| 日木av无码专区亚洲av毛片| 中文字幕高清免费不卡视频| 免费永久在线观看黄网站| 色老板亚洲视频免在线观| 国产免费131美女视频| 华人在线精品免费观看| 久久久国产亚洲精品| 超清首页国产亚洲丝袜| 一区二区三区免费在线观看| 久久久久久亚洲Av无码精品专口|