站長資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        經(jīng)典Javascript正則表達(dá)式[優(yōu)質(zhì)排版]

        匹配中文字符的正則表達(dá)式:

        復(fù)制代碼 代碼如下:
        [u4e00-u9fa5]

        匹配雙字節(jié)字符(包括漢字在內(nèi)):

        復(fù)制代碼 代碼如下:
        [^x00-xff]

        應(yīng)用:計算字符串的長度(一個雙字節(jié)字符長度計2,ASCII字符計1)

        復(fù)制代碼 代碼如下:
        String.prototype.len=function(){ return this.replace([^x00-xff]/g,”aa”).length; }

        匹配空行的正則表達(dá)式:

        復(fù)制代碼 代碼如下:
        n[s|]*r

        匹配HTML標(biāo)記的正則表達(dá)式:

        復(fù)制代碼 代碼如下:
        /<(.*)>.*</1>|<(.*) />/

        匹配首尾空格的正則表達(dá)式:

        復(fù)制代碼 代碼如下:
        (^s*)|(s*$)

        應(yīng)用:j avascript中沒有像v bscript那樣的trim函數(shù),我們就可以利用這個表達(dá)式來實現(xiàn),如下:

        復(fù)制代碼 代碼如下:
        String.prototype.trim = function()
        {
            return this.replace(/(^s*)|(s*$)/g, “”);
        }

        利用正則表達(dá)式分解和轉(zhuǎn)換IP地址
        下面是利用正則表達(dá)式匹配IP地址,并將IP地址轉(zhuǎn)換成對應(yīng)數(shù)值的Javascript程序:

        復(fù)制代碼 代碼如下:
        function IP2V(ip)
        {
            re=/(d+).(d+).(d+).(d+)/g  //匹配IP地址的正則表達(dá)式
            if(re.test(ip))
            {
                return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
            }
            else
            {
                throw new Error(“Not a valid IP address!”)
            }
        }

        不過上面的程序如果不用正則表達(dá)式,而直接用split函數(shù)來分解可能更簡單,程序如下:

        復(fù)制代碼 代碼如下:
        var ip=”10.100.20.168″
        ip=ip.split(“.”)
        alert(“IP值是:”+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))

        匹配Email地址的正則表達(dá)式:

        復(fù)制代碼 代碼如下:
        w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*

        匹配網(wǎng)址URL的正則表達(dá)式:

        復(fù)制代碼 代碼如下:
        http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?

        利用正則表達(dá)式去除字串中重復(fù)的字符的算法程序:[*注:此程序不正確]

        復(fù)制代碼 代碼如下:
        var s=”abacabefgeeii”
        var s1=s.replace(/(.).*1/g,”$1″)
        var re=new RegExp(“[“+s1+”]”,”g”)
        var s2=s.replace(re,””)
        alert(s1+s2)  //結(jié)果為:abcefgi

        *注
        ===============================
        如果var s = “abacabefggeeii”
        結(jié)果就不對了,結(jié)果為:abeicfgg
        正則表達(dá)式的能力有限
        ===============================

        我原來在CSDN上發(fā)貼尋求一個表達(dá)式來實現(xiàn)去除重復(fù)字符的方法,最終沒有找到,這是我能想到的最簡單的實現(xiàn)方法。思路是使用后向引用取出包括重復(fù)的字符,再以重復(fù)的字符建立第二個表達(dá)式,取到不重復(fù)的字符,兩者串連。這個方法對于字符順序有要求的字符串可能不適用。

        得用正則表達(dá)式從URL地址中提取文件名的javascript程序,如下結(jié)果為page1

        復(fù)制代碼 代碼如下:
        s=”http://blog.penner.cn/page1.htm”
        s=s.replace(/(.*/){ 0, }([^.]+).*/ig,”$2″)
        alert(s)

        利用正則表達(dá)式限制網(wǎng)頁表單里的文本框輸入內(nèi)容:

        用正則表達(dá)式限制只能輸入中文:

        復(fù)制代碼 代碼如下:
        onkeyup=”value=value.replace(/[^u4E00-u9FA5]/g,”)” onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^u4E00-u9FA5]/g,”))”

        用正則表達(dá)式限制只能輸入全角字符:

        復(fù)制代碼 代碼如下:
        onkeyup=”value=value.replace(/[^uFF00-uFFFF]/g,”)” onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^uFF00-uFFFF]/g,”))”

        用正則表達(dá)式限制只能輸入數(shù)字:

        復(fù)制代碼 代碼如下:
        onkeyup=”value=value.replace(/[^d]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^d]/g,”))”

        用正則表達(dá)式限制只能輸入數(shù)字和英文:

        復(fù)制代碼 代碼如下:
        onkeyup=”value=value.replace(/[W]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^d]/g,”))”

        匹配非負(fù)整數(shù)(正整數(shù) + 0)

        復(fù)制代碼 代碼如下:
        ^d+$

        匹配正整數(shù)

        復(fù)制代碼 代碼如下:
        ^[0-9]*[1-9][0-9]*$

        匹配非正整數(shù)(負(fù)整數(shù) + 0)

        復(fù)制代碼 代碼如下:
        ^((-d+)|(0+))$

        匹配負(fù)整數(shù)

        復(fù)制代碼 代碼如下:
        ^-[0-9]*[1-9][0-9]*$

        匹配整數(shù)

        復(fù)制代碼 代碼如下:
        ^-?d+$

        匹配非負(fù)浮點數(shù)(正浮點數(shù) + 0)

        復(fù)制代碼 代碼如下:
        ^d+(.d+)?$

        匹配正浮點數(shù)

        復(fù)制代碼 代碼如下:
        ^(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*))$

        匹配非正浮點數(shù)(負(fù)浮點數(shù) + 0)

        復(fù)制代碼 代碼如下:
        ^((-d+(.d+)?)|(0+(.0+)?))$

        匹配負(fù)浮點數(shù)

        復(fù)制代碼 代碼如下:
        ^(-(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*)))$

        匹配浮點數(shù)

        復(fù)制代碼 代碼如下:
        ^(-?d+)(.d+)?$

        匹配由26個英文字母組成的字符串

        復(fù)制代碼 代碼如下:
        ^[A-Za-z]+$

        匹配由26個英文字母的大寫組成的字符串

        復(fù)制代碼 代碼如下:
        ^[A-Z]+$

        匹配由26個英文字母的小寫組成的字符串

        復(fù)制代碼 代碼如下:
        ^[a-z]+$

        匹配由數(shù)字和26個英文字母組成的字符串

        復(fù)制代碼 代碼如下:
        ^[A-Za-z0-9]+$

        匹配由數(shù)字、26個英文字母或者下劃線組成的字符串

        復(fù)制代碼 代碼如下:
        ^w+$

        匹配email地址

        復(fù)制代碼 代碼如下:
        ^[w-]+(.[w-]+)*@[w-]+(.[w-]+)+$

        匹配url

        復(fù)制代碼 代碼如下:
        ^[a-zA-z]+://匹配(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$

        匹配html tag

        復(fù)制代碼 代碼如下:
        <s*(S+)(s[^>]*)?>(.*?)<s*/1s*>

        Visual Basic & C# Regular Expression
        1.確認(rèn)有效電子郵件格式
        下面的示例使用靜態(tài) Regex.IsMatch 方法驗證一個字符串是否為有效電子郵件格式。如果字符串包含一個有效的電子郵件地址,則 IsValidEmail 方法返回 true,否則返回 false,但不采取其他任何操作。您可以使用 IsValidEmail,在應(yīng)用程序?qū)⒌刂反鎯υ跀?shù)據(jù)庫中或顯示在 ASP.NET 頁中之前,篩選出包含無效字符的電子郵件地址。

        [Visual Basic]

        復(fù)制代碼 代碼如下:
        Function IsValidEmail(strIn As String) As Boolean
        ‘ Return true if strIn is in valid e-mail format.
        Return Regex.IsMatch(strIn, (“^([w-.]+)@(([[0-9]{ 1,3 }.[0-9]{ 1,3 }.[0-9]{ 1,3 }.)|(([w-]+.)+))([a-zA-Z]{ 2,4 }|[0-9]{ 1,3 })(]?)$”)
        End Function

        [C#]

        復(fù)制代碼 代碼如下:
        bool IsValidEmail(string strIn)
        {
        // Return true if strIn is in valid e-mail format.
        return Regex.IsMatch(strIn, @”^([w-.]+)@(([[0-9]{ 1,3 }.[0-9]{ 1,3 }.[0-9]{ 1,3 }.)|(([w-]+.)+))([a-zA-Z]{ 2,4 }|[0-9]{ 1,3 })(]?)$”);
        }

        2.清理輸入字符串
        下面的代碼示例使用靜態(tài) Regex.Replace 方法從字符串中抽出無效字符。您可以使用這里定義的 CleanInput 方法,清除掉在接受用戶輸入的窗體的文本字段中輸入的可能有害的字符。CleanInput 在清除掉除 @、-(連字符)和 .(句點)以外的所有非字母數(shù)字字符后返回一個字符串。

        [Visual Basic]

        復(fù)制代碼 代碼如下:
        Function CleanInput(strIn As String) As String
        ‘ Replace invalid characters with empty strings.
        Return Regex.Replace(strIn, “[^w.@-]”, “”)
        End Function

        [C#]

        復(fù)制代碼 代碼如下:
        String CleanInput(string strIn)
        {
            // Replace invalid characters with empty strings.
            return Regex.Replace(strIn, @”[^w.@-]”, “”);
        }

        3.更改日期格式
        以下代碼示例使用 Regex.Replace 方法來用 dd-mm-yy 的日期形式代替 mm/dd/yy 的日期形式。

        [Visual Basic]

        復(fù)制代碼 代碼如下:
        Function MDYToDMY(input As String) As String
        Return Regex.Replace(input, _
        “b(?<month>d{ 1,2 })/(?<day>d{ 1,2 })/(?<year>d{ 2,4 })b”, _
        “${ day }-${ month }-${ year }”)
        End Function

        [C#]

        復(fù)制代碼 代碼如下:
        String MDYToDMY(String input)
        {
            return Regex.Replace(input,”\b(?<month>\d{ 1,2 })/(?<day>\d{ 1,2 })/(?<year>\d{ 2,4 })\b”,”${ day }-${ month }-${ year }”);
        }

        Regex 替換模式
        本示例說明如何在 Regex.Replace 的替換模式中使用命名的反向引用。其中,替換表達(dá)式 ${ day } 插入由 (?…) 組捕獲的子字符串。

        有幾種靜態(tài)函數(shù)使您可以在使用正則表達(dá)式操作時無需創(chuàng)建顯式正則表達(dá)式對象,而 Regex.Replace 函數(shù)正是其中之一。如果您不想保留編譯的正則表達(dá)式,這將給您帶來方便

        4.提取 URL 信息
        以下代碼示例使用 Match.Result 來從 URL 提取協(xié)議和端口號。例如,“http://www.penner.cn:8080……將返回“http:8080”。

        [Visual Basic]

        復(fù)制代碼 代碼如下:
        Function Extension(url As String) As String
        Dim r As New Regex(“^(?<proto>w+)://[^/]+?(?<port>:d+)?/”, _
        RegexOptions.Compiled)
        Return r.Match(url).Result(“${ proto }${ port }”)
        End Function

        [C#]

        復(fù)制代碼 代碼如下:
        String Extension(String url)
        {
            Regex r = new Regex(@”^(?<proto>w+)://[^/]+?(?<port>:d+)?/”,
            RegexOptions.Compiled);
            return r.Match(url).Result(“${ proto }${ port }”);
        }

        只有字母和數(shù)字,不小于6位,且數(shù)字字母都包含的密碼的正則表達(dá)式
        在C#中,可以用這個來表示:

        復(fù)制代碼 代碼如下:
        “w{ 6 }(w+)*”

        一個將需要將路徑字符串拆分為根目錄和子目錄兩部分的算法程序,考慮路徑格式有:C:aabbcc ,\aabbcc , ftp://aa.bb/cc 上述路徑將分別被拆分為:C:和aabbcc ,\aa 和 bbcc , ftp:// 和 aa.bb/cc 用javascript實現(xiàn)如下:

        復(fù)制代碼 代碼如下:
        var strRoot,strSub
        var regPathParse=/^([^\^/]+[\/]+|\\[^\]+)(.*)$/
        if(regPathParse.test(strFolder))
        {
            strRoot=RegExp.$1
            strSub=RegExp.$2
        }

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
        主站蜘蛛池模板: 热综合一本伊人久久精品| 成人午夜精品网站在线观看| 久久精品国产亚洲av高清漫画| 99免费精品国产| 69国产成人综合久久精品| 亚洲精品成人网久久久久久| 国产日韩久久久精品影院首页 | 国产免费伦精品一区二区三区| 国产99视频精品免视看7| 亚洲色精品aⅴ一区区三区| 精品伦精品一区二区三区视频| 久久亚洲精品视频| 国产伦精品一区二区三区女| 精品久久久久久久无码| 日韩欧精品无码视频无删节| 亚洲国产精品碰碰| 人妻无码精品久久亚瑟影视| 麻豆精品国产自产在线观看一区| 国产精品福利区一区二区三区四区| 久久精品www| 日本精品卡一卡2卡3卡四卡| 国产91大片精品一区在线观看| 国产精品三级国产电影| 久久久久亚洲精品无码蜜桃| 亚洲精品无码高潮喷水在线| 亚洲国产精品成人网址天堂| 欧美人与性动交α欧美精品成人色XXXX视频| 国产精品午夜免费观看网站| 国产精品成人啪精品视频免费| 99精品国产一区二区| 成人精品一区二区三区免费看| 99久久国产热无码精品免费久久久久| 麻豆精品久久久一区二区| 色花堂国产精品第一页| 国产高清精品一区| 国产精品麻豆欧美日韩ww| 国产综合成人色产三级高清在线精品发布 | 国产日韩一区在线精品欧美玲| 国产精品国产三级国产专播| 国产成人精品亚洲日本在线| 国产精品一国产精品|