摘要:按照這個說法,在還是行不通的,應(yīng)該得到,得到?jīng)]問題,有些摸不到邊了,所以自定義一下這個方法以便備用總結(jié)日益強大,各種語言逐步向它靠近。開發(fā)中一般時間很緊迫,好多東西都沒工夫想,所以還有很多要優(yōu)化的地方,有時候,放慢腳步,可能也是一種進步吧
Jquery再熟悉不過,其中的$.ajax封裝也不陌生,其中
$.ajax({ url:url, type:"GET", data:data, success:function(res){ }, error:function(err){ } });
以前比較喜歡success固定回調(diào)這種寫法,很清晰
接下來實現(xiàn)success和error這種語法
var $={ ajax(call){ if(call.bol){ call.success("成功的回調(diào)"); }else{ console.error("bol is undefined");//提示 } } }
調(diào)用:
$.ajax({ bol:false,//切換bol存在即可調(diào)用成功回調(diào) success:function(res){ console.log(res); }, error:function(err){ console.log(err); } });
類似物流信息,后臺返回一個字符串,前端識別出連續(xù)的11位數(shù)字,并且可撥打電話
做這里的時候,想要跟后臺多要一個字段為電話,前端再a標(biāo)簽直接包起來。但是后臺接的也是三方,三方返回就是一個整串......
后來仔細想想這個流程,即使后臺多給一個字段,這需求一樣做不完美
比如這個串是這樣的:
"您的快遞正在配送,配送員電話:17600699305,某某快遞持續(xù)為您服務(wù)"
后臺分了倆字段
"str1=您的快遞正在配送,配送員電話:,某某快遞持續(xù)為您服務(wù)" str2="17600699305"
這個str2插到str1的哪里呢?顯然也不好弄。
那還不如不麻煩后臺,前端自己消化。
"識別連續(xù)的11位數(shù)字",第一想到的就是正則:
var str="您的快遞正在配送,配送員電話:17600699305,某某快遞持續(xù)為您服務(wù)",strCon=str.match(/d{11}/);
match符合條件會返回一個數(shù)組,包含 匹配到的內(nèi)容,內(nèi)容的開始下標(biāo),整個內(nèi)容,還有個groups(求釋義)
接下來封裝實現(xiàn):
function continuFunc(str){ var strBol=str.match(/d{11}/); if(strBol){ return strBol.input.slice(0,strBol.index)+""+strBol[0]+""+strBol.input.slice(strBol.index+strBol[0].length,str.length); } }
就是分成三個部分返回,以匹配到的11位連續(xù)數(shù)字為節(jié)點,前后各為兩部分,再進行拼接。
index就是匹配區(qū)的開始下標(biāo),所以第一部分從0取到下標(biāo),第二部分已經(jīng)返回,第三部分取index+字符長度(11)——結(jié)尾
toFixed()方法如何實現(xiàn)(保留n位小數(shù))
剛開始看到是不是很慌,這方法調(diào)用的時候都是Number.toFixed(),而常規(guī)的函數(shù)封裝都是
function Func(argu){ return argu; }
調(diào)用都是Func("調(diào)用");,很慌。
這種函數(shù)基本都是綁定在原型上的,不難發(fā)現(xiàn),調(diào)用toFixed方法的都是Number類型,所以toFixed方法應(yīng)該就是綁定在Number的prototype了,接下來分析內(nèi)部實現(xiàn)問題
Number.prototype.toDiyFixed=function(n){ return (Math.round(this * Math.pow( 10, n ))/ Math.pow( 10, n)).toString(); }
調(diào)用:var num=100.123, a.toDiyFixed(2)得到100.12。
toDiyFixed方法就成功的copy了toFixed方法。
就a=100.123這個例子講實現(xiàn)原理:把原數(shù) num先乘以100(n是多少就乘以10的幾次方),再進行四舍五入,(去除小數(shù)兩位之后的小數(shù),因為乘以100以后,前兩位小數(shù)已經(jīng)變?yōu)檎麛?shù)部分,四舍五入操作就不會影響了),至此完成保留2(n)位小數(shù)的操作。
注意:但是,這個方法有個問題,就是不會自動向末尾補0,比如說100.196保留兩位小數(shù)應(yīng)該得到100.20,但是該方法只能拿到100.2,100.201應(yīng)該得到100.20,但該方法得到100.2,目前還沒想到解決辦法,歡迎一起交流探討,但是基礎(chǔ)功能可以實現(xiàn).
另外說個原生toFixed的bug:
0.7.toFixed(0)發(fā)現(xiàn)得到的是1(IE)
0.035和0.045保留兩位小數(shù)后得到的都是0.04(Chrom),當(dāng)然如果覺得這點誤差無所謂,10.35、10.45保留兩位小數(shù)得到10.3、10.4發(fā)現(xiàn)都是錯的,這是不容小覷的數(shù)字了吧,后來查閱資料說,js的toFixed方法用的是”銀行家算法“,實質(zhì)就是 ”四舍六入無成雙“,那啥意思呢,當(dāng)舍去位的數(shù)值小于5時,直接舍去該位;當(dāng)舍去位的數(shù)值大于等于6時,在舍去該位的同時向前位進一;當(dāng)舍去位的數(shù)值等于5時,如果前位數(shù)值為奇,則在舍去該位的同時向前位進一,如果前位數(shù)值為偶,則直接舍去該位。
按照這個說法,在Chrom還是行不通的,10.35應(yīng)該得到10.4,10.45得到10.4沒問題,有些摸不到邊了,所以自定義一下toDiyFixed這個方法以便備用
javaScript日益強大,各種語言逐步向它靠近。(??) 開發(fā)中一般時間很緊迫,好多東西都沒工夫想,所以還有很多要優(yōu)化的地方,有時候,放慢腳步,可能也是一種進步吧!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/96161.html
摘要:還以為我是一個失業(yè)青年,后來想想,后已經(jīng)是中年了。對于各路框架,還是根據(jù)業(yè)務(wù)需求去學(xué)習(xí)比較好,相信自己的學(xué)習(xí)能力。我還是先鞏固一下數(shù)據(jù)結(jié)構(gòu)和算法吧。數(shù)據(jù)結(jié)構(gòu)與算法的描述針對自己目前所處的環(huán)境,就用來描述常用的數(shù)據(jù)結(jié)構(gòu)跟常用的算法。 失業(yè)中年 前段時間,帶我出道的CTO要帶我去創(chuàng)業(yè),然后,之前談好的技術(shù)方案在我過去之后都沒能開始,怪可惜的,甚至,他自己都背鍋離職了。再后來,股東突然撤資了...
摘要:對于第一種方式,回顯時只需要將從后臺獲取的數(shù)據(jù)拼接在一起就行,對于第二種方式,需要去進行循環(huán)對比,找出對應(yīng)的索引值然后進行賦值,具體代碼在這里。 距離上篇文章已經(jīng)快九個月了,我是不是墮落了。。這篇文章主要是記錄我在項目中遇到的一個小問題,其實說小也不小,在去年剛接觸vue的時候,對于select如何綁定多個值這個問題一度讓我不知所措。剛開始完全沒接觸過vue和elementUI直接上手...
摘要:協(xié)程的判斷條件下面我們來著重看下的源碼,因為從這里開始就涉及到協(xié)程的判斷。第二點是關(guān)鍵點,用來判斷該方法的調(diào)用是否使用到了協(xié)程。原理我們先來看下使用協(xié)程是怎么寫的這是一個標(biāo)準(zhǔn)的協(xié)程寫法,然后我們再套用上面的條件,發(fā)現(xiàn)完全匹配不到。 第一眼看,跟我之前印象中的有點區(qū)別(也不知道是什么版本),return的時候居然...
閱讀 2647·2021-09-02 15:40
閱讀 1627·2019-08-30 15:54
閱讀 1139·2019-08-30 12:48
閱讀 3469·2019-08-29 17:23
閱讀 1102·2019-08-28 18:04
閱讀 3718·2019-08-26 13:54
閱讀 657·2019-08-26 11:40
閱讀 2471·2019-08-26 10:15