jquery驗(yàn)證郵箱格式并顯示提交按鈕
簡(jiǎn)要教程
簡(jiǎn)潔、大方和直觀的用戶界面是我們最喜歡的網(wǎng)頁設(shè)計(jì)。本文介紹的正是這樣的一個(gè)設(shè)計(jì)風(fēng)格。
如何才能做到頁面的簡(jiǎn)潔大方并且人性化?大多數(shù)網(wǎng)站的表單采用文本提示的方法,提示用戶哪里填寫錯(cuò)了,哪里不正確,但我們應(yīng)該能做得更好:填寫不正確就不顯示提交按鈕!
HTML結(jié)構(gòu)
<form class="newsletter"> <input type="email" value="" placeholder="Enter your email address" /> <input type="submit" value="OK" /> </form>
JAVASCRIPT:
檢查輸入的文本是否為一個(gè)正確的email地址,如果正確,就給表單添加特定的樣式,否則不添加,通過css來控制這個(gè)樣式是否顯示按鈕。
依賴于jQuery的做法:
$( function( $, window, document, undefined ) { 'use strict'; var form = '.newsletter', className = 'newsletter--active', email = 'input[type="email"]'; $( form ).each( function() { var $form = $( this ), $email = $form.find( email ), val = ''; $email.on( 'keyup.addClassWhenEmail', function() { val = $email.val(); $form.toggleClass( className, val != '' && /^([\w-\.]+@([\w-]+\.)+[\w-]{2,12})?$/.test( val ) ); }); }); })( jQuery, window, document );
以上代碼兼容IE6以上的瀏覽器
如果你想關(guān)閉這項(xiàng)功能,可以通過關(guān)閉名稱空間addClassWhenEmail來實(shí)現(xiàn)。
$( '.newsletter input[type="email"]' ).off( '.addClassWhenEmail' );
不使用jQuery,純javascript的做法:
;( function( window, document, undefined ) { 'use strict'; var form = '.newsletter', className = 'newsletter--active', email = 'input[type="email"]', addEventListener = function( element, event, handler ) { element.addEventListener ? element.addEventListener( event, handler ) : element.attachEvent( 'on' + event, function(){ handler.call( element ); }); }, forEach = function( elements, fn ) { for( var i = 0; i < elements.length; i++ ) fn( elements[ i ], i ); }, addClass = function( element, className ) { element.classList ? element.classList.add( className ) : element.className += ' ' + className; }, removeClass = function( element, className ) { element.classList ? element.classList.remove( className ) : element.className += element.className.replace( new RegExp( '(^|\\b)' + className.split( ' ' ).join( '|' ) + '(\\b|$)', 'gi' ), ' ' ); }; forEach( document.querySelectorAll( form ), function( $form ) { var $email = $form.querySelectorAll( email ); if( $email.length ) { $email = $email[ 0 ]; addEventListener( $email, 'keyup', function() { $email.value != '' && /^([\w-\.]+@([\w-]+\.)+[\w-]{2,12})?$/.test( $email.value ) ? addClass( $form, className ) : removeClass( $form, className ); }); } }); })( window, document );
以上代碼兼容IE8+以及所有現(xiàn)代瀏覽器。
可用參數(shù)
這里有三個(gè)參數(shù)可以用來改變選擇器:
var form = '.newsletter', // form selector className = 'newsletter--active', // class name for form when correct email is entered email = 'input[type="email"]', // email input field selector
CSS代碼
js代碼用來切換樣式,真正顯示于隱藏則通過css來實(shí)現(xiàn):
.newsletter:not( .newsletter--active ) input[type='submit'] { display: none; }
以上就是為大家分享的jquery驗(yàn)證郵箱格式并顯示提交按鈕的方法,希望對(duì)大家的學(xué)習(xí)有所幫助。
相關(guān)文章
jQuery獲得IE版本不準(zhǔn)確webbrowser的解決方法
用$.browser.version經(jīng)常出現(xiàn)一些不準(zhǔn)確的狀況,最近碰到,做了一些總結(jié),不知道是否全面2014-02-02jQuery 出現(xiàn)Cannot read property ‘msie’ of undefined錯(cuò)誤的解決方法
這篇文章主要介紹了jQuery 出現(xiàn)Cannot read property ‘msie’ of undefined錯(cuò)誤的解決方法的相關(guān)資料,需要的朋友可以參考下2016-11-11a標(biāo)簽跳轉(zhuǎn)到指定div,jquery添加和移除class屬性的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猘標(biāo)簽跳轉(zhuǎn)到指定div,jquery添加和移除class屬性的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10jquery驗(yàn)證郵箱格式是否正確實(shí)例講解
這篇文章主要介紹了一個(gè)jquery驗(yàn)證郵箱格式是否正確的實(shí)踐案例,利用正則表達(dá)式進(jìn)行驗(yàn)證,感興趣的小伙伴們可以參考一下2015-11-11jQuery animate(滑塊滑動(dòng)效果代碼)
jQuery animate 滑塊滑動(dòng)效果,學(xué)習(xí)jquery的朋友可以看下。2010-01-01PHP+MySQL+jQuery隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置實(shí)例講解
這篇文章主要介紹了PHP+MySQL+jQuery隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置的實(shí)現(xiàn)方法,感興趣的小伙伴們可以參考一下2015-10-10使用jQuery和PHP實(shí)現(xiàn)類似360功能開關(guān)效果
本文介紹了使用jQuery、PHP和MySQL實(shí)現(xiàn)類似360安全衛(wèi)士防火墻開啟關(guān)閉的開關(guān),可以將此功能應(yīng)用在產(chǎn)品功能的開啟和關(guān)閉功能上,需要的朋友可以參考下2014-02-02