从零开始学习jQuery (十一) 实战表单验证与自动完成提示插件

本系列文章导航

从零开始学习jQuery (一) 开天辟地入门篇

从零开始学习jQuery (二) 万能的选择器

从零开始学习jQuery (三) 管理jQuery包装集

从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式

从零开始学习jQuery (五) 事件与事件对象

从零开始学习jQuery (六) jQuery中的Ajax

从零开始学习jQuery (七) jQuery动画-让页面动起来!

从零开始学习jQuery (八) 插播:jQuery实施方案

从零开始学习jQuery (九) jQuery工具函数

从零开始学习jQuery (十) jQueryUI常用功能实战

从零开始学习jQuery (十一) 实战表单验证与自动完成提示插件

 

一.摘要

本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,  即使你会使用jQuery也能在阅读中发现些许秘籍.

本文是介绍两个最常用的jQuery插件. 分别用于表单验证和自动完成提示(类似google suggest).

 

二.前言

研究别人的作品真是一件花时间而且痛苦的过程. 当然也和本人英文不好有关. 总觉得控件作者写了很多文档但是都不够系统, 需要深入研究很多的实例后才能了解作者的思路.所以学习和研究一个插件需要很高成本, 如果发现了Bug并修复需要的成本也是未知数(本次我花了较少的时间解决了自动完成提示插件的一个中文bug, 但是如果复杂的bug就不会这么简单了.).

对于简单应用我首先推荐上文中的jQuery UI. 但是jQuery UI解决的问题有限. 使用jQuery插件是我们最后的一个好办法---还算是好办法, 起码比自己开发要好吧?

很多jQuery的插件编码异常优美, 看一看艺龙首页现在的城市输入框控件, 除了需要为输入框手工添加很多很多属性(onkeyup, onkeydown等等), 而且还不够通用, 占用服务器资源和网络资源.但是当初也是花费了很久的时间完成的作品.

站在巨人的肩膀上, 让我感觉写脚本和写设计C#程序一样, 都有高度和深度可以挖掘. 除了使用作者开发好的功能, 还可以学习如何开发和封装javascript控件. 看过优秀的jQuery插件作者的代码和设计思想后, 常常自叹设计水平差距居然如此之大, 增加自认为脚本高手, 比较过后就是C#程序员和架构师之间的差距.

希望大家通过本章节介绍的两个插件, 除了学会如何使用,  还能够略微领悟到如何封装和设计javascript控件.

 

三.表单验证插件 validate

在提交表单前常要对用户输入进行校验.ASP.NET的验证控件就是用于此目的, 可以同时进行客户端和服务器端验证. 但是验证控件并没有被所有项目采用. 而且在MVC项目中经常使用自己的客户端验证框架.

在比较了若干表单验证插件后, 决定采用validate插件. 因为其使用简单并且灵活.

插件首页:

http://bassistance.de/jquery-plugins/jquery-plugin-validation/

插件文档:

http://docs.jquery.com/Plugins/Validation

配置说明:

http://docs.jquery.com/Plugins/Validation/validate#options

1.应用实例

实例效果:

image

实例代码:

<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
    <title>jQuery PlugIn - 表单验证插件实例 Validate </title>
    <!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader-->
    <link rel="stylesheet" type="text/css" href="<%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%>" />
    <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/jquery-min-lastest.js"></script>
    <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"></script>
    <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/plugin/jquery.validate/jquery.validate.min.js"></script>
    <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/plugin/jquery.validate/localization/messages_cn.js"></script>
        
    <% if (false)
       {%><script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"></script>
    <% }%>
    <script type="text/javascript">
        /*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/
    </script>
    <style type="text/css">
        body
        {
            font-size:12px;
        }
        /* form中显示文字的label */
        .slabel
        {
            width:100px;
            display: -moz-inline-box;
            line-height: 1.8;
            display: inline-block;
            text-align:right;
        }
        /* 出错样式 */
        input.error, textarea.error
        {
            border: solid 1px #CD0A0A;
        }
        label.error
        {
            color:#CD0A0A;
            margin-left:5px;
        }
        /* 深红色文字 */
        .textred
        {
            color:#CD0A0A;
        }
    </style>
</head>
<body>
    <form id="commentForm" method="get" action="">
    <fieldset style="width:500px;"><legend>表单验证</legend>
        <p><label for="cname" class="slabel"><em class="textred">*</em> 姓名:</label>
            <input id="cname" name="name" size="25" class="required" minlength="2" />
        </p>
        <p><label for="cemail" class="slabel"><em class="textred">*</em> E-Mail:</label>
            <input id="cemail" name="email" size="25"/>
        </p>
        <p><label for="curl" class="slabel">网址:</label>            
            <input id="curl" name="url" size="25" class="url" value="" />
        </p>
        <p><label for="ccomment" class="slabel"><em class="textred">*</em> 内容:</label>
            <textarea rows="2" id="ccomment" name="comment" cols="20" class="required" style="height:80px;"></textarea>
        </p>
        <p style="text-align:center;">
            <input class="submit" type="submit" value="提交" />
        </p>
    </fieldset>
    </form>
    <script type="text/javascript">
       /*==========用户自定义方法==========*/


       /*==========事件绑定==========*/
       $(function()
       {

       });

       /*==========加载时执行的语句==========*/
       $(function()
       {
           $("#commentForm").validate(
           {
               errorClass: "error",
               submitHandler: function(form)
               {
                   //如果想提交表单, 需要使用form.submit()而不要使用$(form).submit()
                   alert("submitted!");
               },
               rules: {
                   //为name为email的控件添加两个验证方法:required()和email()
                   email: { required: true, email: true }
               },
               messages: {
                   //为name为email的控件的required()和email()验证方法设置验证失败的消息内容
                   email: {required:"需要输入电子邮箱", email:"电子邮箱格式不正确"}
               }

           });
       });        
    </script>
</body>
</html>

 

2. 实例讲解

(1) 验证方法

验证方法是验证某一个控件是否满足某些规则的方法, 返回一个boolean值. 比如email( ) 方法验证内容是否符合email格式, 符合则返回true. 下面是类库中email方法的源代码:

        // http://docs.jquery.com/Plugins/Validation/Methods/email
        email: function(value, element) {
            // contributed by Scott Gonzalez: http://projects.scottsplayground.com/email_address_validation/
            return this.optional(element) || /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i.test(value);
        },

我们在:

http://docs.jquery.com/Plugins/Validation

中的 List of built-in Validation methods 一节中列出了所有内置的验证方法. 同时插件还提供了additional-methods.js 文件, 里面包含了更多的验证方法, 引入后既可启用.

(2) 验证消息

验证消息就是验证方法失败后显示的文字内容. 验证消息一定关联在某一个验证方法上, 并且全局的验证消息保存在jQuery.validator.messages 属性中.

默认的validate类库自带英文验证消息:

    messages: {
        required: "This field is required.",    
        //...    
});


上面说明当required验证方法验证失败是, 显示"This field is required."这条消息.

在下载文件的localization文件夹中, 包含了各国语言的基本验证消息, 如同本实例一样引入不同的语言文件即可实现语言切换:

<script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/plugin/jquery.validate/localization/messages_cn.js"></script>

语言文件的内容举例:

jQuery.extend(jQuery.validator.messages, {
        required: "必选字段",
        //...
});

 

现在必填项的问题提示就变成了中文.

除了全局默认的验证消息, 也可以为某一个表单元素设置特有的验证消息, 比如本文实例中, 为email元素设置了特有的验证消息:

               messages: {
                   //为name为email的控件的required()和email()验证方法设置验证失败的消息内容
                   email: {required:"需要输入电子邮箱", email:"电子邮箱格式不正确"}

 

options的messages属性可以针对某一个表单元素设置验证消息, 第一个email表示email元素, 值是一个集合, required就表示required验证函数, 第二个email表示是email验证函数.

(3)验证规则

验证规则就是这样的语意语句: 在元素A上, 使用 验证方法A 和 验证方法B 进行验证.

验证规则将元素与验证方法关联起来, 因为验证方法同时也关联了验证消息, 所以元素与消息也关联了起来.

为一个元素添加验证规则有多种方式.

本实例的"姓名"元素使用了CSS样式规则和元素属性规则:

<input id="cname" name="name" size="25" class="required" minlength="2" />

class元素属性设置元素的CSS样式类, 因为样式类中添加了required类,  所以会和required()验证函数关联. 这种规则叫做CSS样式规则.

minlength元素属性也会自动和minlength()验证函数关联, 这种规则叫做元素属性规则.

另外还可以通过编程的方式进行关联:

               rules: {
                   //为name为email的控件添加两个验证方法:required()和email()
                   email: { required: true, email: true }
               },

上面的语句表名为email表单对象添加了required()和email()验证函数.

(4)  表单提交

默认情况下, 当验证函数失败时表单不会提交.

但是可以通过添加class="cancel"的方式让提交按钮跳过验证:

<input type="submit" class="cancel" name="cancel" value="Cancel" />


当表单提交时, 会触发options中submitHandler属性设置的函数:

               submitHandler: function(form)
               {
                   //如果想提交表单, 需要使用form.submit()而不要使用$(form).submit()
                   alert("submitted!");
               },

此函数的签名同上.  我们可以在这个函数中,  编写在表单提交前需要处理的业务逻辑.

需要注意当最后以编程的方式提交表单时, 一定不要使用jQuery对象的submit()方法, 因为此方法会触发表单验证,并且再次调用submitHandler设置的函数, 会导致递归调用.

此函数的参数form就是表单对象, 用途就是不进行验证提交表单:form.submit()

(5) DEBUG模式

在开发阶段我们通常不希望表单被真正提交,  虽然可以通过本实例中重写submitHandler函数来实现, 但是还有更好的方式, 我们可以在submitHandler函数完成正式提交的逻辑, 然后通过设置options的debug属性, 来达到即使验证通过也不会提交表单的目的:

$(".selector").validate({
   debug: true
})

(6) 多表单验证

有时会在一个页面上出现多个Form, 因为validate控件是针对form对象进行包装的, 所以我们可以控制哪些form对象需要验证.

同时为了方便一次设置页面上所有的应用了validate控件的form对象,  提供了 jQuery.validator.setDefaults 函数让我们可以一次设置所有的默认值:

jQuery.validator.setDefaults({ 
    debug: true 
});

 

 

四.自动完成插件 autocomplete

autocomplete插件能帮助我们实现类似于Google Suggest的效果:

image

插件首页:

http://bassistance.de/jquery-plugins/jquery-plugin-autocomplete/

插件文档:

http://docs.jquery.com/Plugins/Autocomplete

配置说明:

http://docs.jquery.com/Plugins/Autocomplete/autocomplete#toptions

1.应用实例

本实例演示的是使用autocomplete完成对输入城市的自动提示效果,如图:

image

实例代码:

<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
    <title>jQuery PlugIn - 自动完成插件实例 AutoComplete </title>
    <!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader-->
    <link rel="stylesheet" type="text/css" href="<%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%>" />
    <link rel="stylesheet" type="text/css" href="<%=WebConfig.ResourceServer +"/JsLib/jquery/plugin/jquery.autocomplete/jquery.autocomplete.css"%>" />
    <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/jquery-min-lastest.js"></script>
    <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"></script>
    <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/plugin/jquery.autocomplete/jquery.autocomplete.min.js"></script>
    <% if (false)
       {%><script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"></script>
    <% }%>
    <script type="text/javascript">
        /*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/
    </script>
    <style type="text/css">
        body
        {
            font-size: 12px;
        }
        
        .formLabel{float: left; width: 150px; text-align:right;}
        .formInput{float: left;}
    </style>
</head>
<body>
    <!-- Demo. 应用AutoComplete插件 -->
    <div class="ui-widget ui-widget-content ui-corner-all" style="width: 700px; padding: 5px;">
        <h3>
            Demo. 应用AutoComplete插件 </h3>
        <br style="clear: both" />
        <div class="formLabel">
            <label for="inputCityName">请输入城市拼音和汉字:</label>
        </div>
        <div class="formInput">
            <input id="inputCityName" name="inputCityName" type="text" />
        </div>
        <br style="clear:both" />
        <br style="clear: both" />
        <div class="formLabel">
            <label for="inputCityName">城市ID:</label></div>
        <div class="formInput">
            <input id="inputCityId" name="inputCityId" type="text" /></div>
        <br style="clear: both" />
        <br style="clear: both" />
    </div>
    <script type="text/javascript">
        /*==========用户自定义方法==========*/
        //城市数据
        var cityList;
        //autocomplete选项
        var options = {
            minChars: 1,
            max: 500,
            width: 250,
            matchContains: true,
            formatItem: function(row, i, max)
            {
                return i + "/" + max + ": \"" + row.CityNameEn + "\" [" + row.CityName + "]";
            },
            formatMatch: function(row, i, max)
            {
                return row.CityNameEn + " " + row.CityName;
            },
            formatResult: function(row)
            {
                return row.CityName;
            }            
        };
        //autocomplete初始化函数
        function initAutoComplete(data)
        {
            cityList = data;
            $("#inputCityName").autocomplete(cityList, options);
            $("#inputCityName").result(function(event, data, formatted)
            {
                $("#inputCityId").val(data.ElongCityId);
            });                    
        }


        /*==========事件绑定==========*/
        $(function()
        {
        });

        /*==========加载时执行的语句==========*/
        $(function()
        {
            //加载城市数据, 并在回调函数中用返回的数据初始化autocomplete
            $.getJSON("cityinfo.htm", null, initAutoComplete)  
        });        
    </script>
</body>
</html>

 

2. 实例讲解

(1)准备数据源

首先要准备实现自动建议的数据源. 本实例是通过发送Ajax请求获取JSON对象. autocomplete()方法支持两个参数, 第一个是data, 第二个是options.

其中data参数可以使本实例中的一个数据变量, 也可以是一个url. 如果是url则会每次都调用Ajax请求获取数据.

为了效率我倾向于在数据量允许的情况下, 在页面加载后使用Ajax获取全部的数据, 然后使用传递数据变量给autocomplete组件. 如实例中所示. 除非数据特别巨大无法再客户端加载,  则只能每次都使用发送Ajax请求从服务器端获取部分数据. 但是这会对服务器造成负担.

(2) 设置关键函数

虽然options是可选项, 但是对于我们的数据源cityList是一个多属性对象, 所以必须设置下面几个关键的配置项后才能够使用:

formatItem

对匹配的每一行数据使用此函数格式化, 返回值是显示给用户的数据内容.

函数签名:

function(row, rowNum, rowCount, searchItem)

参数说明:

row: 当前行. the results row,

rowNum: 当前行号,从1开始.(注意不是索引,索引从0开始) the position of the row in the list of results (starting at 1),

rowCount: 总的行号 the number of items in the list of results

searchItem: 查询使用的数据, 即formatMatch函数返回的数据格式的内容. 我们在formatMatch函数中会设置程序内部搜索时使用的数据格式,这个格式和给用户展示的数据是不同的.

formatMatch

对每一行数据使用此函数格式化需要查询的数据格式. 返回值是给内部搜索算法使用的. 实例中用户看到的匹配结果是formatItem中设置的格式, 但是程序内部其实只搜索城市的英文和中文名称, 搜索数据在formatMatch中定义:

return row.CityNameEn + " " + row.CityName;


函数签名:

function(row, rowNum, rowCount,)

参数说明同上

formatResult

此函数是用户选中后返回的数据格式. 比如实例中只返回城市名给input控件:

return row.CityName;


函数签名:

function(row, rowNum, rowCount,)

参数说明同上

(3) 为控件添加Result事件函数

上面3个函数无法实现这类要求: 虽然只返回城市名称, 但是查询时使用城市ID, 选中一个城市后需要将城市ID存储在一个隐藏域中.

所以autocomplete控件提供了result事件函数, 此事件会在用户选中某一项后触发:

            $("#inputCityName").result(function(event, data, formatted)
            {
                $("#inputCityId").val(data.ElongCityId);
            }); 

函数签名:

function(event, data, formatted)

参数列表:

Result事件会为绑定的事件处理函数传递三个参数:

event: 事件对象. event.type为result.

data: 选中的数据行.

formatted:   虽然官方的解释应该是formatResult函数返回的值, 但是实验结果是formatMatch返回的值. 在本实例为: "Beijing  北京".

(4) 匹配中文

当前版本的autocomplete控件对中文搜索存在Bug, 原因是其搜索事件绑定在keydown事件上, 当使用中文输入法输入"北"字时没有任何提示. 我对原库做了修改, 将keydown事件修改为keyup事件, 即可完成对中文的智能提示搜索. 另外主要需要将"matchContains"配置项设置为"true", 因为我们的搜索格式是"Beijing 北京", 默认只匹配开头的字符.

(5) 更多配置项

关于更多的配置项, 请参考官方文档:

http://docs.jquery.com/Plugins/Autocomplete/autocomplete#toptions

(6) 更多事件

除了上面介绍的autocomplete()和result()函数, 还有如下函数:

search( ) : 激活search事件

flushCache( ) : 清空缓存

setOptions( options ) : 设置配置项

 

五.总结

本文详细介绍了表单验证插件和自动完成插件, 目前大家可以搜索到很多的插件应用, 或者上千的插件列表, 但是却找不到详细的使用文档. 插件用起来简单但是真正的灵活应用却不容易, 除了要翻越英文文档学习基本的使用, 还要花很长时间了解各个参数的作用, 如何配合使用等. 并且在上面做二次开发的难度相对较大, 插件的核心代码多没有注释并且复杂,  要在其中寻找逻辑关系要花费很多时间和精力. 本文介绍的两个插件更多的细节请参考官方文档, 地址都在一开始为大家提供了.

后续文章我决定先进行jQuery技巧和javascript必备知识的讲解,  我们很少开发自定义插件所以将开发插件篇放在最后.

 

本章节代码下载:

http://files.cnblogs.com/zhangziqiu/Code-jQueryStudy-11.rar

作者:张子秋
出处:http://www.cnblogs.com/zhangziqiu/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
posted @ 2009-05-22 11:35 ziqiu.zhang 阅读(23869) 评论(71) 编辑 收藏

 回复 引用   
#1楼 2009-05-22 11:47 封Ja葬va
忍不住注册登录就为此3个字--"写的好",
收益非浅啊。

 回复 引用 查看   
#2楼 2009-05-22 11:51 qnfng      
希望楼主能有些插件开发的文章......
 回复 引用 查看   
#3楼 2009-05-22 12:01 MyCoolDog      
赞~学习
 回复 引用 查看   
#4楼 2009-05-22 12:26 vieri122      
每章必看,写的真不错,希望楼主继续
 回复 引用 查看   
#5楼 2009-05-22 14:23 zoti      
不錯,支持樓主。
 回复 引用 查看   
#6楼 2009-05-22 14:27 斯克迪亚      
这一系列都是经典中的经典
 回复 引用 查看   
#7楼[楼主] 2009-05-22 15:11 ziqiu.zhang      
@封Ja葬va
@MyCoolDog
@vieri122
@zoti
@斯克迪亚
谢谢支持! 你们的支持是我写下去的动力啊!

 回复 引用 查看   
#8楼[楼主] 2009-05-22 15:14 ziqiu.zhang      
@qnfng
开发插件相对比较高级一些, 尤其是需要手工处理很多的跨浏览器问题. 我想循序渐进的学习, 先从优化jQuery, 提高自身使用jQuery的水平. 然后再介绍插件开发.

 回复 引用 查看   
#9楼 2009-05-22 15:23 一线风      
不错,Mark一下.
 回复 引用 查看   
#10楼 2009-05-22 16:06 菌哥      
请教LZ一个问题,如果我在某个元素上绑定了click事件,当我下次再绑定事件的时候,能否检测此元素上已经绑定了哪个事件,如何遍历这些事件?
因为有的元素的事件只需绑定一次,防止重复绑定

 回复 引用 查看   
#11楼 2009-05-22 17:55 坤坤      
受益匪浅,谢谢子秋!
 回复 引用   
#12楼 2009-05-22 18:04 Willis[未注册用户]
每章必学,
楼主辛苦了



 回复 引用 查看   
#13楼 2009-05-22 20:14 文明的天空      

 回复 引用 查看   
#14楼 2009-05-22 22:23 Leem      
表彰验证还是猫冬的fromValidater好用
 回复 引用   
#15楼 2009-05-22 22:31 testdb[未注册用户]
楼主乃社会之栋梁也!
 回复 引用 查看   
#16楼 2009-05-22 22:56 ilovedotnet      
楼主要坚持更新啊,这样大家才能一起进步啊!哈哈……
 回复 引用 查看   
#17楼[楼主] 2009-05-23 00:06 ziqiu.zhang      
@菌哥
你可以在绑定前, 先使用unbind("click")取消所有的click事件处理函数. 然后在bind("click")

 回复 引用 查看   
#18楼 2009-05-23 08:55 gc      
严重支持,你写的一系列我都会认真去看
 回复 引用   
#19楼 2009-05-23 11:41 cafe[未注册用户]
严重支持
 回复 引用 查看   
#20楼 2009-05-24 00:34 深山老林      
终于看到活的了呵呵。
 回复 引用   
#21楼 2009-05-24 10:35 无意中路过[未注册用户]
楼主文章写得这么好,打算从0学习jQuery了
 回复 引用 查看   
#22楼 2009-05-24 13:32 jay tian      
呵呵,子秋加油!支持这个系列!
 回复 引用   
#23楼 2009-05-25 16:49 封Ja葬va
我学习Jquery就是从你这开始的...
 回复 引用 查看   
#24楼 2009-05-25 22:23 叶宁      
支持博主
 回复 引用 查看   
#25楼[楼主] 2009-05-26 19:03 ziqiu.zhang      
@深山老林
活的好点吧.....不过我还对不上你是谁. 讨论的时候坐我旁边的那位?

 回复 引用 查看   
#26楼 2009-05-26 19:29 Silenus-G      
嗯嗯~~没得说哦,学习,支持。
 回复 引用 查看   
#27楼 2009-06-01 17:52 carelesswords      
我得加油了,快跟不上你的速度了
 回复 引用 查看   
#28楼 2009-06-02 17:05 子风      
有用了一下,有时候能自能提示,有时候又不能,
环境:xp ,ie6,jquert 1.2.6,vs2005

不知道问题出在哪?

 回复 引用 查看   
#29楼 2009-06-03 10:47 子风      
搂住,单个的input我测试成功了!
现在我想实现这样的功能,在表格中实现自动完成。
在点击表格时候,插入一个input,但是在实际中碰到了问题,只有在第一个表格中能实现自动完成。其它的都失效了。我附上源码,请大家看看问题出在哪了?
-------------代码部分---------------------------
$(function(){

//---------点击td插入input-----------------------
var numTd= $(".input"); //取到所有要自动完成的td
var inputObj = $("<input type = 'text' id = 'tempInput' /> ").addClass("inputObj");

numTd.click(function(){
var tdObj = $(this);

if (tdObj.children("input").length >0){
return false;
}

var text = tdObj.html();
tdObj.html("");

inputObj .width(tdObj.width()) //给input添加样式
.val(text)
.appendTo(tdObj);
inputObj.trigger("focus").trigger("select");
inputObj.click(function(){
return false;
});


inputObj.keyup(function(event){
var keyCode = event.which;
if(keyCode ==13){
var inputText = $(this).val();
tdObj.html(inputText);
}
})

inputObj.blur(function(event){
tdObj.html($(this).val());
});


});
//--------点击td插入input-------------------------------------


//----input 自动完成功能-------------------
var cityList;
var options ={
minChars:1,
max:500,
width:250,
matchContains:true,
formatItem:function(row,rowNum,rowCount,searchItem){
return rowNum + "/" + rowCount + ": \"" + row.CityNameEn + "\" [" + row.CityName + "]";
},
formatMatch: function(row, rowNum, rowCount)
{
return row.CityNameEn + " " + row.CityName;
},
formatResult: function(row, rowNum, rowCount)
{
return row.CityName;
}
};

//autocomplete初始化函数
function initAutoComplete(data)
{
cityList = data;
inputObj.autocomplete(cityList, options);
inputObj.result(function(event, data, formatted){
inputObj.val(data.CityName);
});
}

$.getJSON("cityinfo.htm", null, initAutoComplete)

//-----input 自动完成功能-------------------
//------------------------


//--------------------
});

 回复 引用 查看   
#30楼 2009-06-05 17:28 子风      
我成功了,改了一下,每次点击td时候都要绑定数据库 initAutoComplete

谢谢搂住。

 回复 引用 查看   
#31楼 2009-06-15 14:29 oo縼箻ㄗs.鋒      
楼主的共享精神值大家学习。

在逐字逐句地看完这个帖子以后,我的心久久不能平静,震撼啊!为什么会有如此好的帖子?!我纵横网络blog多年,自以为再也不会有任何帖子能打动我,没想到今天看到了如此精妙绝伦的这样一篇帖子。
楼主,是你让我深深地理解了‘人外有人,天外有天’这句话。谢谢侬!
在看完这帖子以后,我没有立即回复,因为我生怕我庸俗不堪的回复会玷污了这网上少有的帖子。但是我还是回复了,因为觉得如果不能在如此精彩的帖子后面留下自己的网名,那我死也不会瞑目的!能够在如此精彩的帖子后面留下自己的网名是多么骄傲的一件事啊!楼主,请原谅我的自私!
我知道无论用多么华丽的辞藻来形容楼主您帖子的精彩程度都是不够的,都是虚伪的,所以我只想说一句:您的帖子太好看了!我愿意一辈子的看下去!
这篇帖子构思新颖,题材独具匠心,段落清晰,情节诡异,跌宕起伏,主线分明,引人入胜,平淡中显示出不凡的文学功底,可谓是字字珠玑,句句经典,是我辈应当学习之典范。
就小说艺术的角度而言,这篇帖子不算太成功,但它的实验意义却远远大于成功本身。正所谓:“一马奔腾,射雕引弓,天地都在我心中!”楼主真不愧为无厘界新一代的开山怪!
本来我已经对这个社区失望了,觉得这个社区没有前途了,心里充满了悲哀。但是看了你的这个帖子,又让我对社区产生了希望。是你让我的心里重新燃起希望之火,是你让我的心死灰复燃,是你拯救了我一颗拨凉拨凉的心!
本来我决定不会在社区回任何帖子了,但是看了你的帖子,我告诉自己这个帖子是一定要回的!这是百年难得一见的好贴啊!苍天有眼啊,让我在优生之年得以观得如此精彩绝伦的帖子!
楼主,你要继续努力啊!你是社区的希望啊!

 回复 引用 查看   
#32楼 2009-06-19 13:31 LeoXing      
希望可以多一些这样的实例教程!
 回复 引用   
#33楼 2009-06-19 15:24 johnson-qian[未注册用户]
怎么下载的实例报JS错误啊。
 回复 引用   
#34楼 2009-06-25 09:03 ddd[未注册用户]

ddddddddddddddddd
















ddddddddd

引用oo縼箻ㄗs.鋒:
楼主的共享精神值大家学习。
<br/>
<br/>在逐字逐句地看完这个帖子以后,我的心久久不能平静,震撼啊!为什么会有如此好的帖子?!我纵横网络blog多年,自以为再也不会有任何帖子能打动我,没想到今天看到了如此精妙绝伦的这样一篇帖子。
<br/>楼主,是你让我深深地理解了‘人外有人,天外有天’这句话。谢谢侬!
<br/>在看完这帖子以后,我没有立即回复,因为我生怕我庸俗不堪的回复会玷污了这网上少有的帖子。但是我还是回复了,因为觉得如果不能在如此精彩的帖子后面留下自己的网名,那我死也不会瞑目的!能够在如此精彩的帖子后面留下自己的网名是多么骄傲的一件事啊!楼主...

内心世界很丰富!

 回复 引用 查看   
#36楼 2009-07-22 21:03 missbillows      
下载您的实例,但是出现了错误,不能运行,可能是js错误,还请楼主解决。
 回复 引用   
#37楼 2009-08-06 11:00 allen-huang[未注册用户]
楼主,下载您的实例怎么运行不了啊
plugin-AutoComplete.aspx没有自动完成功能


验证的出现下面错误
行:83
Char:12
错误:对象不支持此属性或方法
代码:0

 回复 引用 查看   
#38楼 2009-08-13 16:07 AGPSky      
下载的实例怎么运行不了呢

 回复 引用   
#39楼 2009-08-27 16:54 o偶[未注册用户]
看到楼主这么好的文章不留下点什么都不好意思了```呵呵```楼主的文章写的太实用了````学了很多,也是刚学jq````顶下 ``期待更多的好文章。
 回复 引用 查看   
#40楼 2009-09-08 16:39 kevin.li      
学习,顶。。
 回复 引用 查看   
#41楼 2009-09-19 13:01 封Ja葬va      
怎么后续的文章不继续写了呢?
 回复 引用 查看   
#42楼 2009-09-27 16:58 清茶      
表单验证的那个 message_cn.js在哪里下载啊?
我找了很多地方都没有找到这个JS文件!是否能够发给我
谢谢!
Email:liuxinhuahao@163.com

 回复 引用   
#43楼 2009-10-16 09:54 zengchumin[未注册用户]
断断续续,终于把这个系列看完了。

子秋加油!!感激不尽!!

 回复 引用 查看   
#44楼 2009-11-05 20:25 彦斌      
今天下午到现在都一直在楼主地盘上学这个系列。
太棒了。tks
还有吗?

 回复 引用 查看   
#45楼 2009-11-29 19:10 YeanJay      
引用子风:我成功了,改了一下,每次点击td时候都要绑定数据库 initAutoComplete
<br/>
<br/>谢谢搂住。

你好这个在点击TD时候绑定数据库怎么操作

 回复 引用 查看   
#46楼 2009-12-10 21:44 itliyi      
弱弱的问楼主
<% if (false)
{%><script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"></script>
<% }%>
永远不成立 那还要这句话干什么?
还有动态设置js css路径是怎么回事?thanks

 回复 引用   
#47楼 2009-12-15 10:40 gsgsdgsdgsdgs[未注册用户]
@itliyi

为了智能提示


 回复 引用 查看   
#48楼 2009-12-24 11:01 边缘徘徊      
首先感谢博主能分享所学知识。刚接触Jquery,一直在看博主的文章,本章自动完成插件的实列,下载后一直不能成功运行。我看博主引用的JS。是通过<% =WebConfig.ResourceServer %>路径下的文件。是否文件已经更改或替换了。麻烦楼主告知。
 回复 引用 查看   
#49楼 2009-12-25 16:55 俊采星驰      
楼主真是太有才了!!顶顶!!!
 回复 引用 查看   
#50楼 2009-12-29 17:04 混世者      
最后一贴,必然要回
 回复 引用 查看   
#51楼 2010-01-16 10:52 ℡↘佐誡鑕懓      
大哥我怎么下载了源代码运行起来怎么什么都没有啊
样式什么都没有!

 回复 引用 查看   
#52楼 2010-03-03 15:47 Julian's Blog      
怎么可以动态的加载数据来匹配呢。
 回复 引用 查看   
#53楼 2010-03-05 17:32 念时      
<% =WebConfig.ResourceServer %> 有问题。。。

www.dotnetapi.com不能访问了!!!

请楼主更新一下吧。。。

我的邮箱:nianshi0531@163.com

 回复 引用 查看   
#54楼 2010-04-28 11:24 轻风随风      
感谢楼主贡献!
我在测试自动完成插件时遇到了汉字提示不出现的问题,按楼主的方法将控件的keydown事件该为keyup事件,这样汉字的提示问题解决了,但是在按Tab键切换时,由于其keydown事件触发了浏览器的默认动作(没能执行event.preventDefault();),这时就不会再执行绑定控件的keyup事件了,所以这种解决方法并不完美。但不知道有什么完美的解决方案。楼主有的话回复一下呀!

 回复 引用 查看   
#55楼 2010-04-29 14:27 三个代表      
谢谢楼主,不顶不行
 回复 引用 查看   
#56楼 2010-05-25 12:02 冰の酷龙      
花了一个上午的时间来看完这个系列的文章,非常感谢楼主的贡献精神,否则我还在那里啃jquery的api文档。也希望楼主能继续写作,为我等菜鸟少走弯路。
 回复 引用 查看   
#57楼 2010-07-01 17:43 djune      
引用冰の酷龙:花了一个上午的时间来看完这个系列的文章,非常感谢楼主的贡献精神,否则我还在那里啃jquery的api文档。也希望楼主能继续写作,为我等菜鸟少走弯路。

一个上午就看完一个系列。惭愧!

 回复 引用 查看   
#58楼 2011-04-25 17:11 jackdesk      
这个系列看了差不多,收获不浅啊,谢谢楼主
 回复 引用 查看   
#59楼 2011-06-21 14:10 -可乐      
从第一章一直看到这里,这种文章不顶真的是没道理了。。。。
 回复 引用 查看   
#60楼 2011-07-03 18:51 目标RE      
好文要顶,不知楼主的关于插件的开发出来没?
 回复 引用 查看   
#61楼 2011-08-09 16:28 caored      
从第一章一直看到这里,这种文章不顶真的是没道理了。。。。

 收获不浅啊,谢谢楼主

 回复 引用 查看   
#62楼 2011-08-10 14:21 caored      
<% =WebConfig.ResourceServer %> 有问题。。。

www.dotnetapi.com不能访问了!!!

请楼主更新一下吧。。。

 回复 引用 查看   
#63楼 2011-09-06 09:43 菠萝35      
楼主,请教个问题
为什么我没有引用vsdoc.js一样有智能提示啊

 回复 引用 查看   
#64楼 2011-09-06 11:48 mary.qu      
谢谢LZ,正在学jquery,真是太好,简单易懂,讲的太精辟了,比看书来的快多了,多谢多谢呀!
 回复 引用 查看   
#65楼 2011-10-28 16:53 豐滿理想      
太感谢了!希望能整理成文档,放到网上共享!
 回复 引用 查看   
#66楼 2011-11-02 14:51 miro      
@oo縼箻ㄗs.鋒
哥你的回复太牛逼了

 回复 引用   
#67楼 2011-11-14 14:46 香草[未注册用户]
我刚看到您代码。</br>
正在努力学习JQUERY。</br>
谢谢您努力写的代码和学习心得分享给大家。</br>
有一个问题就是:“http://www.dotnetapi.com/”这个网站已经不好使了。
代码就无效了。你懂的。

 回复 引用   
#68楼 2011-11-14 14:47 香草[未注册用户]
怎么办啊?下载脚本库的话,找不到啊。另外我不知道你里面有没有重新编写啊。
求教啊。
仙人

 回复 引用   
#69楼 2011-11-14 14:55 香草[未注册用户]
我搞定了。
换一个地址。(*^__^*) 嘻嘻
http://resource.elong.com
嘎嘎。嘎嘎

 回复 引用   
#70楼 2011-12-12 11:59 看灰机飞过[未注册用户]
顶顶更健康!
 回复 引用 查看   
#71楼 2012-02-03 16:57 long-2008      
在逐字逐句地看完这个帖子以后,我的心久久不能平静,震撼啊!为什么会有如此好的帖子?!我纵横网络blog多年,自以为再也不会有任何帖子能打动我,没想到今天看到了如此精妙绝伦的这样一篇帖子。
楼主,是你让我深深地理解了‘人外有人,天外有天’这句话。谢谢侬!
在看完这帖子以后,我没有立即回复,因为我生怕我庸俗不堪的回复会玷污了这网上少有的帖子。但是我还是回复了,因为觉得如果不能在如此精彩的帖子后面留下自己的网名,那我死也不会瞑目的!能够在如此精彩的帖子后面留下自己的网名是多么骄傲的一件事啊!楼主,请原谅我的自私!
我知道无论用多么华丽的辞藻来形容楼主您帖子的精彩程度都是不够的,都是虚伪的,所以我只想说一句:您的帖子太好看了!我愿意一辈子的看下去!
这篇帖子构思新颖,题材独具匠心,段落清晰,情节诡异,跌宕起伏,主线分明,引人入胜,平淡中显示出不凡的文学功底,可谓是字字珠玑,句句经典,是我辈应当学习之典范。
就小说艺术的角度而言,这篇帖子不算太成功,但它的实验意义却远远大于成功本身。正所谓:“一马奔腾,射雕引弓,天地都在我心中!”楼主真不愧为无厘界新一代的开山怪!
本来我已经对这个社区失望了,觉得这个社区没有前途了,心里充满了悲哀。但是看了你的这个帖子,又让我对社区产生了希望。是你让我的心里重新燃起希望之火,是你让我的心死灰复燃,是你拯救了我一颗拨凉拨凉的心!
本来我决定不会在社区回任何帖子了,但是看了你的帖子,我告诉自己这个帖子是一定要回的!这是百年难得一见的好贴啊!苍天有眼啊,让我在优生之年得以观得如此精彩绝伦的帖子!
楼主,你要继续努力啊!你是社区的希望啊!

发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 1486912 6ZgKv50VUHw=