这一节和之前教的有点脱节了吧 老师只顾着自己演示了

来源:4-15 编程练习

whiteDive

2018-12-19 23:52:05

<!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 sunmitBtn=document.getElementById("submits");
        sunmitBtn.addEventListener("click", function (event) {
            var allField=form.querySelectorAll(":invalid"),
                errorMessage=form.querySelectorAll(".error-messages"),
                forms=document.getElementById("forms");
            for(var i=0;i<errorMessage.length;i++){
                errorMessage[i].parentNode.removeChild(errorMessage[i]);
            }
            for(var i=0;i<allField.length;i++){
                forms.insertAdjacentHTML("afterbegin","<div class='error-messages'>"+allField[i].validationMessage+"</div>")

            }
        });
        if (invalidFields.length > 0) {
            invalidFields[0].focus();
        }
    }
    var forms = document.getElementById("forms");
    replaceValidationUI(forms);
</script>
</body>

</html>


写回答

1回答

好帮手慕星星

2018-12-20

同学你好,首先表单验证是要有效果的,老师不可能只给大家讲api,不讲真实的效果和性能,这样是对大家不负责任,学完之后还是不知道学的这些东西的真实作用。因此,在这个课程中,老师是结合实际的开发例子,综合为大家展示了H5中是如何处理表单验证问题的,一定是综合的考量。

老师在前面讲了修改默认气泡的思路,然后在后面一节中进行了实际的演示:

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

同学如果觉得学习的比较困难,可以跟着老师一边理解一边敲代码,这样自己也会有一个印象,也会明白老师的思路。同学不用担心,如果在学习中遇到问题,可以在问答区进行提问,老师会帮助你解决问题的。

上传代码中的问题:

1、报错提示:invalidFields未定义

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

是因为预留代码中的名称与自己定义的名称不一致:

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

可以将名称修改一致,然后将判断条件放进点击事件中,参考:

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

2、建议在错误提示前面添加具体的名称:

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

可以在for循环中通过输入框的id值获取相应的label标签中的内容,再拼接到错误信息的前面。

自己完善下,祝学习愉快!

0

0 学习 · 5012 问题

查看课程