<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    莊周夢蝶

    生活、程序、未來
       :: 首頁 ::  ::  :: 聚合  :: 管理

    oh,my god.我終于能看懂正則表達式咯

    Posted on 2007-03-07 09:54 dennis 閱讀(1749) 評論(1)  編輯  收藏 所屬分類: web開發(fā)
    ??? 最近一直在讀《javascript高級程序設(shè)計》的正則表達式章節(jié),終于對我一直搞不明白的正則表達式開始有點感覺了,別人寫的表達式基本也能看懂了,可要自己熟練地寫還需要多多練習。推薦一個學習正則表達式的地方,javaeye的正則表達式專欄以及正則表達式工作室

    常用正則表達式,掌握了規(guī)則,看懂這些表達式并不困難,當然,要達到熟練寫的程度就不那么容易了。

    匹配中文字符的正則表達式: [\u4e00-\u9fa5]

    匹配雙字節(jié)字符(包括漢字在內(nèi)):[^\x00-\xff]

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

    String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}

    匹配空行的正則表達式:\n[\s| ]*\r

    匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*) \/>/

    匹配首尾空格的正則表達式:(^\s*)|(\s*$)

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

    String.prototype.trim = function()
    {
    return this.replace(/(^\s*)|(\s*$)/g, "");
    }

    利用正則表達式分解和轉(zhuǎn)換IP地址:

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

    function IP2V(ip)
    {
    re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //匹配IP地址的正則表達式
    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!")
    }
    }

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

    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地址的正則表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

    匹配網(wǎng)址URL的正則表達式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?

    利用正則表達式去除字串中重復(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

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

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

    s="http://www.gzcynet/page1.htm"
    s=s.replace(/(.*\/){0,}([^\.]+).*/ig,"$2")
    alert(s)

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

    用正則表達式限制只能輸入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"

    用正則表達式限制只能輸入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"

    用正則表達式限制只能輸入數(shù)字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

    用正則表達式限制只能輸入數(shù)字和英文:onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"



    評論

    # re: oh,my god.我終于能看懂正則表達式咯  回復(fù)  更多評論   

    2007-03-08 08:43 by 壞男孩
    這個東西看起來,貌似有點難度,理解意思不深究了
    主站蜘蛛池模板: 国产99视频免费精品是看6| 久久亚洲免费视频| 免费a级毛片高清视频不卡| 亚洲A∨无码无在线观看| 黄色毛片免费观看| 亚洲区日韩区无码区| 风间由美在线亚洲一区| 在线日韩av永久免费观看| 亚洲日韩精品国产3区| 麻豆国产人免费人成免费视频| 国产精品高清视亚洲一区二区| 午夜视频免费成人| 香港经典a毛片免费观看看| 四虎影视永久免费视频观看| 在线观看亚洲免费| 国产成人亚洲精品91专区手机| 国产精品高清免费网站| 国产亚洲精品xxx| 亚洲高清免费在线观看| 久久亚洲日韩看片无码| 青青青免费国产在线视频小草| 亚洲日韩看片无码电影| 九月婷婷亚洲综合在线| 国产永久免费高清在线| 久久亚洲AV无码精品色午夜| 国语成本人片免费av无码| 羞羞视频网站免费入口| 亚洲一区二区三区自拍公司| 免费A级毛片无码视频| 亚洲人成图片网站| 亚洲国产成人VA在线观看| 青柠影视在线观看免费高清 | 亚洲日本一线产区和二线| 日本二区免费一片黄2019| 国产视频精品免费视频| 日本久久久久亚洲中字幕| 嫩草影院在线免费观看| 中文字幕高清免费不卡视频 | 亚洲午夜成人精品无码色欲| 亚洲国产精品一区二区第四页| 嫩草影院在线播放www免费观看|