一些前台的正則運行,你可以修改下成為php的
匹配雙字節字符(包括漢字在內): [^\x00-\xff]
應用:計算字串的長度(一個雙位元組字元長度計2,ASCII字元計1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
符合空行的正規表示式: \n[\s| ]*\r
符合HTML標記的正規表示式: /db05f8e866f47612e82f5cb19e67888c.*0e1c620fd1f13d4254a0bb23aec420ea|07579c93b282311247703517f95aa094/
符合首尾空格的正規表示式: (^\s*)|(\s*$)
# 應用:javascript中沒有像vbscript那樣的trim函數,我們就可以利用這個表達式來實現,如下:
String.prototype.trim = function() { return this.replace(/(^\s*)|(\s*$)/g, ""); }
利用正規表示式分解和轉換IP位址:
下面是利用正規表示式來匹配IP位址,並將IP位址轉換成對應數值的javascript程式:
function IP2V(ip) { re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //匹配IP地址的正则表达式 if(re.test(ip)) { return RegExp.*Math.pow(255,3))+RegExp.*Math.pow(255,2))+RegExp.*255+RegExp.*1 } else { throw new Error("Not a valid IP address!") } }
不過上面的程式如果不用正規表示式,而直接用split函數來分解可能更簡單,程式如下:
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+)*
符合網址URL的正規表示式: http://([\w-]+\.)+[\w-]+(/[ \w- ./?%&=]*)?
利用正規表示式移除字串中重複的字元的演算法程式:
var s="abacabefgeeii" var s1=s.replace(/(.).*/g,"") var re=new RegExp("["+s1+"]","g") var s2=s.replace(re,"") alert(s1+s2) //结果为:abcefgi
用正規表示式從URL位址中提取檔案名稱的javascript程序,如下結果為page1
s="http://www.php.cn/page1.htm" s=s.replace(/(.*\/)([^\.]+).*/ig,"") alert(s)
利用正規表示式限制網頁表單裡的文字方塊輸入內容:
# 用正規表示式限制只能輸入中文:
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,''))"
用正規表示式限制只能輸入數字:
onkeyup="value=value.replace(/[^ \d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"
用正規表示式限制只能輸入數字和英文:
onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text ',clipboardData.getData('text').replace(/[^\d]/g,''))
以上是php常用的正規表示式字元轉換詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!