4-15编程练习

来源:4-15 编程练习

soso_crazy

2019-02-11 17:18:34

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title></title>
    <style>
        .oneline {
            line-height: 1.5;
            margin: 10px auto;
        }
        
        .oneline label {
            width: 100px;
            text-indent: 15px;
            font-size: 14px;
            font-family: "Microsoft Yahei";
            display: inline-block;
        }
        
        .oneline .sinput {
            width: 60%;
            height: 30px;
            border-radius: 6px;
            border: 1px solid #e2e2e2;
        }
        
        .oneline input[type="submit"] {
            margin-left: 20px;
            width: 80px;
            height: 30px;
            border: 0;
            background-color: #5899d0;
            color: #fff;
            font-size: 14px;
            border-radius: 6px;
        }
        
        .error-messages {
            color: red;
        }
    </style>
</head>
<body>
    <form id="forms">
        <div class="oneline">
            <label for="name">用户名:</label>
            <input id="name" class="sinput" name="name" type="text" required>
        </div>
        <div class="oneline">
            <label for="email">Email:</label>
            <input id="email" class="sinput" name="email" type="email" required>
        </div>
        <div class="oneline">
            <input type="submit" id="submits" value="提交">
        </div>
    </form>
    <script>
    function replaceValidationUI(form) {
        form.addEventListener("invalid", function(event) {
            event.preventDefault();
        }, true);
        form.addEventListener("submit", function(event) {
            if (!this.checkValidity()) {
                event.preventDefault();
            }
        });
        //此处写代码
        
        var submitButton=document.getElementById("submits"),
            invalidFields=form.querySelectorAll(:invalid),
            errorMessage=form.querySelectorAll('.error-messages');
            
        for(var i=0;i<errorMessage.length;i++){
            errorMessage[i].parentNode.removeChild(errorMessage[i]);
        }
        
        for(var i=0;i<invalidFields.length;i++){
            parent=invalidFields[i].parentNode;
            invalidFields[0].parentNode.parentNode.insertAdjacentHTML('afterbegin',"<div class='error-message'>" + inValidityField[i].validationMessage + "</div>")
        }
        
        
        if (invalidFields.length > 0) {
            invalidFields[0].focus();
        }
    }
    var forms = document.getElementById("forms");
    replaceValidationUI(forms);
    
    submits.onclick=function(){
        replaceValidationUI(forms);
    }
    </script>
</body>

</html>

为什么不能实现?

invalidFields[0].parentNode.parentNode.insertAdjacentHTML('afterbegin',"<div class='error-message'>" + inValidityField[i].validationMessage + "</div>")这句是什么意思?

为什么连默认的气泡都不能删除?

写回答

1回答

樱桃小胖子

2019-02-11

http://img.mukewang.com/climg/5c614ca40001e79a16170783.jpg

http://img.mukewang.com/climg/5c614cb90001a6ea07370183.jpg

insertAdjacentHTML('afterbegin', "<div class='error-messages'>" + invalidFields[i].validationMessage + "</div>")在parent元素后面添

<div class='error-messages'>错误信息</div>这样的一个存放错误信息的div元素

希望可以帮到你!

0

0 学习 · 5012 问题

查看课程

相似问题