这一节和之前教的有点脱节了吧 老师只顾着自己演示了
来源: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回答
同学你好,首先表单验证是要有效果的,老师不可能只给大家讲api,不讲真实的效果和性能,这样是对大家不负责任,学完之后还是不知道学的这些东西的真实作用。因此,在这个课程中,老师是结合实际的开发例子,综合为大家展示了H5中是如何处理表单验证问题的,一定是综合的考量。
老师在前面讲了修改默认气泡的思路,然后在后面一节中进行了实际的演示:
同学如果觉得学习的比较困难,可以跟着老师一边理解一边敲代码,这样自己也会有一个印象,也会明白老师的思路。同学不用担心,如果在学习中遇到问题,可以在问答区进行提问,老师会帮助你解决问题的。
上传代码中的问题:
1、报错提示:invalidFields未定义
是因为预留代码中的名称与自己定义的名称不一致:
可以将名称修改一致,然后将判断条件放进点击事件中,参考:
2、建议在错误提示前面添加具体的名称:
可以在for循环中通过输入框的id值获取相应的label标签中的内容,再拼接到错误信息的前面。
自己完善下,祝学习愉快!
相似问题