新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 讨论HTML、XHTML、Web2.0、Ajax、XUL, ExtJS, jQuery, JSON、Social Networking System(SNS)、Rich Internet Applications (RIA)、Tagging System、Taxonomy(tagsonomy,folkonomy)、XForms、XFrames、XInclude, XBL (XML Binding Language)等话题
    [返回] 计算机科学论坛XML.ORG.CN讨论区 - XML技术『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』 → 使用 jQuery 简化 Ajax 开发 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 12763 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 使用 jQuery 简化 Ajax 开发 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     flyfoxs 帅哥哟,离线,有人找我吗?
      
      
      威望:5
      等级:研一(Artificial Intelligence期期不放过)
      文章:550
      积分:3935
      门派:XML.ORG.CN
      注册:2005/1/8

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给flyfoxs发送一个短消息 把flyfoxs加入好友 查看flyfoxs的个人资料 搜索flyfoxs在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 引用回复这个贴子 回复这个贴子 查看flyfoxs的博客楼主
    发贴心情 使用 jQuery 简化 Ajax 开发

    来源:http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#resources  


    级别: 中级

    2007 年 5 月 16 日

    jQuery 是一个JavaScript 库,它有助于简化 JavaScript™ 以及 Asynchronous JavaScript + XML (Ajax) 编程。与类似的 JavaScript 库不同,jQuery 具有独特的基本原理,可以简洁地表示常见的复杂代码。学习 jQuery 基本原理,探索其特性和功能,执行一些常见的 Ajax 任务并掌握如何使用插件扩展 jQuery。
    jQuery 是什么?

    jQuery 由 John Resig 创建于 2006 年初,对于任何使用 JavaScript 代码的程序员来说,它是一个非常有用的 JavaScript 库。无论您是刚刚接触 JavaScript 语言,并且希望获得一个能解决文档对象模型(Document Object Model,DOM)脚本和 Ajax 开发中一些复杂问题的库,还是作为一个厌倦了 DOM 脚本和 Ajax 开发中无聊的重复工作的资深 JavaScript 专家,jQuery 都会是您的首选。

    jQuery 能帮助您保证代码简洁易读。您再也不必编写大堆重复的循环代码和 DOM 脚本库调用了。使用 jQuery,您可以把握问题的要点,并使用尽可能最少的代码实现您想要的功能。

    毫无疑问,jQuery 的原理是独一无二的:它的目的就是保证代码简洁并可重用。当您理解并体会这一原理后,便可以开始学习本教程了,看看 jQuery 对我们的编程方式有多少改进吧。


      

    一些简单的代码简化

    下面是一个简单示例,它说明了 jQuery 对代码的影响。要执行一些真正简单和常见的任务,比方说为页面的某一区域中的每个链接附加一个单击(click)事件,您可以使用纯 JavaScript 代码和 DOM 脚本来实现,如 [URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list1]清单 1[/URL] 所示。


    清单 1. 没有使用 jQuery 的 DOM 脚本
                    
    var external_links = document.getElementById('external_links');
    var links = external_links.getElementsByTagName('a');
    for (var i=0;i < links.length;i++) {
        var link = links.item(i);
        link.onclick = function() {
            return confirm('You are going to visit: ' + this.href);
        };
    }


    [URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list2]清单 2[/URL] 显示了使用 jQuery 实现的相同的功能。


    清单 2. 使用了 jQuery 的 DOM 脚本
                    
    $('#external_links a').click(function() {
        return confirm('You are going to visit: ' + this.href);
    });


    是不是很神奇? 使用 jQuery,您可以把握问题的要点,只让代码实现您想要的功能,而省去了一些繁琐的过程。无需对元素进行循环,click() 函数将完成这些操作。同样也不需要进行多个 DOM 脚本调用。您只需要使用一个简短的字符串对所需的元素进行定义即可。

    理解这一代码的工作原理可能会有一点复杂。首先,我们使用了 $() 函数 —— jQuery 中功能最强大的函数。通常,我们都是使用这个函数从文档中选择元素。在本例中,一个包含有一些层叠样式表(Cascading Style Sheet,CSS)语法的字符串被传递给函数,然后 jQuery 尽可能高效地把这些元素找出来。

    如果您具备 CSS 选择器的基本知识,那么应该很熟悉这些语法。在 [URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list2]清单 2[/URL] 中,#external_links 用于检索 id 为 external_links 的元素。a 后的空格表示 jQuery 需要检索 external_links 元素中的所有 <a> 元素。用英语说起来非常绕口,甚至在 DOM 脚本中也是这样,但是在 CSS 中这再简单不过了

    $() 函数返回一个含有所有与 CSS 选择器匹配的元素的 jQuery 对象。jQuery 对象 类似于数组,但是它附带有大量特殊的 jQuery 函数。比方说,您可以通过调用 click 函数把 click 处理函数指定给 jQuery 对象中的所有元素。

    还可以向 $() 函数传递一个元素或者一个元素数组,该函数将把这些元素封装在一个 jQuery 对象中。您可能会想要使用这个功能将 jQuery 函数用于一些对象,比方说 window 对象。例如,我们通常会像下面这样把函数分配给加载事件:

    window.onload = function() {
        // do this stuff when the page is done loading
    };


    使用 jQuery 编写的功能相同的代码:

    $(window).load(function() {
        // run this when the whole page has been downloaded
    });


    您可能有所体会,等待窗口加载的过程是非常缓慢而且令人痛苦的,这是因为必须等整个页面加载完所有的内容,包括页面上所有的的图片。有的时候,您希望首先完成图片加载,但是在大多数情况下,您只需加载超文本标志语言(Hypertext Markup Language,HTML)就可以了。通过在文档中创建特殊的 ready 事件,jQuery 解决了这个问题,方法如下:

    $(document).ready(function() {
        // do this stuff when the HTML is all ready
    });


    这个代码围绕 document 元素创建了一个 jQuery 对象,然后建立一个函数,用于在 HTML DOM 文档就绪的时候调用实例。可以根据需要任意地调用这个函数。并且能够以真正的 jQuery 格式,使用快捷方式调用这个函数。这很简单,只需向 $() 函数传递一个函数就可以了:

    $(function() {
        // run this when the HTML is done downloading
    });


    到目前以止,我已经向大家介绍了 $() 函数的三种用法。第四种方法可以使用字符串来创建元素。结果会产生一个包含该元素的 jQuery 对象。[URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list3]清单 3[/URL] 显示的示例在页面中添加了一个段落。


    清单 3. 创建和附加一个简单的段落
                    
    $('<p></p>')
        .html('Hey World!')
        .css('background', 'yellow')
        .appendTo("body");


    在前一个例子中您可能已经注意到,jQuery 中的另一个功能强大的特性就是方法链接(method chaining)。每次对 jQuery 对象调用方法时,方法都会返回相同的 jQuery 对象。这意味着如果您需要对 jQuery 对象调用多个方法,那么您不必重新键入选择器就可以实现这一目的:

    $('#message').css('background', 'yellow').html('Hello!').show();


      

    使 Ajax 变得简单

    使用 jQuery 将使 Ajax 变得及其简单。jQuery 提供有一些函数,可以使简单的工作变得更加简单,复杂的工作变得不再复杂。

    Ajax 最常见的用法就是把一块 HTML 代码加载到页面的某个区域中去。为此,只需简单地选择所需的元素,然后使用 load() 函数即可。下面是一个用于更新统计信息的示例:

    $('#stats').load('stats.html');


    通常,我们只需简单地把一些参数传递给服务器中的某个页面。正如您所预料的,使用 jQuery 实现这一操作非常地简单。您可以使用 $.post() 或者 $.get(),这由所需的方法决定。如果需要的话,您还可以传递一个可选的数据对象和回调函数。[URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list4]清单 4[/URL] 显示了一个发送数据和使用回调的简单示例。


    清单 4. 使用 Ajax 向页面发送数据
                    
    $.post('save.cgi', {
        text: 'my string',
        number: 23
    }, function() {
        alert('Your data has been saved.');
    });


    如果您确实需要编写一些复杂的 Ajax 脚本,那么需要用到 $.ajax() 函数。您可以指定 xml、script、html 或者 json,jQuery 将自动为回调函数准备合适的结果,这样您便可以立即使用该结果。还可以指定 beforeSend、error、success 或者 complete 回调函数,向用户提供更多有关 Ajax 体验的反馈。此外,还有一些其它的参数可供使用,您可以使用它们设置 Ajax 请求的超时,也可以设置页面 “最近一次修改” 的状态。[URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list5]清单 5[/URL] 显示了一个使用一些我所提到的参数检索 XML 文档的示例。


    清单 5. $.ajax() 使 Ajax 由复杂变简单
                    
    $.ajax({
        url: 'document.xml',
        type: 'GET',
        dataType: 'xml',
        timeout: 1000,
        error: function(){
            alert('Error loading XML document');
        },
        success: function(xml){
            // do something with xml
        }
    });


    当 success 回调函数返回 XML 文档后,您可以使用 jQuery 检索这个 XML 文档,其方式与检索 HTML 文档是一样的。这样使得处理 XML 文档变得相当地容易,并且把内容和数据集成到了您的 Web 站点里面。[URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list6]清单 6[/URL] 显示了 success 函数的一个扩展,它为 XML 中的每个 <item> 元素都添加了一个列表项到 Web 页面中。


    清单 6. 使用 jQuery 处理 XML 文档
                    
    success: function(xml){
        $(xml).find('item').each(function(){
            var item_text = $(this).text();

            $('<li></li>')
                .html(item_text)
                .appendTo('ol');
        });
    }


      

    为 HTML 添加动画

    可以使用 jQuery 处理基本的动画和显示效果。animate() 函数是动画代码的核心,它用于更改任何随时间变化的数值型的 CSS 样式值。比方说,您可以变化高度、宽度、不透明度和位置。还可以指定动画的速度,定为毫秒或者预定义的速度:慢速,中速或快速。

    下面是一个同时变化某个元素高度和宽度的示例。请注意,这些参数没有开始值,只有最终值。开始值取自元素的当前尺寸。同时我也附加了一个回调函数。

    $('#grow').animate({ height: 500, width: 500 }, "slow", function(){
        alert('The element is done growing!');
    });


    jQuery 的内置函数使更多常见的动画更容易完成。可以使用 show() 和 hide() 元素,立即显示或者以特定的速度显示。还可以通过使用 fadeIn() 和 fadeOut(),或者 slideDown() 和 slideUp() 显示和隐藏元素,这取决于您所需要的显示效果。下面的示例定义了一个下滑的导航菜单。

    $('#nav').slideDown('slow');


      

    DOM 脚本和事件处理

    或许 jQuery 最擅长的就是简化 DOM 脚本和事件处理。遍历和处理 DOM 非常简单,同时附加、移除和调用事件也十分容易,且不像手动操作那样容易出错。

    从本质上说,jQuery 可以使 DOM 脚本中的常用操作变得更加容易。您可以创建元素并且使用 append() 函数把它们与其它的一些元素链接到一起,使用 clone() 复制元素,使用 html() 设置内容,使用 empty() 函数删除内容,使用 remove() 函数删除所有的元素,即便是使用 wrap() 函数,用其他元素将这些元素包装起来。

    通过遍历 DOM,一些函数可以用于更改 jQuery 对象本身的内容。可以获得元素所有的 siblings()、parents() 和 children()。还可以选择 next() 和 prev() 兄弟元素。find() 函数或许是功能最强大的函数,它允许使用 jQuery 选择器搜索 jQuery 对象中元素的后代元素。

    如果结合使用 end() 函数,那么这些函数将变得更加强大。这个函数的功能类似于 undo 函数,用于返回到调用 find() 或 parents() 函数(或者其它遍历函数)之前的 jQuery 对象。

    如果配合方法链接(method chaining)一起使用,这些函数可以使复杂的操作看上去非常简单。[URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#list7]清单 7 [/URL]显示了一个示例,其中包含有一个登录表单并处理了一些与之有关的元素。


    清单 7. 轻松地遍历和处理 DOM
                    
    $('form#login')
        // hide all the labels inside the form with the 'optional' class
        .find('label.optional').hide().end()

        // add a red border to any password fields in the form
        .find('input:password').css('border', '1px solid red').end()

        // add a submit handler to the form
        .submit(function(){
            return confirm('Are you sure you want to submit?');
        });


    不管您是否相信,这个示例只是一行满是空白的被链接的代码。首先,选择登录表单。然后,发现其中含有可选标签,隐藏它们,并调用 end() 返回表单。然后,我创建了密码字段,将其边界变为红色,再次调用 end() 返回表单。最后,我在表单中添加了一个提交事件处理程序。其中尤为有趣的就是(除了其简洁性以外),jQuery 完全优化了所有的查询操作,确保将所有内容很好地链接在一起后,不需要对一个元素执行两次查询。

    处理常见事件就像调用函数(比方说 click()、submit() 或 mouseover())和为其传递事件处理函数一样简单。此外,还可以使用 bind('eventname', function(){}) 指定自定义的事件处理程序。可以使用 unbind('eventname') 删除某些事件或者使用 unbind() 删除所有的事件。有关这些函数的使用方法的完整列表,请参阅 [URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#resources]参考资料[/URL] 中的 jQuery 应用程序编程接口(Application Program Interface,API)文档。


      

    释放 jQuery 选择器的强大能量

    我们经常会使用 ID 来选择元素,比如 #myid,或者通过类名,比如 div.myclass 来选择元素。然而,jQuery 提供了更为复杂和完整的选择器语法,允许我们在单个选择器中选择几乎所有的元素组合。

    jQuery 的选择器语法主要是基于 CSS3 和 XPath 的。对 CSS3 和 XPath 了解的越多,使用 jQuery 时就越加得心应手。有关 jQuery 选择器的完整列表,包括 CSS 和 XPath,请参阅 [URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#resources]参考资料[/URL] 中的链接。

    CSS3 包含一些并不是所有浏览器都支持的语法,因此我们很少使用它。然而,我们仍然可以在 jQuery 中使用 CSS3 选择元素,因为 jQuery 具备自己的自定义选择器引擎。比方说,要在表格中的每一个空列中都添加一个横杠,可以使用::empty 伪选择器(pseudo-selector):

    $('td:empty').html('-');


    如果需要找出所有含特定类的元素呢? CSS3 同样提供了一个语法可以完成这个目的,使用 :not 伪选择器: 如下代码显示了如何隐藏所有不含 required 类的输入内容:

    $('input:not(.required)').hide();


    与在 CSS 中一样,可以使用逗号将多个选择器连接成一个。下面是一个同时隐藏页面上所有类型列表的简单示例:

    $('ul, ol, dl').hide();


    XPath 是一种功能强大的语法,用于在文档中搜寻元素。它与 CSS 稍有区别,不过它能实现的功能略多于 CSS。要在所有复选框的父元素中添加一个边框,可以使用 XPath 的 /.. 语法:

    $("input:checkbox/..").css('border', '1px solid #777');


    jQuery 中也加入了一些 CSS 和 XPath 中没有的选择器。比方说,要使一个表更具可读性,通常可以在表格的奇数行或偶数行中附加一个不同的类名 —— 也可以称作把表分段(striping)。使用 jQuery 不费吹灰之力就可以做到这点,这需要归功于 odd 伪选择器。下面这个例子使用 striped 类改变了表格中所有奇数行的背景颜色:

    $('table.striped > tr:odd').css('background', '#999999');


    我们可以看到强大的 jQuery 选择器是如何简化代码的。不论您想处理什么样的元素,不管这个元素是具体的还是模糊的,都有可能找到一种方法使用一个 jQuery选择器对它们进行定义。


      

    使用插件扩展 jQuery

    与大多数软件不同,使用一个复杂的 API 为 jQuery 编写插件并不是非常困难。事实上,jQuery 插件非常易于编写,您甚至希望编写一些插件来使代码更加简单。下面是可以编写的最基本的 jQuery 插件:

    $.fn.donothing = function(){
        return this;
    };


    虽然非常简单,但是还是需要对这个插件进行一些解释。首先,如果要为每一个 jQuery 对象添加一个函数,必须把该函数指派给 $.fn。第二,这个函数必须要返回一个 this(jQuery 对象),这样才不至于打断 [URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#chaining]方法链接(method chaining)[/URL]。

    可以轻松地在这个示例之上构建。要编写一个更换背景颜色的插件,以替代使用 css('background'),可以使用下面的代码:

    $.fn.background = function(bg){
        return this.css('background', bg);
    };


    清注意,可以只从 css() 返回值,因为已经返回了 jQuery 对象。因此,方法链接(method chaining)仍然运作良好。

    我建议在需要重复工作的时候使用 jQuery 插件。比方说,如果您需要使用 each() 函数反复执行相同的操作,那么可以使用一个插件来完成。

    由于 jQuery 插件相当易于编写,所以有上百种可供你选择使用。jQuery 提供的插件可用于制表、圆角、滑动显示、工具提示、日期选择器,以及我们可以想到的一切效果。有关插件的完整列表,请参阅 [URL=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html#resources]参考资料[/URL]。

    最为复杂、使用最为广泛的插件要属界面(Interface),它是一种动画插件,用于处理排序、拖放功能、复杂效果、以及其它有趣和复杂的用户界面(User Interface,UI)。界面对于 jQuery 来说就如 Scriptaculous 对于 Prototype 一样。

    表单插件也同样流行且非常有用,通过它可以使用 Ajax 在后台中轻松地提交表单。这个插件用于处理一些常见的情况:您需要截获某个表单的提交事件,找出所有不同的输入字段,并使用这些字段构造一个 Ajax 调用。


      

    结束语

    分享这篇文章……


    [URL=http://digg.com/submit?phase=2&url=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html]按此在新窗口浏览图片 [/URL] [URL=http://digg.com/submit?phase=2&url=http://www.ibm.com/developerworks/cn/xml/x-ajaxjquery.html]将本文提交到 Digg[/URL]  

    [URL=http://del.icio.us/post]按此在新窗口浏览图片 [/URL] [URL=http://del.icio.us/post]发布到 del.icio.us[/URL]  

    [URL=http://slashdot.org/bookmark.pl?url=]按此在新窗口浏览图片 [/URL] [URL=http://slashdot.org/bookmark.pl?url=]提交到 Slashdot! [/URL]



    我只是简要地介绍了使用 jQuery 可能完成的任务。jQuery 使用起来非常有趣,因此我们总是能学到看上去很简单的新技巧和新特性。从刚开始使用 jQuery 的那一刻起,jQuery 便可以完全简化您的 JavaScript 和 Ajax 编程;每学会一点新知识,您的代码就会更简单一点。

    学习了 jQuery 之后,我在使用 JavaScript 语言进行编程的同时也获得了许多的乐趣。不用操心所有无聊的内容,我可以专注地编写有趣的内容。使用 jQuery 后,我几乎就告别了编写 for 循环代码的时代。甚至在想到要使用其它 JavaScript 库时,不禁会有所畏缩不前。jQuery 确确实实改变了我对 JavaScript 编程的看法。


    参考资料

    学习

    您可以参阅本文在 developerWorks 全球网站上的 [URL=http://www.ibm.com/developerworks/xml/library/x-ajaxjquery.html?S_TACT=105AGX52&S_CMP=cn-a-x]英文原文[/URL]。


    [URL=http://www.ibm.com/developerworks/cn/xml]developerWork 中国网站 XML 专区[/URL]:了解 XML 的方方面面。


    [URL=http://docs.jquery.com/Main_Page]jQuery API 文档[/URL]:通过一些教程和 API 参考资料的链接,研究完整的 jQuery 的文档。


    [URL=http://docs.jquery.com/Tutorials]jQuery 教程[/URL]:参阅各种不同语言的 jQuery 教程,包括 40 篇英语文章。


    [URL=http://visualjquery.com/]可视化 jQuery[/URL]:阅读这个交互式的、易于导航的 jQuery API 参考资料。


    [URL=http://www.ibm.com/certify/certs/xmsdreltop.shtml?S_TACT=105AGX52&S_CMP=cn-a-x]IBM XML 认证[/URL]:看看如何才能成为一名 IBM 认证的 XML 及相关技术的开发人员。


    [URL=http://www.ibm.com/developerworks/cn/xml/library/technical/xml.html]XML 技术文档库[/URL]:developerWorks XML 专区提供了大量技术文章、提示、教程、标准以及 IBM 红皮书。

    获得产品和技术

    [URL=http://jquery.com/]jQuery[/URL]:访问 jQuery 主页并下载源代码。


    [URL=http://docs.jquery.com/DOM/Traversing/Selectors]选择器[/URL]:获取在 jQuery 中可以使用的选择器的完整列表,包括 CSS3 和 XPath 选择器。


    [URL=http://docs.jquery.com/Plugins]jQuery 插件[/URL]:获取可以使用的 jQuery 插件的完整列表。


    [URL=http://interface.eyecon.ro/]Interface[/URL]:尝试使用 jQuery 最基本的插件,可用于动画、显示效果、拖放功能和用户界面(UI)。


    [URL=http://jquery.com/dev/svn/trunk/plugins/form/form.js?format=txt]Form 插件[/URL]:获取 jQuery 插件,它可用于使用 Ajax 提交表单。

    讨论

    [URL=http://jquery.com/blog/]jQuery 博客[/URL]:有关 jQuery 的日常新闻和更新,请经常访问官方的 jQuery blog。


    [URL=http://www.ibm.com/developerworks/forums/dw_xforums.jsp]XML 专区讨论论坛[/URL]:参与任何以 XML 为中心的论坛。

    关于作者


    按此在新窗口浏览图片
      Jesse Skinner 是一名自由的 Web 开发人员,致力于 JavaScript 和 CSS 的开发。他从加拿大移居到德国,主要研究如何使 Web 使用起来更加有趣,并解开了由来已久的 CSS 浏览器兼容性难题。如果想进一步了解 Jesse 或者阅读更多有关 Web 开发的内容,请参阅他的博客 [URL=http://www.thefutureoftheweb.com/]The Future of the Web[/URL]。


    对本文的评价

       
    太差! (1)
    需提高 (2)
    一般;尚可 (3)
    好文章 (4)
    真棒!(5)

    建议?



      


      

    Java 和所有基于 Java 的商标是 Sun Microsystems,Inc 在美国和/或其他国家的商标。 其他公司、产品或服务的名称可能是其他公司的商标或服务标志。

    IBM 公司保留在 developerWorks 网站上发表的内容的著作权。未经IBM公司或原始作者的书面明确许可,请勿转载。如果您希望转载,请通过 提交转载请求表单 联系我们的编辑团队。

        [URL=http://www.ibm.com/cn/ibm/index.shtml]关于 IBM[/URL]      [URL=http://www.ibm.com/cn/ibm/privacy/index.shtml]隐私条约[/URL]      [URL=http://www.ibm.com/contact/]联系 IBM[/URL]


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    存在即是被搜索!

    BLOG =>  http://www.OpenJ.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/5/26 16:19:00
     
     Qr 帅哥哟,离线,有人找我吗?
      
      
      威望:9
      等级:博士二年级(版主)
      文章:4392
      积分:29981
      门派:XML.ORG.CN
      注册:2004/5/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Qr发送一个短消息 把Qr加入好友 查看Qr的个人资料 搜索Qr在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 访问Qr的主页 引用回复这个贴子 回复这个贴子 查看Qr的博客2
    发贴心情 
    GOOD!MARK!

    ----------------------------------------------
    没人帮忙,那就靠自己,自己才是最好的老师!本人拒绝回答通过站内短消息提出的问题!

    blog:http://Qr.blogger.org.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/5/26 22:38:00
     
     hjx_221 帅哥哟,离线,有人找我吗?
      
      
      威望:7
      等级:博士一年级
      文章:4607
      积分:24021
      门派:XML.ORG.CN
      注册:2004/8/30

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hjx_221发送一个短消息 把hjx_221加入好友 查看hjx_221的个人资料 搜索hjx_221在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hjx_221的博客3
    发贴心情 
    well done!!

    once more!!

    ----------------------------------------------
    初从文,三年不中;后习武,校场发一矢,中鼓吏,逐之出;遂学医,有所成。自撰一良方,服之,卒~ 
    http://hjx221.blogger.org.cn/

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/7/14 14:13:00
     
     goalbell 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:1
      积分:65
      门派:XML.ORG.CN
      注册:2006/8/31

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给goalbell发送一个短消息 把goalbell加入好友 查看goalbell的个人资料 搜索goalbell在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 引用回复这个贴子 回复这个贴子 查看goalbell的博客4
    发贴心情 
    学习,关注中!
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/7/31 11:50:00
     
     yf0888 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:5
      积分:78
      门派:XML.ORG.CN
      注册:2006/5/29

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给yf0888发送一个短消息 把yf0888加入好友 查看yf0888的个人资料 搜索yf0888在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 引用回复这个贴子 回复这个贴子 查看yf0888的博客5
    发贴心情 
    good
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/8/17 14:29:00
     
     flyfoxs 帅哥哟,离线,有人找我吗?
      
      
      威望:5
      等级:研一(Artificial Intelligence期期不放过)
      文章:550
      积分:3935
      门派:XML.ORG.CN
      注册:2005/1/8

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给flyfoxs发送一个短消息 把flyfoxs加入好友 查看flyfoxs的个人资料 搜索flyfoxs在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 引用回复这个贴子 回复这个贴子 查看flyfoxs的博客6
    发贴心情 
    以前只是随便看了一下,突然看到这个帖子觉得好亲切,仔细一看居然是我转帖的,好亲切。


    最近又开始仔细学习了一下, 这个和prototype有得比,如果两个都没学过,想学一个比较好用的JS框架,建议先学习jQuery.

    ----------------------------------------------
    存在即是被搜索!

    BLOG =>  http://www.OpenJ.cn

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/8/18 23:23:00
     
     chinaxmlorg 帅哥哟,离线,有人找我吗?魔羯座1984-1-7
      
      
      等级:大一新生
      文章:5
      积分:72
      门派:XML.ORG.CN
      注册:2007/8/20

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给chinaxmlorg发送一个短消息 把chinaxmlorg加入好友 查看chinaxmlorg的个人资料 搜索chinaxmlorg在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 引用回复这个贴子 回复这个贴子 查看chinaxmlorg的博客7
    发贴心情 
    学习````

    ----------------------------------------------
    [size=5][url=http://www.cimgoo.com/][color=red][b]网 络营销www.cimgoo.com[/b][/color][/url][/size]

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/8/20 10:57:00
     
     GoogleAdSense魔羯座1984-1-7
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 HTML/XHTML/Ajax/Web 2.0/Web 3.0 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/6/23 0:43:54

    本主题贴数7,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    125.000ms