国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Javascript控制input輸入時間格式的方法

2019-11-20 13:18:25
字體:
供稿:網(wǎng)友

本文實例講述了Javascript控制input輸入時間格式的方法。分享給大家供大家參考。具體分析如下:

之前做了一個Javascript控制時間格式的輸入,主要用到了keydown和keyup兩個事件,但感覺寫的很復(fù)雜而且還有bug。

今日了解了一下keypress事件與keydown和keyup的區(qū)別。大致如下(目前只了解這么多):

keydown:按鍵按下的時候觸發(fā),通過event可以獲取到keyCode,可以獲取到文本框輸入之前的值;

keyup:按鍵彈出(松開)時觸發(fā),通過event可以獲取到keyCode,可以獲取到文本框輸入之后的值;

keypress:此事件在Chrome和IE中基本相同,但Firefox有點不一樣;

1、在Chrome和IE中:只要按下的鍵能在文本框中出現(xiàn)字符則會觸發(fā)(如輸入字母、數(shù)字、符號等),通過event可以獲取到keyCode,event.key為undefined;不能出現(xiàn)字符的則不會觸發(fā)(如方向鍵、Home、Backspace等)

2、在火狐中:字母、數(shù)字、符號、方向、退格等按鍵均能觸發(fā),均可以通過event.key獲取按鍵名,如果所按的鍵能輸出字符則event.keyCode為0,如果不能輸出字符則event.keyCode為對應(yīng)的ASCII碼

回到正題,先直接看代碼(上面提到的event就相當于下面代碼中的e):

復(fù)制代碼 代碼如下:
var isFF = /firefox/i.test(navigator.userAgent);
$("input").on({
    keyup : function (e) {
        !/^[/d:]+$/.test(e.target.value) && (e.target.value = "");
    },
    keypress : function (e) {
        if (isFF && e.keyCode !== 0) {
            /// 在火狐中按任意鍵都會觸發(fā)keypress事件,而在IE/Chrome中只有按下能輸出字符的按鍵才會觸發(fā)
            /// 針對火狐,e.keyCode!==0則按下了退格、方向、Home等按鍵之一
        } else {
            if (e.target.value.length > 7)
                return false;
            if (//d{2}$/.test(e.target.value)) {
                e.target.value += ':';
            }
            var char = String.fromCharCode(e.keyCode === 0 ? e.which : e.keyCode);
            if (!/^/d/.test(char))
                return false;
        }
    }
});

通過isFF && e.keyCode !== 0來區(qū)分Firefox能輸出字符的按鍵和不能輸出字符的按鍵,由于Firefox中e.keyCode不一定能取到值,所以使用了e.which來取代。

keyup是用于處理使用輸入法時能輸入中文或字母的問題。

通過String.fromCharCode()得到ASCII碼對應(yīng)的字符。

希望本文所述對大家的javascript程序設(shè)計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 青河县| 宜川县| 彩票| 唐海县| 巴东县| 浦东新区| 嘉义县| 广饶县| 西平县| 陕西省| 乐都县| 托克托县| 龙口市| 保定市| 仪陇县| 金湖县| 平和县| 永春县| 吐鲁番市| 伊金霍洛旗| 富平县| 淮阳县| 城固县| 平利县| 杂多县| 南和县| 建湖县| 祁门县| 临泽县| 长顺县| 江永县| 重庆市| 屏东县| 新巴尔虎左旗| 德庆县| 松潘县| 英吉沙县| 司法| 雷山县| 伊宁市| 汝城县|