javascript框架設(shè)計(jì)讀書筆記之字符串的擴(kuò)展和修復(fù)
1.repeat方法:將一個(gè)字符串重復(fù)自身n次。比如:repeat("chaojidan",2) -> chaojidanchaojidan
方法1:
function repeat(str,n){
return Array.prototype.join.call({length:n+1},str);
//在類數(shù)組{length:n+1}上下文下執(zhí)行join方法,并傳入str。也就是用str來(lái)分隔類數(shù)組的選項(xiàng),類數(shù)組是空,所以就有n個(gè)str分隔n+1個(gè)"",得到的結(jié)果就是n個(gè)str連接。
}
方法2:
function repeat(str,n){
var s = str ,total = "";
while(n>0){
//假設(shè)n是5,n%2后,等于1,因此total = str.s=strstr。n=2.第二次循環(huán):s=strstrstrstr,n=1.第三次循環(huán)total = strstrstrstrstr,break,跳出循環(huán),返回total,剛好是str重復(fù)了5次的字符串
if(n%2 ==1){
total + =s; //這里是2的0次方,也就是1,所有的正整數(shù),都可以使用1,2,4,8....進(jìn)行組合。比如:3=1+2,5=1+4,7=1+2+4.
}
if(n==1) break;
s+=s; //這里利用的是2的冪次方,2,4,8.....
n = n>>1;
}
return total ;
}
2.取字符串所有字節(jié)的長(zhǎng)度:str.charCodeAt(i) >255 就把str的長(zhǎng)度加一次就OK了.
3.轉(zhuǎn)換駝峰風(fēng)格:str.replace(/[-_][^-_]/g,function(match){return match.charAt(1).toUpperCase();})
//-_在[]中,不需要使用\,并且^在[]中是代表反的意思,就是遇到-a或_a,就被替換成A(match就是正則匹配的字符串_a,然后取a,并且大寫)
4.轉(zhuǎn)換為下劃線風(fēng)格:str.replace(/([a-z\d])([A-Z])/g,'$1_$2').replace(/\-/g,'_').toLowerCase();
//第一個(gè)replace,匹配cA,或者4A的字符串,然后用c_A或4_A替換。$1代表第一個(gè)子表達(dá)式。第二個(gè)replace就是使用_替換-。由于-不在[]中,所以需要加\。
5.去掉字符串中的html標(biāo)簽:str.replace(/<[^>]+>/g,''),這里面會(huì)把script標(biāo)簽去掉,但是不會(huì)去掉script中的js腳本
6.去掉script標(biāo)簽,并且移除里面的js腳本:str.replace(/<script[^>]*>(\S\s)*?)<\/script>/img,'')
/需要用\,防止轉(zhuǎn)義。
//(\S\s)*?)盡可能少的匹配,非貪婪匹配。舉個(gè)例子:<script>aaa</script>dddd<script>bbbb</script>,會(huì)先匹配<script>aaa</script>,再匹配<script>bbbb</script>,如果沒(méi)加?,將是貪婪匹配,將會(huì)把<script>aaa</script>dddd<script>bbbb</script>全部匹配掉,連字符串dddd都去掉了。
7.將字符串經(jīng)過(guò)html轉(zhuǎn)義,得到適合在頁(yè)面中顯示的內(nèi)容.
str.replace(/&/g,'&').replace(/</g,'<').replace(/>/g,'>').replace(/"/g,'"').replace(/'/g,''');
8.將字符串的html實(shí)體字符換成對(duì)應(yīng)字符:
跟7相反,只是多了一個(gè)replace(/&#([\d]+);/g,function($0,$1){ return String.fromCharCode(parseInt($1,10)) }) //$1就是第一個(gè)子表達(dá)式匹配項(xiàng)。
9.trim:str.replace(/^\s+ | \s+$/g,'') ,IE或早期的標(biāo)準(zhǔn)瀏覽器,把許多本屬于空白的字符沒(méi)有列為\s中,因此會(huì)有bug。不過(guò),又何必執(zhí)著兼容淘汰的瀏覽器呢。
- 十大熱門的JavaScript框架和庫(kù)
- 深入解析JavaScript框架Backbone.js中的事件機(jī)制
- JavaScript框架是什么?怎樣才能叫做框架?
- 超贊的動(dòng)手創(chuàng)建JavaScript框架的詳細(xì)教程
- javascript框架設(shè)計(jì)之類工廠
- javascript框架設(shè)計(jì)之瀏覽器的嗅探和特征偵測(cè)
- javascript框架設(shè)計(jì)之種子模塊
- javascript框架設(shè)計(jì)之框架分類及主要功能
- 2014 年最熱門的21款JavaScript框架推薦
- javascript框架設(shè)計(jì)讀書筆記之?dāng)?shù)組的擴(kuò)展與修復(fù)
- javascript框架設(shè)計(jì)讀書筆記之模塊加載系統(tǒng)
- javascript框架設(shè)計(jì)讀書筆記之種子模塊
- JavaScript框架(iframe)操作總結(jié)
- 怎么選擇Javascript框架(Javascript Framework)
- 詳細(xì)介紹8款超實(shí)用JavaScript框架
- brook javascript框架介紹
- 16個(gè)最流行的JavaScript框架[推薦]
- 如何選擇適合你的JavaScript框架
相關(guān)文章
Js 代碼中,ajax請(qǐng)求地址后加隨機(jī)數(shù)防止瀏覽器緩存的原因
Js 代碼中,ajax請(qǐng)求地址后加隨機(jī)數(shù)防止瀏覽器緩存的原因,需要的朋友可以參考一下2013-05-05
Three光源Target位置改變光照方向不變的問(wèn)題解決方法
這篇文章主要為大家介紹了Three光源Target位置改變光照方向不變的問(wèn)題及解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12
JS小球拋物線軌跡運(yùn)動(dòng)的兩種實(shí)現(xiàn)方法詳解
這篇文章主要介紹了JS小球拋物線軌跡運(yùn)動(dòng)的兩種實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了javascript實(shí)現(xiàn)小球拋物線運(yùn)動(dòng)的相關(guān)計(jì)算與圖形繪制操作技巧,需要的朋友可以參考下2017-12-12
JS實(shí)現(xiàn)超簡(jiǎn)單的漢字轉(zhuǎn)拼音功能示例
這篇文章主要介紹了JS實(shí)現(xiàn)超簡(jiǎn)單的漢字轉(zhuǎn)拼音功能,結(jié)合實(shí)例形式分析了javascript漢字轉(zhuǎn)換成拼音的函數(shù)定義與使用技巧,需要的朋友可以參考下2016-12-12
使用微信內(nèi)嵌H5網(wǎng)頁(yè)解決JS倒計(jì)時(shí)失效問(wèn)題
最近參考項(xiàng)目開發(fā),遇到這樣一個(gè)需求將H5商城頁(yè)面嵌套到公司微信公眾號(hào)里,在開發(fā)遇到一個(gè)棘手的問(wèn)題,js倒計(jì)時(shí)失效問(wèn)題,怎么回事呢?下面說(shuō)下我使用微信內(nèi)嵌h5解決的這一問(wèn)題,需要的朋友參考下吧2017-01-01
js實(shí)現(xiàn)前端界面導(dǎo)航欄下拉列表
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)前端界面導(dǎo)航欄下拉列表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08
JavaScript是如何實(shí)現(xiàn)繼承的(六種方式)
大多OO語(yǔ)言都支持兩種繼承方式: 接口繼承和實(shí)現(xiàn)繼承 ,而ECMAScript中無(wú)法實(shí)現(xiàn)接口繼承,ECMAScript只支持實(shí)現(xiàn)繼承,而且其實(shí)現(xiàn)繼承主要是依靠原型鏈來(lái)實(shí)現(xiàn),下文給大家技術(shù)js實(shí)現(xiàn)繼承的六種方式,需要的朋友參考下2016-03-03

