使用原生javascript創(chuàng)建通用表單驗(yàn)證——更鋒利的使用dom對(duì)象
首先看下效果,沒什么特別,呵呵!
調(diào)用的代碼呢,則是相當(dāng)簡(jiǎn)單,不需要?jiǎng)?chuàng)建其他的Label或者span標(biāo)簽,腳本將自動(dòng)生成:
<input type="text" id="txt1" onkeyup="checkResult(this.value == '', 'txt1', ' *這里不能為空喔!')" />
接下來我們看下這個(gè)checkResult這個(gè)函數(shù),checkCondition參數(shù)表示判斷條件,當(dāng)條件為true時(shí)顯示提示信息;showAfterId參數(shù)為創(chuàng)建的顯示提示信息的標(biāo)簽之前的元素ID,在這里我們?cè)趇nput后面創(chuàng)建一個(gè)span來顯示提示信息,因而 傳入的參數(shù)值為當(dāng)前input的ID“txt1”;最后一個(gè)參數(shù)為顯示的文字,這個(gè)就不用啰嗦了。
//驗(yàn)證不能為空展示提示信息
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 = '';
}
}
好,最后我們來看這個(gè)“createShowElement(currentId, elementId, style, showMsg, tagName)”函數(shù):currentId即當(dāng)前標(biāo)簽的ID;elementId為創(chuàng)建的標(biāo)簽的ID;style為創(chuàng)建的標(biāo)簽的樣式,按照樣式的寫法即可;showMsg不講了;tagName為創(chuàng)建的標(biāo)簽名,如label或者span等。
//創(chuàng)建展示提示信息的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);
}
僅供交流,歡迎大家提出指點(diǎn),渴望寶貴的意見。個(gè)人覺得,即使是寫簡(jiǎn)單的腳本驗(yàn)證程序,也應(yīng)該盡量遵循面向?qū)ο蟮乃枷?,并且在可擴(kuò)展與效率上追尋一個(gè)協(xié)調(diào)的點(diǎn),既不影響效率,同時(shí)讓我們寫的任何程序具有更高的可擴(kuò)展性,這點(diǎn)思路其實(shí)不難,但是經(jīng)常被很多初級(jí)程序員忽略。
- JavaScript 學(xué)習(xí)筆記(十三)Dom創(chuàng)建表格
- javascript轉(zhuǎn)換字符串為dom對(duì)象(字符串動(dòng)態(tài)創(chuàng)建dom)
- JavaScript與DOM組合動(dòng)態(tài)創(chuàng)建表格實(shí)例
- js和jquery對(duì)dom節(jié)點(diǎn)的操作(創(chuàng)建/追加)
- 通過JS動(dòng)態(tài)創(chuàng)建一個(gè)html DOM元素并顯示
- javascript實(shí)現(xiàn)dom動(dòng)態(tài)創(chuàng)建省市縱向列表菜單的方法
- JS動(dòng)態(tài)創(chuàng)建DOM元素的方法
- 基于JavaScript創(chuàng)建動(dòng)態(tài)Dom
相關(guān)文章
JavaScript的removeChild()函數(shù)用法詳解
removechild 函數(shù)可以刪除父元素的指定子元素,通過本文給大家介紹javascript的removeChild()函數(shù)用法,對(duì)js removechild函數(shù)相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2015-12-12js實(shí)現(xiàn)3D旋轉(zhuǎn)相冊(cè)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)3D旋轉(zhuǎn)相冊(cè),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08js 獲取經(jīng)緯度的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猨s 獲取經(jīng)緯度的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06JavaScript設(shè)計(jì)模式之構(gòu)造器模式(生成器模式)定義與用法實(shí)例分析
這篇文章主要介紹了JavaScript設(shè)計(jì)模式之構(gòu)造器模式(生成器模式)定義與用法,結(jié)合實(shí)例形式分析了javascript構(gòu)造器模式的概念、原理、與工廠模式的區(qū)別以及相關(guān)使用方法,需要的朋友可以參考下2018-07-07js實(shí)現(xiàn)數(shù)據(jù)雙向綁定(訪問器監(jiān)聽)
這篇文章主要為大家詳細(xì)介紹了采用訪問器監(jiān)聽的方式實(shí)現(xiàn)簡(jiǎn)單數(shù)據(jù)雙向綁定,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09非常不錯(cuò)的功能強(qiáng)大代碼簡(jiǎn)單的管理菜單美化版
由于網(wǎng)盤不穩(wěn)定,很多時(shí)候文件提示找不到,幸好U盤里存了. 喜歡這3個(gè)風(fēng)格的朋友們別在PM我啦.....我把文件傳到我服務(wù)器上了..2008-07-07JS 新增Cookie 取cookie值 刪除cookie 舉例詳解
cookie很實(shí)用的一個(gè)功能,可以判斷某個(gè)狀態(tài),下面與大家分享下JS 如何新增Cookie 取cookie值 刪除cookie,感興趣的朋友可以參考下2014-10-10