生命是一種過程

          事情的結果盡管重要,但是做事情的過程更加重要,因為結果好了我們會更加快樂,但過程使我們的生命充實!
          posts - 13, comments - 1, trackbacks - 0, articles - 0
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          在b/s開發中經常用到的javaScript技術

          Posted on 2006-04-28 09:47 隱語者 閱讀(247) 評論(0)  編輯  收藏 所屬分類: web

          轉自 http://blog.csdn.net/arcow/

          在b/s開發中經常用到的javaScript技術?
          一、驗證類
          1、數字驗證內
          ? 1.1 整數
          ? 1.2 大于0的整數 (用于傳來的ID的驗證)
          ? 1.3 負整數的驗證
          ? 1.4 整數不能大于iMax
          ? 1.5 整數不能小于iMin
          2、時間類
          ? 2.1 短時間,形如 (13:04:06)
          ? 2.2 短日期,形如 (2003-12-05)
          ? 2.3 長時間,形如 (2003-12-05 13:04:06)
          ? 2.4 只有年和月。形如(2003-05,或者2003-5)
          ? 2.5 只有小時和分鐘,形如(12:03)
          3、表單類
          ? 3.1 所有的表單的值都不能為空
          ? 3.2 多行文本框的值不能為空。
          ? 3.3 多行文本框的值不能超過sMaxStrleng
          ? 3.4 多行文本框的值不能少于sMixStrleng
          ? 3.5 判斷單選框是否選擇。
          ? 3.6 判斷復選框是否選擇.
          ? 3.7 復選框的全選,多選,全不選,反選
          ? 3.8 文件上傳過程中判斷文件類型
          4、字符類
          ? 4.1 判斷字符全部由a-Z或者是A-Z的字字母組成
          ? 4.2 判斷字符由字母和數字組成。
          ? 4.3 判斷字符由字母和數字,下劃線,點號組成.且開頭的只能是下劃線和字母
          ? 4.4 字符串替換函數.Replace();
          5、瀏覽器類
          ? 5.1 判斷瀏覽器的類型
          ? 5.2 判斷ie的版本
          ? 5.3 判斷客戶端的分辨率
          ?
          6、結合類
          ? 6.1 email的判斷。
          ? 6.2 手機號碼的驗證
          ? 6.3 身份證的驗證
          ?

          二、功能類

          1、時間與相關控件類
          ? 1.1 日歷
          ? 1.2 時間控件
          ? 1.3 萬年歷
          ? 1.4 顯示動態顯示時鐘效果(文本,如OA中時間)
          ? 1.5 顯示動態顯示時鐘效果 (圖像,像手表)
          2、表單類
          ? 2.1 自動生成表單
          ? 2.2 動態添加,修改,刪除下拉框中的元素
          ? 2.3 可以輸入內容的下拉框
          ? 2.4 多行文本框中只能輸入iMax文字。如果多輸入了,自動減少到iMax個文字(多用于短信發送)
          ?
          3、打印類
          ? 3.1 打印控件
          4、事件類
          ? 4.1 屏蔽右鍵
          ? 4.2 屏蔽所有功能鍵
          ? 4.3 --> 和<-- F5 F11,F9,F1
          ? 4.4 屏蔽組合鍵ctrl+N
          5、網頁設計類
          ? 5.1 連續滾動的文字,圖片(注意是連續的,兩段文字和圖片中沒有空白出現)
          ? 5.2 html編輯控件類
          ? 5.3 顏色選取框控件
          ? 5.4 下拉菜單
          ? 5.5 兩層或多層次的下拉菜單
          ? 5.6 仿IE菜單的按鈕。(效果如rongshuxa.com的導航欄目)
          ? 5.7 狀態欄,title欄的動態效果(例子很多,可以研究一下)
          ? 5.8 雙擊后,網頁自動滾屏
          6、樹型結構。
          ? 6.1 asp+SQL版
          ? 6.2 asp+xml+sql版
          ? 6.3 java+sql或者java+sql+xml
          7、無邊框效果的制作
          8、連動下拉框技術
          9、文本排序


          一、驗證類
          1、數字驗證內
          ? 1.1 整數
          ????? /^(-|+)?d+$/.test(str)
          ? 1.2 大于0的整數 (用于傳來的ID的驗證)
          ????? /^d+$/.test(str)
          ? 1.3 負整數的驗證
          ????? /^-d+$/.test(str)
          2、時間類
          ? 2.1 短時間,形如 (13:04:06)
          ????? function isTime(str)
          ????? {
          ??????? var a = str.match(/^(d{1,2})(:)?(d{1,2})2(d{1,2})$/);
          ??????? if (a == null) {alert('輸入的參數不是時間格式'); return false;}
          ??????? if (a[1]>24 || a[3]>60 || a[4]>60)
          ??????? {
          ????????? alert("時間格式不對");
          ????????? 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 長時間,形如 (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 只有小時和分鐘,形如(12:03)
          3、表單類
          ? 3.1 所有的表單的值都不能為空
          ????? <input onblur="if(this.value.replace(/^s+|s+$/g,'')=='')alert('不能為空!')">
          ? 3.2 多行文本框的值不能為空。
          ? 3.3 多行文本框的值不能超過sMaxStrleng
          ? 3.4 多行文本框的值不能少于sMixStrleng
          ? 3.5 判斷單選框是否選擇。
          ? 3.6 判斷復選框是否選擇.
          ? 3.7 復選框的全選,多選,全不選,反選
          ? 3.8 文件上傳過程中判斷文件類型
          4、字符類
          ? 4.1 判斷字符全部由a-Z或者是A-Z的字字母組成
          ????? <input onblur="if(/[^a-zA-Z]/g.test(this.value))alert('有錯')">
          ? 4.2 判斷字符由字母和數字組成。
          ????? <input onblur="if(/[^0-9a-zA-Z]/g.test(this.value))alert('有錯')">
          ? 4.3 判斷字符由字母和數字,下劃線,點號組成.且開頭的只能是下劃線和字母
          ????? /^([a-zA-z_]{1})([w]*)$/g.test(str)
          ? 4.4 字符串替換函數.Replace();
          5、瀏覽器類
          ? 5.1 判斷瀏覽器的類型
          ????? window.navigator.appName
          ? 5.2 判斷ie的版本
          ????? window.navigator.appVersion
          ? 5.3 判斷客戶端的分辨率
          ????? window.screen.height;? window.screen.width;
          ?
          6、結合類
          ? 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 手機號碼的驗證
          ? 6.3 身份證的驗證
          ????? function isIdCardNo(num)
          ????? {
          ??????? if (isNaN(num)) {alert("輸入的不是數字!"); 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("輸入的數字位數不對!"); 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("輸入的身份證號 "+ a[0] +" 里出生日期不對!"); return false;}
          ??????? }
          ??????? return true;
          ????? }

          3.7 復選框的全選,多選,全不選,反選
          <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 文件上傳過程中判斷文件類型
          <input type=file onchange="alert(this.value.match(/^(.*)(.)(.{1,8})$/)[3])">

          畫圖:
          <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>


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 大方县| 林西县| 昭苏县| 门源| 黄梅县| 应城市| 垦利县| 固始县| 尼勒克县| 淮南市| 贵州省| 库车县| 大田县| 澄迈县| 水富县| 忻州市| 翼城县| 定兴县| 平山县| 石景山区| 鸡西市| 鄂托克前旗| 三江| 奇台县| 湘西| 固始县| 洪泽县| 张家界市| 景谷| 津市市| 中阳县| 三门峡市| 珲春市| 屯门区| 上林县| 临泽县| 无锡市| 洞口县| 卢龙县| 清原| 海宁市|