表單驗證求助:怎么封裝一個方法川抡,根據(jù)用戶傳入的驗證規(guī)則和提示信息實現(xiàn)表單驗證辐真?

首先,請看HTML頁面代碼簡寫:

<form action="test.php" class="form">

    <h1 class="form_header">表單驗證</h1>
    <hr/>
    <ul class="form_content">
        <li>
            <label for="">用戶名</label>
            <input class="check" type="text" placeholder="請輸入用戶名"/>

            <div class="msg">
                <i></i>
                <span></span>
            </div>
        </li>
        <li>
            <label for="">用戶戶名</label>
            <input type="text" placeholder="請輸入用戶名"/>

            <div class="msg">
                <i></i>
                <span></span>
            </div>
        </li>
        <li>
            <label for="">用戶戶戶名</label>
            <input class="check" type="text" placeholder="請輸入用戶名"/>

            <div class="msg">
                <i></i>
                <span></span>
            </div>
        </li>
        <li>
            <label for="">用戶戶戶戶名</label>
            <input class="check" type="text" placeholder="請輸入用戶名"/>

            <div class="msg">
                <i></i>
                <span>dsafdfadsfas</span>
            </div>
        </li>
        <li>
            <label for="">用戶戶戶戶戶名</label>
            <input type="text" placeholder="請輸入用戶名"/>

            <div class="msg">
                <i></i>
                <span>gggggggggggg</span>
            </div>
        </li>
    </ul>

</form>

CSS代碼:

* {
  margin: 0;
  padding: 0;
  list-style: none;
}
.form {
  width: 800px;
  min-height: 700px;
  background: #cccccc;
  margin: 50px auto;
}
.form_content {
  padding: 10px;
}
.form_content li {
  height: 68px;
}
.form_content li label {
  display: inline-block;
  vertical-align: middle;
  width: 120px;
  text-align: right;
}
.form_content li input {
  width: 268px;
  height: 30px;
  line-height: 30px;
  padding: 5px;
  border-radius: 5px;
  outline: none;
}
.form_content li .msg {
  display: inline-block;
  vertical-align: middle;
  position: relative;
}
.form_content li .msg i {
  display: inline-block;
  vertical-align: middle;
  width: 0;
  height: 0;
  position: absolute;
  border-width: 12px;
  border-style: solid;
  border-color: transparent #51a3cc transparent transparent;
  left: -14px;
  top: -14px;
}
.form_content li .msg span {
  display: inline-block;
  vertical-align: middle;
  position: absolute;
  left: 10px;
  top: -20px;
  text-align: left;
  padding: 10px;
  min-width: 120px;
  color: #ffffff;
  border-radius: 5px;
  background-color: rgba(51, 153, 204, 0.8);
}

需求:

封裝一個插件崖堤,該插件會遍歷form表單里包含check的類侍咱,使用者調(diào)用該插件時只需傳入對應的規(guī)則和提示信息即可,其它工作交給插件進行校驗密幔。該插件會根據(jù)用戶的規(guī)則進行校驗楔脯,如果驗證通過則執(zhí)行正確的回調(diào),否則則把錯誤的顯示信息顯示出來胯甩。
注①:在form表單中昧廷,需要進行校驗的在該標簽中添加一個check類,如
<input class="check" type="text" placeholder="請輸入用戶名"/>
注②:在HTML中有幾個check類偎箫,則在調(diào)用時需要傳入對應數(shù)量的規(guī)則木柬。

以下是我的代碼構(gòu)思,但是無法實現(xiàn)想要的效果淹办,如果有哪位大神路過眉枕,請抽空指導一下,萬分感激怜森!
JS代碼:

 (function ($) {
    $.fn.forms = function (obj) {

        //var _this = this;
        var rules = obj.rules || [];
        var msg = obj.msg || [];
        //var checkID = obj.checkID || "";

        $("form .check").each(function (i, j) {
            $(this).keyup(function () {
                if (obj.rules[i]) {
                    $(this).parent().siblings(".form_msg").hide();
                    $(this).addClass("right");
                    return false;
                } else {
                    $(this).removeClass("right");
                    $(this).addClass("wrong");
                    $(this).parent().siblings(".form_msg").show();
                    if (msg) {
                        $(this).parent().siblings(".form_msg").children("span").html(msg[i]);
                    }
                }
            });
        });
    };
})(jQuery);

//調(diào)用
$(function () {

    $(".msg").hide();

    $(".form").forms({
        rules: ["$(this).val().length>5", "$(this).val() == 'TEST'", "", ""],
        msg: ["提示信息1", "提示信息2", "提示信息3", "提示信息4"]
    });

});

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末齐遵,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子塔插,更是在濱河造成了極大的恐慌,老刑警劉巖拓哟,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件想许,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機流纹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進店門糜烹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人漱凝,你說我怎么就攤上這事疮蹦。” “怎么了茸炒?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵愕乎,是天一觀的道長。 經(jīng)常有香客問我壁公,道長感论,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任紊册,我火速辦了婚禮比肄,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘囊陡。我一直安慰自己芳绩,他們只是感情好,可當我...
    茶點故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布撞反。 她就那樣靜靜地躺著妥色,像睡著了一般。 火紅的嫁衣襯著肌膚如雪痢畜。 梳的紋絲不亂的頭發(fā)上垛膝,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天,我揣著相機與錄音线衫,去河邊找鬼凿可。 笑死,一個胖子當著我的面吹牛授账,可吹牛的內(nèi)容都是我干的白热。 我是一名探鬼主播屋确,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼纱昧!你這毒婦竟也來了识脆?” 一聲冷哼從身側(cè)響起灼捂,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎偎球,沒想到半個月后衰絮,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體猫牡,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡骇陈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年器联,在試婚紗的時候發(fā)現(xiàn)自己被綠了拨拓。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡醋界,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出挡篓,到底是詐尸還是另有隱情官研,我是刑警寧澤戏羽,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站酷宵,受9級特大地震影響浇垦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜此虑,卻給世界環(huán)境...
    茶點故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望况既。 院中可真熱鬧,春花似錦莫其、人聲如沸乱陡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至爽彤,卻和暖如春养盗,著一層夾襖步出監(jiān)牢的瞬間往核,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工丹喻, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留谅猾,地道東北人藏研。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像业踏,于是被迫代替她去往敵國和親禽炬。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,654評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 22年12月更新:個人網(wǎng)站關停伐脖,如果仍舊對舊教程有興趣參考 Github 的markdown內(nèi)容[https://...
    tangyefei閱讀 35,181評論 22 257
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理热幔,服務發(fā)現(xiàn)乐设,斷路器,智...
    卡卡羅2017閱讀 134,652評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,085評論 25 707
  • 本學期绎巨,我校開始了一門新選修課程——創(chuàng)業(yè)家說創(chuàng)新近尚。該課程是由清華大學經(jīng)管學院陸向謙教授創(chuàng)新的新型課程。即線上線下同...
    Deer77閱讀 376評論 0 0
  • 亞馬遜記錄:亞馬遜的移動應用讓用戶有一個流暢的無處不在的體驗的同時场勤,也通過收集手機上的數(shù)據(jù)深入地了解了每個用戶的喜...
    恒跡彩象閱讀 174評論 0 0