使用原生javascript创建通用表单验证——更锋利的使用dom对象
2011-09-13 00:00
671 查看
首先看下效果,没什么特别,呵呵!
调用的代码呢,则是相当简单,不需要创建其他的Label或者span标签,脚本将自动生成:
接下来我们看下这个checkResult这个函数,checkCondition参数表示判断条件,当条件为true时显示提示信息;showAfterId参数为创建的显示提示信息的标签之前的元素ID,在这里我们在input后面创建一个span来显示提示信息,因而 传入的参数值为当前input的ID“txt1”;最后一个参数为显示的文字,这个就不用啰嗦了。
好,最后我们来看这个“createShowElement(currentId, elementId, style, showMsg, tagName)”函数:currentId即当前标签的ID;elementId为创建的标签的ID;style为创建的标签的样式,按照样式的写法即可;showMsg不讲了;tagName为创建的标签名,如label或者span等。
仅供交流,欢迎大家提出指点,渴望宝贵的意见。个人觉得,即使是写简单的脚本验证程序,也应该尽量遵循面向对象的思想,并且在可扩展与效率上追寻一个协调的点,既不影响效率,同时让我们写的任何程序具有更高的可扩展性,这点思路其实不难,但是经常被很多初级程序员忽略。
调用的代码呢,则是相当简单,不需要创建其他的Label或者span标签,脚本将自动生成:
<input type="text" id="txt1" onkeyup="checkResult(this.value == '', 'txt1', ' *这里不能为空喔!')" />
接下来我们看下这个checkResult这个函数,checkCondition参数表示判断条件,当条件为true时显示提示信息;showAfterId参数为创建的显示提示信息的标签之前的元素ID,在这里我们在input后面创建一个span来显示提示信息,因而 传入的参数值为当前input的ID“txt1”;最后一个参数为显示的文字,这个就不用啰嗦了。
//验证不能为空展示提示信息 function checkResult(checkCondition, showAfterId, showMsg) { var showLabelId = showAfterId + "showMsg"; if (checkCondition) { if (document.getElementById(showLabelId)) { document.getElementById(showLabelId).innerHTML = showMsg; } else { createShowElement(showAfterId, showLabelId, "color:red", showMsg, 'span'); } } else if (!checkCondition) { if (document.getElementById(showLabelId)) document.getElementById(showLabelId).innerHTML = ''; } }
好,最后我们来看这个“createShowElement(currentId, elementId, style, showMsg, tagName)”函数:currentId即当前标签的ID;elementId为创建的标签的ID;style为创建的标签的样式,按照样式的写法即可;showMsg不讲了;tagName为创建的标签名,如label或者span等。
//创建展示提示信息的dom function createShowElement(currentId, elementId, style, showMsg, tagName) { if (!tagName) tagName = 'label'; var currentDom = document.getElementById(currentId); var showMsgDom = document.createElement(tagName); //showMsgDom.setAttribute("style", "color:" + textColor + ";"); if (style) showMsgDom.setAttribute("style", style); showMsgDom.setAttribute("id", elementId); showMsgDom.innerHTML = showMsg; currentDom.parentNode.insertBefore(showMsgDom, currentDom.nextSibling); }
仅供交流,欢迎大家提出指点,渴望宝贵的意见。个人觉得,即使是写简单的脚本验证程序,也应该尽量遵循面向对象的思想,并且在可扩展与效率上追寻一个协调的点,既不影响效率,同时让我们写的任何程序具有更高的可扩展性,这点思路其实不难,但是经常被很多初级程序员忽略。
相关文章推荐
- 使用原生javascript创建通用表单验证 —— 更锋利的使用dom对象
- 使用原生javascript创建通用表单验证——更锋利的使用dom对象
- JavaScript通用表单验证函数
- [置顶] 【JS】JavaScript进行表单验证经常使用的判断条件
- yii 使用cactiveform 创建表单时候遇到的一些验证问题和使用ajax_form时重置验证规则的解决办法
- 使用JavaScript创建智能表单
- HTML表单javascript验证通用模式
- JavaScript通用表单验证函数
- 使用JavaScript实现表单的前端简单验证后提交
- javascript实现通用表单验证函数
- JavaScript通用表单验证函数
- 使用Pear QuickForm创建和验证表单2008-02-13 17:37这是Zend上的一篇文章 http://devzone.zend.com/article/2699-Generating-and-Validating-Web-Forms-Wit
- 使用图片按钮调用Javascript验证表单
- (二)yii使用原生html不使用yii生成html表单如何忽略m层验证无法通过
- JavaScript通用表单验证函数
- 使用javascript的onsubmit进行表单合法性验证
- JS通用表单验证函数,基于javascript正则表达式
- 【JavaScript】在前台验证表单,必须使用onsubmit="return xx()"的形式
- 通用表单验证函数 - FormCheck JavaScript Function
- 使用javascript验证表单