首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >链接bind()和unbind()事件处理程序

链接bind()和unbind()事件处理程序
EN

Stack Overflow用户
提问于 2013-06-05 00:19:36
回答 2查看 906关注 0票数 0

有人能解释一下这部分链接的逻辑吗?

代码语言:javascript
复制
$("#name").unbind("focus").focus(function(){
    $("#name").unbind("blur").blur(function(){

下面的代码?我无法访问HTML,但here是呈现的网页。另外,是否可以在第一次声明事件处理程序的同时解除它们的绑定?

代码语言:javascript
复制
$(document).ready(function(){

    $("#name").unbind("focus").focus(function(){
        $("#name").unbind("blur").blur(function(){
            var name = $("input[name='name']").val().toString();
            console.log(name);
            if(name === ""){
                $("#nameError").css("display", "block");
            }
            $("#name").focus(function(){
                $("#nameError").css("display", "none");
            });
        });
    });
    ...
});
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-06-05 00:28:33

我想这段代码已经破解了。

外部处理程序及其.unbind('focus').focus()链用于确保没有注册其他focus处理程序。它还确保在第一次将元素悬停在该元素上之前,不会注册任何blur处理程序,并抛出一个.unbind以确保额外的安全性。

然而,在该处理程序内部,每当元素看到.blur事件时,内部.focus处理程序将被重新注册为,而无需安全网。最终结果是在该元素上注册了许多重复的处理程序。

票数 1
EN

Stack Overflow用户

发布于 2013-06-05 00:22:29

这样绑定就可以多次运行,而不用担心重复

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16922803

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档