轉(zhuǎn)自 http://blog.csdn.net/arcow/
在b/s開(kāi)發(fā)中經(jīng)常用到的javaScript技術(shù)?
一、驗(yàn)證類(lèi)
1、數(shù)字驗(yàn)證內(nèi)
? 1.1 整數(shù)
? 1.2 大于0的整數(shù) (用于傳來(lái)的ID的驗(yàn)證)
? 1.3 負(fù)整數(shù)的驗(yàn)證
? 1.4 整數(shù)不能大于iMax
? 1.5 整數(shù)不能小于iMin
2、時(shí)間類(lèi)
? 2.1 短時(shí)間,形如 (13:04:06)
? 2.2 短日期,形如 (2003-12-05)
? 2.3 長(zhǎng)時(shí)間,形如 (2003-12-05 13:04:06)
? 2.4 只有年和月。形如(2003-05,或者2003-5)
? 2.5 只有小時(shí)和分鐘,形如(12:03)
3、表單類(lèi)
? 3.1 所有的表單的值都不能為空
? 3.2 多行文本框的值不能為空。
? 3.3 多行文本框的值不能超過(guò)sMaxStrleng
? 3.4 多行文本框的值不能少于sMixStrleng
? 3.5 判斷單選框是否選擇。
? 3.6 判斷復(fù)選框是否選擇.
? 3.7 復(fù)選框的全選,多選,全不選,反選
? 3.8 文件上傳過(guò)程中判斷文件類(lèi)型
4、字符類(lèi)
? 4.1 判斷字符全部由a-Z或者是A-Z的字字母組成
? 4.2 判斷字符由字母和數(shù)字組成。
? 4.3 判斷字符由字母和數(shù)字,下劃線,點(diǎn)號(hào)組成.且開(kāi)頭的只能是下劃線和字母
? 4.4 字符串替換函數(shù).Replace();
5、瀏覽器類(lèi)
? 5.1 判斷瀏覽器的類(lèi)型
? 5.2 判斷ie的版本
? 5.3 判斷客戶端的分辨率
?
6、結(jié)合類(lèi)
? 6.1 email的判斷。
? 6.2 手機(jī)號(hào)碼的驗(yàn)證
? 6.3 身份證的驗(yàn)證
?
二、功能類(lèi)
1、時(shí)間與相關(guān)控件類(lèi)
? 1.1 日歷
? 1.2 時(shí)間控件
? 1.3 萬(wàn)年歷
? 1.4 顯示動(dòng)態(tài)顯示時(shí)鐘效果(文本,如OA中時(shí)間)
? 1.5 顯示動(dòng)態(tài)顯示時(shí)鐘效果 (圖像,像手表)
2、表單類(lèi)
? 2.1 自動(dòng)生成表單
? 2.2 動(dòng)態(tài)添加,修改,刪除下拉框中的元素
? 2.3 可以輸入內(nèi)容的下拉框
? 2.4 多行文本框中只能輸入iMax文字。如果多輸入了,自動(dòng)減少到iMax個(gè)文字(多用于短信發(fā)送)
?
3、打印類(lèi)
? 3.1 打印控件
4、事件類(lèi)
? 4.1 屏蔽右鍵
? 4.2 屏蔽所有功能鍵
? 4.3 --> 和<-- F5 F11,F9,F1
? 4.4 屏蔽組合鍵ctrl+N
5、網(wǎng)頁(yè)設(shè)計(jì)類(lèi)
? 5.1 連續(xù)滾動(dòng)的文字,圖片(注意是連續(xù)的,兩段文字和圖片中沒(méi)有空白出現(xiàn))
? 5.2 html編輯控件類(lèi)
? 5.3 顏色選取框控件
? 5.4 下拉菜單
? 5.5 兩層或多層次的下拉菜單
? 5.6 仿IE菜單的按鈕。(效果如rongshuxa.com的導(dǎo)航欄目)
? 5.7 狀態(tài)欄,title欄的動(dòng)態(tài)效果(例子很多,可以研究一下)
? 5.8 雙擊后,網(wǎng)頁(yè)自動(dòng)滾屏
6、樹(shù)型結(jié)構(gòu)。
? 6.1 asp+SQL版
? 6.2 asp+xml+sql版
? 6.3 java+sql或者java+sql+xml
7、無(wú)邊框效果的制作
8、連動(dòng)下拉框技術(shù)
9、文本排序
一、驗(yàn)證類(lèi)
1、數(shù)字驗(yàn)證內(nèi)
? 1.1 整數(shù)
????? /^(-|+)?d+$/.test(str)
? 1.2 大于0的整數(shù) (用于傳來(lái)的ID的驗(yàn)證)
????? /^d+$/.test(str)
? 1.3 負(fù)整數(shù)的驗(yàn)證
????? /^-d+$/.test(str)
2、時(shí)間類(lèi)
? 2.1 短時(shí)間,形如 (13:04:06)
????? function isTime(str)
????? {
??????? var a = str.match(/^(d{1,2})(:)?(d{1,2})2(d{1,2})$/);
??????? if (a == null) {alert('輸入的參數(shù)不是時(shí)間格式'); return false;}
??????? if (a[1]>24 || a[3]>60 || a[4]>60)
??????? {
????????? alert("時(shí)間格式不對(duì)");
????????? return false
??????? }
??????? return true;
????? }
? 2.2 短日期,形如 (2003-12-05)
????? function strDateTime(str)
????? {
???????? var r = str.match(/^(d{1,4})(-|/)(d{1,2})2(d{1,2})$/);
???????? if(r==null)return false;
???????? var d= new Date(r[1], r[3]-1, r[4]);
???????? return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);
????? }
? 2.3 長(zhǎng)時(shí)間,形如 (2003-12-05 13:04:06)
????? function strDateTime(str)
????? {
??????? var reg = /^(d{1,4})(-|/)(d{1,2})2(d{1,2}) (d{1,2}):(d{1,2}):(d{1,2})$/;
??????? var r = str.match(reg);
??????? if(r==null)return false;
??????? var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);
???????
return
(d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);
????? }
? 2.4 只有年和月。形如(2003-05,或者2003-5)
? 2.5 只有小時(shí)和分鐘,形如(12:03)
3、表單類(lèi)
? 3.1 所有的表單的值都不能為空
????? <input onblur="if(this.value.replace(/^s+|s+$/g,'')=='')alert('不能為空!')">
? 3.2 多行文本框的值不能為空。
? 3.3 多行文本框的值不能超過(guò)sMaxStrleng
? 3.4 多行文本框的值不能少于sMixStrleng
? 3.5 判斷單選框是否選擇。
? 3.6 判斷復(fù)選框是否選擇.
? 3.7 復(fù)選框的全選,多選,全不選,反選
? 3.8 文件上傳過(guò)程中判斷文件類(lèi)型
4、字符類(lèi)
? 4.1 判斷字符全部由a-Z或者是A-Z的字字母組成
????? <input onblur="if(/[^a-zA-Z]/g.test(this.value))alert('有錯(cuò)')">
? 4.2 判斷字符由字母和數(shù)字組成。
????? <input onblur="if(/[^0-9a-zA-Z]/g.test(this.value))alert('有錯(cuò)')">
? 4.3 判斷字符由字母和數(shù)字,下劃線,點(diǎn)號(hào)組成.且開(kāi)頭的只能是下劃線和字母
????? /^([a-zA-z_]{1})([w]*)$/g.test(str)
? 4.4 字符串替換函數(shù).Replace();
5、瀏覽器類(lèi)
? 5.1 判斷瀏覽器的類(lèi)型
????? window.navigator.appName
? 5.2 判斷ie的版本
????? window.navigator.appVersion
? 5.3 判斷客戶端的分辨率
????? window.screen.height;? window.screen.width;
?
6、結(jié)合類(lèi)
? 6.1 email的判斷。
????? function ismail(mail)
????? {
??????? return(new RegExp(/^w+((-w+)|(.w+))*@[A-Za-z0-9]+((.|-)[A-Za-z0-9]+)*.[A-Za-z0-9]+$/).test(mail));
????? }
? 6.2 手機(jī)號(hào)碼的驗(yàn)證
? 6.3 身份證的驗(yàn)證
????? function isIdCardNo(num)
????? {
??????? if (isNaN(num)) {alert("輸入的不是數(shù)字!"); return false;}
??????? var len = num.length, re;
??????? if (len == 15)
????????? re = new RegExp(/^(d{6})()?(d{2})(d{2})(d{2})(d{3})$/);
??????? else if (len == 18)
????????? re = new RegExp(/^(d{6})()?(d{4})(d{2})(d{2})(d{3})(d)$/);
??????? else {alert("輸入的數(shù)字位數(shù)不對(duì)!"); return false;}
??????? var a = num.match(re);
??????? if (a != null)
??????? {
????????? if (len==15)
????????? {
??????????? var D = new Date("19"+a[3]+"/"+a[4]+"/"+a[5]);
??????????? var B = D.getYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
????????? }
????????? else
????????? {
??????????? var D = new Date(a[3]+"/"+a[4]+"/"+a[5]);
??????????? var B = D.getFullYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
????????? }
????????? if (!B) {alert("輸入的身份證號(hào) "+ a[0] +" 里出生日期不對(duì)!"); return false;}
??????? }
??????? return true;
????? }
3.7 復(fù)選框的全選,多選,全不選,反選
<form name=hrong>
<input type=checkbox name=All onclick="checkAll('mm')">全選<br/>
<input type=checkbox name=mm onclick="checkItem('All')"><br/>
<input type=checkbox name=mm onclick="checkItem('All')"><br/>
<input type=checkbox name=mm onclick="checkItem('All')"><br/>
<input type=checkbox name=mm onclick="checkItem('All')"><br/>
<input type=checkbox name=mm onclick="checkItem('All')"><br/><br/>
<input type=checkbox name=All2 onclick="checkAll('mm2')">全選<br/>
<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>
<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>
<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>
<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>
<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>
</form>
<SCRIPT LANGUAGE="JavaScript">
function checkAll(str)
{
? var a = document.getElementsByName(str);
? var n = a.length;
? for (var i=0; i<n; i++)
? a[i].checked = window.event.srcElement.checked;
}
function checkItem(str)
{
? var e = window.event.srcElement;
? var all = eval("document.hrong."+ str);
? if (e.checked)
? {
??? var a = document.getElementsByName(e.name);
??? all.checked = true;
??? for (var i=0; i<a.length; i++)
??? {
????? if (!a[i].checked){ all.checked = false; break;}
??? }
? }
? else all.checked = false;
}
</SCRIPT>
3.8 文件上傳過(guò)程中判斷文件類(lèi)型
<input type=file onchange="alert(this.value.match(/^(.*)(.)(.{1,8})$/)[3])">
畫(huà)圖:
<OBJECT
id=S
style="LEFT: 0px; WIDTH: 392px; TOP: 0px; HEIGHT: 240px"
height=240
width=392
classid="clsid:369303C2-D7AC-11D0-89D5-00A0C90833E6">
</OBJECT>
<SCRIPT>
S.DrawingSurface.ArcDegrees(0,0,0,30,50,60);
S.DrawingSurface.ArcRadians(30,0,0,30,50,60);
S.DrawingSurface.Line(10,10,100,100);
</SCRIPT>
posted @ 2006-04-28 09:47 隱語(yǔ)者 閱讀(247) | 評(píng)論 (0) | 編輯 收藏