輸入框+模擬鍵盤

1.當前事件獲取

var e=window.event||test.caller.arguments[0];// 獲取event對象

var el=e.target||e.srcElement;// 獲取觸發(fā)事件的源對象

2.獲取當前事件的標簽

方法:

el.tagName.toLowerCase()

實例:el.tagName.toLowerCase()=="td"&&el.rowSpan<=1&&el.colSpan<=1

備注:判斷當前的事件的標簽是否為td,并且符合后面兩個屬性

3.改變表格的跨行數

document.getElementById("td2").rowSpan="2;

4.驗證函數

字母大小寫:/^[a-z]$/.test(str),/^[A-Z]$/.test(str)

實例:針對于字母大小寫鎖的函數


一些其他的驗證:

/

用途:檢查輸入手機號碼是否正確

輸入:

s:字符串

返回:

如果通過驗證返回true,否則返回false

/

function checkMobile(s){

var regu =/^[1][3][0-9]{9}$/;

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

/**

檢查輸入的身份證號是否正確

輸入:str? 字符串

返回:true 或 flase; true表示格式正確

/

function checkCard(str) {

//15位數身份證正則表達式

var arg1 = /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;

//18位數身份證正則表達式

var arg2 = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[A-Z])$/;

if (str.match(arg1) == null && str.match(arg2) == null) {

return false;

}

else {

return true;

}

}

/**

檢查輸入的字符是否具有特殊字符

輸入:str? 字符串

返回:true 或 flase; true表示包含特殊字符

主要用于注冊信息的時候驗證

/

function checkQuote(str) {

var items = new Array("~", "`", "!","@", "#", "$", "%", "^", "&", "", "{", "}", "[", "]", "(", ")");

items.push(":", ";", "'", "|", "\", "<", ">", "?", "/", "<<", ">>", "||", "http://");

items.push("admin", "administrators", "administrator", "管理員", "系統(tǒng)管理員");

items.push("select", "delete", "update", "insert", "create", "drop", "alter", "trancate");

str = str.toLowerCase();

for (var i = 0; i < items.length; i++) {

if (str.indexOf(items[i]) >= 0) {

return true;

}

}

return false;

}

/**

檢查輸入的URL地址是否正確

輸入:str? 字符串

返回:true 或 flase; true表示格式正確

/

function checkURL(str) {

if (str.match(/(http[s]?|ftp):\/\/[^\/.]+?..+\w$/i) == null) {

return false

}

else {

return true;

}

}

/

用途:檢查輸入的電話號碼格式是否正確

輸入:

strPhone:字符串

返回:

如果通過驗證返回true,否則返回false

/

function checkPhone(strPhone) {

var phoneRegWithArea = /^[0][1-9]{2,3}-[0-9]{5,10}$/;

var phoneRegNoArea = /^[1-9]{1}[0-9]{5,8}$/;

//var prompt = "您輸入的電話號碼不正確!"

if (strPhone.length > 9) {

if (phoneRegWithArea.test(strPhone)) {

return true;

} else {

//alert( prompt );

return false;

}

} else {

if (phoneRegNoArea.test(strPhone)) {

return true;

} else {

//alert(prompt);

return false;

}

}

}

/用途:校驗ip地址的格式

輸入:strIP:ip地址

返回:如果通過驗證返回true,否則返回false;

/

function isIP(strIP) {

if (isNull(strIP)) return false;

var re=/^(\d+).(\d+).(\d+).(\d+)$/g //匹配IP地址的正則表達式

if(re.test(strIP))

{

if( RegExp.$1 <256 && RegExp.$2<256 && RegExp.$3<256 && RegExp.$4<256) return true;

}

return false;

}

/

用途:檢查輸入字符串是否為空或者全部都是空格

輸入:str

返回:

如果全是空返回true,否則返回false

/

function isNull( str ){

if ( str == "" ) return true;

var regu = "^[ ]+$";

var re = new RegExp(regu);

return re.test(str);

}

/

用途:檢查輸入對象的值是否符合整數格式

輸入:str 輸入的字符串

返回:如果通過驗證返回true,否則返回false

/

function isInteger( str ){

var regu = /^[-]{0,1}[0-9]{1,}$/;

return regu.test(str);

}

/

用途:檢查輸入字符串是否符合正整數格式

輸入:

s:字符串

返回:

如果通過驗證返回true,否則返回false

/

function isNumber( s ){

var regu = "^[0-9]+$";

var re = new RegExp(regu);

if (s.search(re) != -1) {

return true;

} else {

return false;

}

}

/

用途:檢查輸入字符串是否是帶小數的數字格式,可以是負數

輸入:

s:字符串

返回:

如果通過驗證返回true,否則返回false

/

function isDecimal( str ){

if(isInteger(str)) return true;

var re = /^[-]{0,1}(\d+)[.]+(\d+)$/;

if (re.test(str)) {

if(RegExp.$1==0&&RegExp.$2==0) return false;

return true;

} else {

return false;

}

}

/

用途:檢查輸入對象的值是否符合端口號格式

輸入:str 輸入的字符串

返回:如果通過驗證返回true,否則返回false

/

function isPort( str ){

return (isNumber(str) && str<65536);

}

/

用途:檢查輸入對象的值是否符合E-Mail格式

輸入:str 輸入的字符串

返回:如果通過驗證返回true,否則返回false

/

function isEmail( str ){

var myReg = /^[-_A-Za-z0-9]+@([_A-Za-z0-9]+.)+[A-Za-z0-9]{2,3}$/;

if(myReg.test(str)) return true;

return false;

}

/

用途:檢查輸入字符串是否符合金額格式

格式定義為帶小數的正數,小數點后最多三位

輸入:

s:字符串

返回:

如果通過驗證返回true,否則返回false

/

function isMoney( s ){

var regu = "^[0-9]+[.][0-9]{0,3}$";

var re = new RegExp(regu);

if (re.test(s)) {

return true;

} else {

return false;

}

}

/

用途:檢查輸入字符串是否只由英文字母和數字和下劃線組成

輸入:

s:字符串

返回:

如果通過驗證返回true,否則返回false

/

function isNumberOr_Letter( s ){//判斷是否是數字或字母

var regu = "^[0-9a-zA-Z_]+$";

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

/

用途:檢查輸入字符串是否只由英文字母和數字組成

輸入:

s:字符串

返回:

如果通過驗證返回true,否則返回false

/

function isNumberOrLetter( s ){//判斷是否是數字或字母

var regu = "^[0-9a-zA-Z]+$";

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

/

用途:檢查輸入字符串是否只由漢字、字母、數字組成

輸入:

value:字符串

返回:

如果通過驗證返回true,否則返回false

/

function isChinaOrNumbOrLett( s ){//判斷是否是漢字、字母、數字組成

var regu = "^[0-9a-zA-Z\u4e00-\u9fa5]+$";

var re = new RegExp(regu);

if (re.test(s)) {

return true;

}else{

return false;

}

}

/

用途:判斷是否是日期

輸入:date:日期;fmt:日期格式

返回:如果通過驗證返回true,否則返回false

/

function isDate( date, fmt ) {

if (fmt==null) fmt="yyyyMMdd";

var yIndex = fmt.indexOf("yyyy");

if(yIndex==-1) return false;

var year = date.substring(yIndex,yIndex+4);

var mIndex = fmt.indexOf("MM");

if(mIndex==-1) return false;

var month = date.substring(mIndex,mIndex+2);

var dIndex = fmt.indexOf("dd");

if(dIndex==-1) return false;

var day = date.substring(dIndex,dIndex+2);

if(!isNumber(year)||year>"2100" || year< "1900") return false;

if(!isNumber(month)||month>"12" || month< "01") return false;

if(day>getMaxDay(year,month) || day< "01") return false;

return true;

}

function getMaxDay(year,month) {

if(month==4||month==6||month==9||month==11)

return "30";

if(month==2)

if(year%4==0&&year%100!=0 || year%400==0)

return "29";

else

return "28";

return "31";

}

/

用途:字符1是否以字符串2結束

輸入:str1:字符串;str2:被包含的字符串

返回:如果通過驗證返回true,否則返回false

/

function isLastMatch(str1,str2)

{

var index = str1.lastIndexOf(str2);

if(str1.length==index+str2.length) return true;

return false;

}

/

用途:字符1是否以字符串2開始

輸入:str1:字符串;str2:被包含的字符串

返回:如果通過驗證返回true,否則返回false

/

function isFirstMatch(str1,str2)

{

var index = str1.indexOf(str2);

if(index==0) return true;

return false;

}

/

用途:字符1是包含字符串2

輸入:str1:字符串;str2:被包含的字符串

返回:如果通過驗證返回true,否則返回false

/

function isMatch(str1,str2)

{

var index = str1.indexOf(str2);

if(index==-1) return false;

return true;

}

/

用途:檢查輸入的起止日期是否正確,規(guī)則為兩個日期的格式正確,

且結束如期>=起始日期

輸入:

startDate:起始日期,字符串

endDate:結束如期,字符串

返回:

如果通過驗證返回true,否則返回false

/

function checkTwoDate( startDate,endDate ) {

if( !isDate(startDate) ) {

alert("起始日期不正確!");

return false;

} else if( !isDate(endDate) ) {

alert("終止日期不正確!");

return false;

} else if( startDate > endDate ) {

alert("起始日期不能大于終止日期!");

return false;

}

return true;

}

/

用途:檢查輸入的Email信箱格式是否正確

輸入:

strEmail:字符串

返回:

如果通過驗證返回true,否則返回false

/

function checkEmail(strEmail) {

//var emailReg = /^[_a-z0-9]+@([_a-z0-9]+.)+[a-z0-9]{2,3}$/;

var emailReg = /^[\w-]+(.[\w-]+)@[\w-]+(.[\w-]+)+$/;

if( emailReg.test(strEmail) ){

return true;

}else{

alert("您輸入的Email地址格式不正確!");

return false;

}

}

/

用途:檢查復選框被選中的數目

輸入:

checkboxID:字符串

返回:

返回該復選框中被選中的數目

/

function checkSelect( checkboxID ) {

var check = 0;

var i=0;

if( document.all(checkboxID).length > 0 ) {

for( i=0; i

if( document.all(checkboxID).item( i ).checked ) {

check += 1;

}

}

}else{

if( document.all(checkboxID).checked )

check = 1;

}

return check;

}

function getTotalBytes(varField) {

if(varField == null)

return -1;

var totalCount = 0;

for (i = 0; i< varField.value.length; i++) {

if (varField.value.charCodeAt(i) > 127)

totalCount += 2;

else

totalCount++ ;

}

return totalCount;

}

function getFirstSelectedValue( checkboxID ){

var value = null;

var i=0;

if( document.all(checkboxID).length > 0 ){

for( i=0; i

if( document.all(checkboxID).item( i ).checked ){

value = document.all(checkboxID).item(i).value;

break;

}

}

} else {

if( document.all(checkboxID).checked )

value = document.all(checkboxID).value;

}

return value;

}

function getFirstSelectedIndex( checkboxID ){

var value = -2;

var i=0;

if( document.all(checkboxID).length > 0 ){

for( i=0; i

if( document.all(checkboxID).item( i ).checked ) {

value = i;

break;

}

}

} else {

if( document.all(checkboxID).checked )

value = -1;

}

return value;

}

function selectAll( checkboxID,status ){

if( document.all(checkboxID) == null)

return;

if( document.all(checkboxID).length > 0 ){

for( i=0; i

document.all(checkboxID).item( i ).checked = status;

}

} else {

document.all(checkboxID).checked = status;

}

}

function selectInverse( checkboxID ) {

if( document.all(checkboxID) == null)

return;

if( document.all(checkboxID).length > 0 ) {

for( i=0; i

document.all(checkboxID).item( i ).checked = !document.all(checkboxID).item( i ).checked;

}

} else {

document.all(checkboxID).checked = !document.all(checkboxID).checked;

}

}

function checkDate( value ) {

if(value=='') return true;

if(value.length!=8 || !isNumber(value)) return false;

var year = value.substring(0,4);

if(year>"2100" || year< "1900")

return false;

var month = value.substring(4,6);

if(month>"12" || month< "01") return false;

var day = value.substring(6,8);

if(day>getMaxDay(year,month) || day< "01") return false;

return true;

}

/

用途:檢查輸入的起止日期是否正確,規(guī)則為兩個日期的格式正確或都為空

且結束日期>=起始日期

輸入:

startDate:起始日期,字符串

endDate: 結束日期,字符串

返回:

如果通過驗證返回true,否則返回false

/

function checkPeriod( startDate,endDate ) {

if( !checkDate(startDate) ) {

alert("起始日期不正確!");

return false;

} else if( !checkDate(endDate) ) {

alert("終止日期不正確!");

return false;

} else if( startDate > endDate ) {

alert("起始日期不能大于終止日期!");

return false;

}

return true;

}

/

用途:檢查證券代碼是否正確

輸入:

secCode:證券代碼

返回:

如果通過驗證返回true,否則返回false

/

function checkSecCode( secCode ) {

if( secCode.length !=6 ){

alert("證券代碼長度應該為6位");

return false;

}

if(!isNumber( secCode ) ){

alert("證券代碼只能包含數字");

return false;

}

return true;

}

/***************************************************

function:cTrim(sInputString,iType)

description:字符串去空格的函數

parameters:iType:1=去掉字符串左邊的空格

2=去掉字符串左邊的空格

0=去掉字符串左邊和右邊的空格

return value:去掉空格的字符串

****************************************************/

function cTrim(sInputString,iType)

{

var sTmpStr = ' ';

var i = -1;

if(iType == 0 || iType == 1)

{

while(sTmpStr == ' ')

{

++i;

sTmpStr = sInputString.substr(i,1);

}

sInputString = sInputString.substring(i);

}

if(iType == 0 || iType == 2)

{

sTmpStr = ' ';

i = sInputString.length;

while(sTmpStr == ' ')

{

--i;

sTmpStr = sInputString.substr(i,1);

}

sInputString = sInputString.substring(0,i+1);

}

return sInputString;

}

5.數字鍵盤和拼音鍵盤的切換

在這里我是創(chuàng)建的兩個鍵盤,一個拼音的和一個數字的,注意一點,每個鍵盤要有自己的id,以便后面getElementById來獲取對象,開始數字鍵盤不顯示display:none,然后在定義ctrKeyboard函數里面通過當前對象的offsetWidth是否大于0來判定是否顯示了該鍵盤


最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,563評論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 99,694評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,672評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,965評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,690評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,019評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,013評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,188評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 49,718評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,438評論 3 360
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,667評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,149評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,845評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,252評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,590評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,384評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,635評論 2 380

推薦閱讀更多精彩內容

  • 單例模式 適用場景:可能會在場景中使用到對象,但只有一個實例,加載時并不主動創(chuàng)建,需要時才創(chuàng)建 最常見的單例模式,...
    Obeing閱讀 2,092評論 1 10
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現,斷路器,智...
    卡卡羅2017閱讀 134,832評論 18 139
  • 《ijs》速成開發(fā)手冊3.0 官方用戶交流:iApp開發(fā)交流(1) 239547050iApp開發(fā)交流(2) 10...
    葉染柒丶閱讀 5,275評論 0 7
  • 工廠模式類似于現實生活中的工廠可以產生大量相似的商品,去做同樣的事情,實現同樣的效果;這時候需要使用工廠模式。簡單...
    舟漁行舟閱讀 7,805評論 2 17
  • ¥開啟¥ 【iAPP實現進入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個線程,因...
    小菜c閱讀 6,495評論 0 17