>웹 프론트엔드 >JS 튜토리얼 >입력의 블러 이벤트와 버튼의 클릭 이벤트에 대한 자세한 소개

입력의 블러 이벤트와 버튼의 클릭 이벤트에 대한 자세한 소개

黄舟
黄舟원래의
2017-06-26 14:28:562142검색

소개부터 시작하겠습니다. 저는 최근 휴대폰용 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">密    码</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>

이전 예상은 입력 상자에 포커스 및 흐림 이벤트를 추가하는 것이었습니다.

$("#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);
        }    
    });

그러나 문제가 발생했습니다. 입력 후 삭제 아이콘을 클릭하면 이때 아이콘이 사라졌습니다. 아이콘은 있지만 블러 처리 중에 아이콘을 사라지게 하지 않으면 각 입력이 완료된 후 입력이 포커스를 잃고 아이콘이 항상 표시됩니다.

오늘까지 이 질문이 맴돌았어요. . . 또 다른 문제가 발생했습니다! !

문제설명: 입력창에 내용 입력을 마친 후 바로 등록버튼을 눌렀는데, 처음 눌렀을 때 입력에 포커스가 있을 때 버튼을 눌렀을 때마다 반응이 없었습니다. 버튼이 반응하기 전에 두 번 클릭해야 했습니다. ;

이때 이것이 클릭의 각광을 받고 있다는 것을 깨달았기 때문에 블러 실행에 지연을 추가하면 당연히 블러에서 문제를 찾아야 했습니다. ...

$("#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);
    });

다 괜찮을 거야, 갑자기 세상이 조용해졌어. . .

그러면 더 이상 아무것도 없었습니다. 이전에 삭제한 작은 아이콘도 준수하여 흐리게 표시할 수 있었습니다. 그런데 제 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") 처럼 다시 가져와야 합니까? 또는 실제로 이 코드를 단순화할 수 있지만 아직 생각해 본 적이 없습니다. . . 또한 각계각층의 학생들에게 조언을 부탁드립니다.

위 내용은 입력의 블러 이벤트와 버튼의 클릭 이벤트에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.