1.repeat方法:將一個字串重複自身n次。如:repeat("chaojidan",2) -> chaojidanchaojidan
方法1:
方法2:
2.取字串所有位元組的長度:str.charCodeAt(i) >255 就把str的長度加一次就OK了.
3.轉換駝峰風格:str.replace(/[-_][^-_]/g,function(match){return match.charAt(1).toUpperCase();})
//-_在[]中,不需要使用,並且^在[]中是代表反的意思,就是遇到-a或_a,就被替換成A(match就是正則匹配的字符串_a,然後取a,並且大寫)
4.轉換為底線風格:str.replace(/([a-zd])([A-Z])/g,'$1_$2').replace(/-/g,'_').toLowerCase ();
//第一個replace,匹配cA,或4A的字串,然後用c_A或4_A替換。 $1代表第一個子表達式。第二個replace就是使用_替換-。由於-不在[]中,所以需要加。
5.去掉字串中的html標籤:str.replace(/] >/g,''),這裡面會把script標籤去掉,但是不會去掉script中的js腳本
6.去掉script標籤,並且移除裡面的js腳本:str.replace(/<script>]*>(Ss)*?)</script>/img,'')
/需用,防止轉義。
//(Ss)*?)盡可能少的匹配,非貪婪匹配。舉例:<script>aaa</script>dddd<script>bbbb</script>,會先配對<script>aaa</script>,再配對<script>bbbb</script>,若沒加?,將會是貪婪匹配,會把<script>aaa</script>dddd<script>bbbb</script>全部匹配掉,連字串dddd都去掉了。
7.將字串經過html轉義,得到適合在頁面中顯示的內容.
str.replace(/&/g,'&').replace(/,'/g,'>').replace(/"/g,'" ').replace(/'/g,''');
8.將字串的html實體字元換成對應字元:
跟7相反,只是多了一個replace(/([d] );/g,function($0,$1){ return String.fromCharCode(parseInt($1,10)) }) //$1就是第一個子表達式匹配項。
9.trim:str.replace(/^s | s $/g,'') ,IE或早期的標準瀏覽器,把許多本屬於空白的字元沒有列為s中,因此會有bug。不過,又何必執著與淘汰的瀏覽器。