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
insertAdjacentHTML('afterbegin', "<div class='error-messages'>" + invalidFields[i].validationMessage + "</div>")在parent元素后面添
<div class='error-messages'>错误信息</div>这样的一个存放错误信息的div元素
希望可以帮到你!