今天在用Jquery改造之前的JS代码过程中,遇到了一个让我懵逼了三小时的问题。

问题的关键在 this 的使用。在这里与大家分享一下。并且分享一下我做表单提交的检查代码

错误代码如下:

$("form").submit(function () {
return checkName() && checkAge() && checkEmail() && checkQq();
})
// 验证姓名
$('#name').blur(checkName);
function checkName() {
// 验证姓名验证正则
var reg = /^[\u4E00-\u9FA5\uf900-\ufa2d·s]{2,20}$/;
var flag = reg.test($('#name').val());
if( !flag ){
$('#error_name').remove();
$(this).after("<p id='error_name' class='error_msg'>姓名格式不正确 </p>");
} else {
$('#error_name').remove();
}
return flag;
}

分析:

  • 这段代码在执行过程中,验证姓名的离焦事件是可以成功触发并执行监听器代码,
  • 然而提交事件在执行 checkName() 方法过程中,由于 $(this) 语句在执行过程中,this 对象指代的是并非Input标签对象。因此代码不能执行到 return 行。无法阻止表单提交。
  • 那提交事件执行 checkName 方法时,this指代的是什么呢?我们试着弹一下它:

    在代码中添加以下代码:

        alert("我是谁?"+this);
    $(this).after("<p id='error_name' class='error_msg'>姓名格式不正确 </p>");

    在离焦事件触发后,窗口弹出:



    而当提交事件触发后,窗口弹出:



    至此,问题就真相大白了。在提交事件触发时,监听器代码中 this 对象指代的是 window 对象,程序执行 after()会出异常。导致 return 语句不能执行。 因此解决问题的方法也很明确:修改this。这里我将this改成了'#name'以 id 选择器为 input 标签'造'一个弟弟.

    以下是完整代码:

     <script>
    // JQuery 完成表单检验
    $(function () {
    // 表单提交函数。检查name&age&email&qq等属性符合正则后方可提交
    $("form").submit(function () {
    return checkName() && checkAge() && checkEmail() && checkQq();
    })
    //验证姓名
    $('#name').blur(checkName);
    function checkName() {
    // 验证姓名验证正则
    var reg = /^[\u4E00-\u9FA5\uf900-\ufa2d·s]{2,20}$/; var flag = reg.test($('#name').val()); if( !flag ){
    $('#error_name').remove();
    $('#name').after("<p id='error_name' class='error_msg'>姓名格式不正确 </p>");
    } else {
    $('#error_name').remove();
    } return flag;
    }
    //验证年龄
    $('#age').blur(checkAge)
    function checkAge() {
    // 验证姓名验证正则
    var reg = /^\d{1,3}$/; var flag = reg.test($('#age').val()); if (!flag) {
    $('#error_age').remove();
    $('#age').after("<p id='error_age' class='error_msg'>年龄格式不正确 </p>");
    } else {
    $('#error_age').remove();
    }
    return flag;
    }
    //验证QQ
    $('#qq').blur(checkQq)
    function checkQq() {
    // 验证姓名验证正则
    var reg = /^\d{6,20}$/; var flag = reg.test($('#qq').val()); if( !flag ){
    $('#error_qq').remove();
    $('#qq').after("<p id='error_qq' class='error_msg'>qq格式不正确 </p>");
    } else {
    $('#error_qq').remove();
    }
    return flag;
    }
    //验证Email
    $('#email').blur(checkEmail)
    function checkEmail() {
    // 验证验证码正则
    var reg = /^[A-Za-z\d]+([-_.][A-Za-z\d]+)*@([A-Za-z\d]+[-.])+[A-Za-z\d]{2,4}$/;
    var flag = reg.test($('#email').val());
    if (!flag) {
    $('#error_email').remove();
    $('#email').after("<p id='error_email' class='error_msg'>邮箱格式不正确 </p>");
    } else {
    $('#error_email').remove();
    }
    return flag;
    }
    });
    </script>

    记录一次Jquery中 this 关键字使用出现的问题的更多相关文章

    1. jQuery中防止表单提交两次的方法

      遇到过表单提交两次的情况,做个记录: 解决场景:首先是表单验证,其次是防止多次提交表单: jQuery中插件:validate_submitHandler_plugin,具体的可以使用关键字搜索: 使 ...

    2. JQuery中的工具函数总结

      前提引入 前提当然也是要引入Jquery啦... <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js" typ ...

    3. JavaScript jQuery 中定义数组与操作及jquery数组操作

      首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象Javascript不支持多 ...

    4. JQuery中$.each 和$(selector).each()的区别详解

      PS:晚上在写页面时,发现了一个问题,$.each 和$(selector).each()有哪些区别?百度搜索关键词,首页显示出来一些前人的经验,总结一下,发上来. 1.$(selector).eac ...

    5. jquery中的ajax参数说明

      本文只作为记录,方便以后查阅. 内容原地址:$.ajax( )方法详解及案例_JQuery_wodi0007的博客_程序员博客网 http://u.cxyblog.com/28/article-aid ...

    6. 四、jquery中的事件与应用

      当用户浏览页面时,浏览器会对页面代码进行解释或编译--这个过程实质上是通过时间来驱动的,即页面在加载时,执行一个Load事件,在这个事件中实现浏览器编译页面代码的过程.时间无论在页面元素本身还是在元素 ...

    7. jQuery:详解jQuery中的事件(一)

      之前用过一些jQuery的动画和特效,但是用到的部分也不超过10%的样子,感觉好浪费啊——当然浪费的不是jQuery,而是Web资源.后来就想深入研究下jQuery的内部机理,读过两遍jQuery源代 ...

    8. JQuery中each()的使用方法说明

      JQuery中each()的使用方法说明 对于jQuery对象,只是把each方法简单的进行了委托:把jQuery对象作为第一个参数传递给jQuery的each方法.换句话说:jQuery提供的eac ...

    9. jQuery中的map()方法

      jQuery中map()方法的使用格式为:$(selector).map(callback(index,domElement)). 将在每一个被选元素上执行map()方法中设置的回调函数,在回调函数中 ...

    随机推荐

    1. [leetcode] 456. 132 Pattern (Medium)

      对一个三个元素以上的数组,如果存在1-3-2模式的组合,则返回true. 1-3-2模式就是值的排序是i<k<j但是下标排序是i<j<k. 解法一: 硬解,利用一个变量存储是否 ...

    2. c实现哲学家进餐问题。WINDOWS下。

      // 解决哲学家就餐问题// 每个哲学家可用一个线程来模拟.// 设有5个哲学家,5只筷子,每个哲学家吃饭时间为一个随机值,哲学家吃饭后的思考时间也是一个随机值.#include <Window ...

    3. luogu题解 P5022 【旅行】

      本人的代码可以说洛谷最简单的了 我的存图方式有些与众不同 a[5000][5000]中第一个下标表示第几个点,第二个表示与点相连的点 虽然比前向星废内存但时间极快,大概是O(n)的. 现在步入正题 6 ...

    4. jsp定义全局变量:读取properties文件

      <%java.util.Properties prop = new java.util.Properties();java.io.InputStream in;in = getClass().g ...

    5. 微信小程序设计总结

      微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验. 小程序提供了一个简单.高效的应用开发框架和丰富的组件及API,帮助开发者在微信中开发具有原生 A ...

    6. LeetCode 138:复制带随机指针的链表 Copy List with Random Pointer

      给定一个链表,每个节点包含一个额外增加的随机指针,该指针可以指向链表中的任何节点或空节点. 要求返回这个链表的深拷贝. A linked list is given such that each no ...

    7. 微信小程序的尺寸单位rpx介绍

      rpx单位是微信小程序中css的尺寸单位,rpx可以根据屏幕宽度进行自适应. 规定屏幕宽为750rpx.如在 iPhone6 上,屏幕宽度为375px,共有750个物理像素,则750rpx = 375 ...

    8. 01 | 健康之路 kubernetes(k8s) 实践之路 : 开篇及概况

      近几年容器相关的技术大行其道,容器.docker.k8s.mesos.service mesh.serverless等名词相信大家多少都有听过,国内互联网公司无一不接触和使用相关技术. 健康之路早在2 ...

    9. Could not launch "APP_NAME" process launch failed: 4294967295

      真机调试忽然遇到这个问题, Could not launch "APP_NAME" process launch failed: 如图所示: 模拟器上能正常调试………… 这个问题还 ...

    10. WTM 构建DotNetCore开源生态,坐而论道不如起而行之

      作为一个8岁开始学习编程,至今40岁的老程序员,这辈子使用过无数种语言,从basic开始,到pascal, C, C++,到后来的 java, c#,perl,php,再到现在流行的python. 小 ...