【原】相煎何太急——input的blur事件与button的click事件

先来一段引子,最近在写手机h5页面,主要是一些登陆注册方面的,最绕不开的就是表单元素。

我想实现的是:在输入框后边有一个删除图标,当输入东西的时候触发事件,显示删除图标,点击该图标会删除之前输入的内容,离开输入框,该图标消失。

<div class="wrapper">
<div class="count">
<label for="person">手机号</label>
<input id="person" type="text" placeholder="请输入手机号">
<i class="r btn_delete delete1"><img src="../imgs/btn_Eliminate.png"></i>
</div>
<div class="count">
<label for="pwd">&nbsp;&nbsp;&nbsp;&nbsp;</label>
<input id="pwd" type="text" placeholder="6-18位,建议数字、字母、符号组合">
<i class="r btn_delete delete2"><img src="../imgs/btn_Eliminate.png"></i>
<i class="r hide_switch"><img src="../imgs/btn_display_switch.png"></i>
</div>
<div class="confirm">
<label for="msg">短信验证码</label>
<input id="msg" type="text" placeholder="请输入短信验证码">
<i class="r btn_delete delete3"><img src="../imgs/btn_Eliminate.png"></i>
<button class="r receive_msg">获取验证码</button>
</div>
</div>
<div class="log">
     <button class="btn_register">立即注册</button>
</div>

之前的预想是:为输入框添加focus和blur事件;

$("#person, #modify_name").focus(function(event) {
event.preventDefault();
$(this).prev().css("color", "#f68121");
if ($(this).val() === person_val) {
$(this).val("").css("color", "#000").keyup(function() {
$(".btn_delete").css("visibility", "visible").bind("click", function(event) {
event.preventDefault();
$("#person").val("").focus();
$(".btn_delete").css("visibility", "hidden");
});
});
}
});
$("#person, modify_name").blur(function(event) {
event.preventDefault();
//$(".btn_delete").css("visibility", "hidden");
$(this).prev().css("color", "#000");
if ($(this).val() === "") {
$(this).css("color", "#acacac").val(person_val);
}    
});

但是遇到了问题:当我输入后点击删除图标,同时也触发了blur事件,此时图标消失,也就点击不到图标了,但是如果不在blur时让图标消失,则每一次输入完成后input失去焦点,图标就一直显示着。

      这个问题向个梗,一直卡着,直到今天。。。我又遇到了另外一个问题!!

问题描述:当我在输入框输入完内容后,直接点击注册按钮,第一次点击,没反应,每一次都是焦点在input时点击button,需要点击两次,button才会有所反应;

      这时我才意识到,这是blur抢占了click的风头,那么我就得去blur里找问题,果然,如果我给blur的执行加一个延时....

$("#person, #pwd, #msg, #mail").focus(function(event) {
event.preventDefault();
if ($(this).attr("placeholder") === person_plc) {
that = $(this);
} else if ($(this).attr("placeholder") === pwd_plc) {
that = $(this);
} else {
that = $(this);
}
that.prev().css("color", "#f68121");
that.css("color", "#000").keyup(function() {
that.next(".btn_delete").css("visibility", "visible").bind("click", function(event) {
$(this).prev().css("color", "#acacac").val("").blur().prev().css("color", "#000");
$(".btn_delete").css("visibility", "hidden");
});
});
})
$("#person").blur(function(event) {
event.preventDefault();
setTimeout(function() {
// console.log("blur");
$(".btn_delete").css("visibility", "hidden");
$("#person").prev().css("color", "#000"); 
if ($("#person").val() === "") {
$("#person").css("color", "#acacac");
}
}, 100);
});

万事大吉,一下子世界都安静了。。。

然后就没有然后了,连之前的删除小图标也听话了,一blur就能隐藏,可是我的js代码重复代码非常之多,如下:

var person_val = $("#person").val();
var person_plc = $("#person").attr("placeholder");
var pwd_plc = $("#pwd").attr("placeholder");
var that;
$("#person, #pwd, #msg, #mail").focus(function(event) {
event.preventDefault();
if ($(this).attr("placeholder") === person_plc) {
that = $(this);
} else if ($(this).attr("placeholder") === pwd_plc) {
that = $(this);
} else {
that = $(this);
}
that.prev().css("color", "#f68121");
that.css("color", "#000").keyup(function() {
that.next(".btn_delete").css("visibility", "visible").bind("click", function(event) {
$(this).prev().css("color", "#acacac").val("").blur().prev().css("color", "#000");
$(".btn_delete").css("visibility", "hidden");
});
});
})
$("#person").blur(function(event) {
event.preventDefault();
setTimeout(function() {
// console.log("blur");
$(".btn_delete").css("visibility", "hidden");
$("#person").prev().css("color", "#000"); 
if ($("#person").val() === "") {
$("#person").css("color", "#acacac");
}
}, 100);
});
$("#pwd").blur(function(event) {
event.preventDefault();
setTimeout(function() {
// console.log("blur");
$(".btn_delete").css("visibility", "hidden");
$("#pwd").prev().css("color", "#000"); 
if ($("#pwd").val() === "") {
$("#pwd").css("color", "#acacac");
}
}, 100);
});
$("#msg").blur(function(event) {
event.preventDefault();
setTimeout(function() {
// console.log("blur");
$(".btn_delete").css("visibility", "hidden");
$("#msg").prev().css("color", "#000"); 
if ($("#msg").val() === "") {
$("#msg").css("color", "#acacac");
}
}, 100);
});

并且,我甚至都不知道第一个问题是怎么被解决的,在此也想向大家请教一下,为什么加一个定时之后,我再用$(this)就取不到当前的对象,必须得像$("#person")这样重新取,导致我还得为每一个input添加一个blur事件,不能集中处理,或者,其实这段代码是可以简化的,只是我还没想到。。。还请各方同学多多指教。

 

本文原创,转载请注明出处。


更多专业前端知识,请上 【猿2048】www.mk2048.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/361559.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

由浅入深:自己动手开发模板引擎——置换型模板引擎(一)

编辑器加载中... 转自&#xff1a;http://www.cnblogs.com/ymind/archive/2012/03/31/progressively-develop-templateEngine-yourself-replacement-type-1.html 受到群里兄弟们的竭力邀请&#xff0c;老陈终于决定来分享一下.NET下的模板引擎开发技术。本系列文章将会带您由浅…

C#锐利体验-第八讲 索引器与操作符重载(转)

第八讲 索引器与操作符重载 南京邮电学院 李建忠&#xff08;cornyfield263.net&#xff09; 索引 C#锐利体验 "Hello,World&#xff01;"程序C#语言基础介绍Microsoft.NET平台基础构造类与对象 构造器与析构器方法域与属性索引器与操作符重载 数组与字符串特征与映射…

Java EE 7 / JAX-RS 2.0:具有自定义HTTP标头的简单REST API身份验证和授权

在使用已可用的HTTP协议实施Web服务时&#xff0c;REST带来了很多便利。 通过仅通过指定的URL触发GET&#xff0c;POST和其他HTTP方法&#xff0c;您将确保通过REST服务的响应来完成某些工作。 但是&#xff0c;无论REST给开发人员带来了什么便利&#xff0c;安全性和访问控制的…

关于form标签,你该知道

有没有发现&#xff0c;自己在写模板的时候很少使用form元素&#xff0c;一来form和table总是那么傻傻分不清楚&#xff1b;二来form的特性理解不清楚&#xff0c;有了input、label来了直接就上&#xff0c;根本不用form&#xff08;不知道有没有人和我一样&#xff09;。因此&…

一个微软面试题--关于位结构体

含位域结构体的sizeof: 前面已经说过&#xff0c;位域成员不能单独被取sizeof值&#xff0c;我们这里要讨论的是含有位域的结构体的sizeof&#xff0c;只是考虑到其特殊性而将其专门列了出来。 C99规定int、unsigned int和bool可以作为位域类型&#xff0c;但编译器几乎都对此作…

easyui树形菜单实现

需求&#xff1a;读取路径配置中的相对路径获取对应的子文件夹及其子文件并形成树形结构&#xff0c;加载xml文件&#xff0c;输入搜索关键字匹配xml里面的value节点的值对应的contact值的集合并进行搜索 例如&#xff1a;输入b&#xff0c;找到xml里面的文本节点等于b的value…

在Twitter上使用Apache Mesos和Apache Aurora进行资源调度和任务启动

播客的第23集是与Bill Farner的谈话 Bill解释了Twitter如何使用Apache Mesos和Apache Aurora在硬件上获得更多收益&#xff0c;并通过在整个基础架构中利用细粒度的资源调度来节省工程时间&#xff08;开发和运营&#xff09;。 Bill谈到了他在Borg上与Google一起在Google上所…

fatal error C1083: 无法打开预编译头文件:“Debug\a.pch”:No such file or directory

一、解决方法 右键点击你创建的项目&#xff0c;选择“属性标签”点击属性&#xff0c;弹出“项目属性页”&#xff0c;在左侧找到以下位置 配置属性 --> C/C --> 预编译头&#xff0c;并选择它&#xff1a;在右边的菜单中选择 “创建/使用预编译头”中的“不使用预编…

ubunt 下 配置samba 服务器

一. samba的安装: sudo apt-get insall sambasudo apt-get install smbfs 二。修改/etc/samba/smb.conf sudo gedit /etc/samba/smb.conf 在smb.conf最后添加 [myShare]comment Shared Folder with username and passwordpath /home/wangywriteable yesbrowseable yesguest…

Telnet初试(本地测试)

win7下开启Telnet功能&#xff1a; 控制面板-程序和功能- 开启服务 然后回车 这样即可完成一次请求 更多专业前端知识&#xff0c;请上 【猿2048】www.mk2048.com

织梦dede 5.7系统基本参数无法修改保存,提示Token mismatch!

织梦dede 5.7系统基本参数无法修改保存&#xff0c;总是提示Token mismatch! 最开始以为是文件权限问题&#xff0c;反复给权限无法解决。 百度了下&#xff0c;也没有好用的方法 最后还是要自己动手 在dede/sys_info.php 54行找到对应的内容 根据代码判断是 $token变量问题 打…

您是否真的要加快Maven的编译/打包速度? 那么takari生命周期插件就是答案。

像你们中的许多人一样&#xff0c;我正在使用多模块Maven项目 。 与现有的许多系统相比&#xff0c;这不是一个很大的数目&#xff0c;它具有15个模块&#xff0c;3种不同的耳朵部署&#xff0c;带有属性文件的大量参数化以及大约10万行Java代码。 在开发高峰期&#xff0c;由于…

手机MMI体系结构及其实现

摘自&#xff1a;http://blog.csdn.net/zc2007/article/details/2340436 1引言 MMI&#xff08;ManMachineInter-face&#xff09;&#xff0c;即人机界面&#xff0c;它负责和用户的交互&#xff0c;在必要的时候调用其它模块的功能。MMI模块在整个系统中处于最 高层&#x…

Aspose.Words简单生成word文档

Aspose.Words简单生成word文档 Aspose.Words.Document doc new Aspose.Words.Document(); Aspose.Words.DocumentBuilder builder new Aspose.W…

ubuntu下安装JDK和netbeans

我在ubuntu下安装netbeans十分简单&#xff0c;我下载了jdk-7u1-nb-7_0_1-linux-ml.sh&#xff0c;直接在终端输入 sh jdk-7u1-nb-7_0_1-linux-ml.sh安装的向导就会启动&#xff0c;你只要选择JDK和netbeans安装的目录&#xff0c;向导就自动替你安装jdk和netbeans&#xff0c;…

在带有组合框的值列表的下拉列表中显示显示属性的子集

组合框值列表&#xff08;inputComboboxListOfValues&#xff09;应该是使用LOV的非常流行的ADF Faces组件。 坦白说&#xff0c;这是我最喜欢的值列表方法。 在这篇简短的文章中&#xff0c;我将重点介绍ADF开发人员经常忽略的一项功能。 如果默认情况下定义了LOV&#xff0c;…

Cause: com.ibatis.common.xml.NodeletException: Error parsing XML. Cause: jav

报错&#xff1a;Cause: com.ibatis.common.xml.NodeletException: Error parsing XML. Cause: jav 原因&#xff1a;1、在对应的xml文件里面 #A#,只写了一个# 2、xml文件里面有多余的字符&#xff0c;如空格等 转载于:https://www.cnblogs.com/zzw3014/p/11316031.html

摆脱困境:在每种测试方法之前重置自动增量列

当我们为将信息保存到数据库的功能编写集成测试时&#xff0c;我们必须验证是否将正确的信息保存到数据库。 如果我们的应用程序使用Spring Framework&#xff0c;则可以为此目的使用Spring Test DbUnit和DbUnit 。 但是&#xff0c;很难验证是否在主键列中插入了正确的值&am…

仅坚持了9天:京东今日宣布暂停火车票代购业务

仅仅只坚持了9天&#xff0c;对于京东商城销售火车票的讨论一直进行着。不论是否具有销售资质&#xff0c;还是变相的收费。到今天下午为止京东商城发表声明暂停火车票代购业务。以下是京东公告全文&#xff1a;尊敬的京东网友&#xff1a;鉴于京东商城火车票代购业务测试期间出…

path.join 与 path.resolve 的区别

1. 对于以/开始的路径片段&#xff0c;path.join只是简单的将该路径片段进行拼接&#xff0c;而path.resolve将以/开始的路径片段作为根目录&#xff0c;在此之前的路径将会被丢弃&#xff0c;就像是在terminal中使用cd命令一样。 path.join(/a, /b) // a/bpath.resolve(/a, /b…