使用JS中的Replace()方法遇到的問題小結(jié)
今天在寫pc客戶端自動化打包腳本的時候遇到遇到了幾個問題,雖然是小問題,但是也卡了一段時間,所以決定記錄一下。
js的replace()方法是用于替換某些內(nèi)容,它可以接收兩個參數(shù),第一個是一個被替換的正則表達(dá)式對象或者一個字符串,第二個可以是將要替換成的內(nèi)容或者函數(shù),將要替換成的內(nèi)容須是一個字符串。我在執(zhí)行的時候遇到的報錯是:Cannot read property ‘replace' of undefined。具體代碼如下:
var fs=require("fs") var infoPlistFile = osxFolder + '/Contents/Info.plist'; var infoPlist = fs.readFile(infoPlistFile); fs.writeFile(infoPlistFile, infoPlist.replace(/Pexip Infinity Connect/gm, $scope.manifest.name));
當(dāng)執(zhí)行這段代碼的時候得到的報錯是無法獲取未定義的屬性replace,開始不知道問題出在哪里,然后試著打印出被替換的文件infoPlist,發(fā)現(xiàn)是null,然后就知道是定義infoPlist那里出現(xiàn)問題,修改成fs.readFileSync之后發(fā)現(xiàn)就沒有這個報錯了,但是又有一個新的報錯:replace is not a function
查找了一下相關(guān)資料,說明對應(yīng)的變量不是字符串,而是其他的類型,所以我打印了一下infoPlist的類型,打印出來的是object,所以問題是出在這里,因為infoPlist的類型不對,所以導(dǎo)致了報錯,于是增加了處理成字符串的操作,于是就可以了
var infoPlistFile = osxFolder + '/Contents/Info.plist'; var infoPlist = readFile(infoPlistFile).toString(); writeFile(infoPlistFile, infoPlist.replace(/Pexip Infinity Connect/gm, $scope.manifest.name));
另外我在自己寫demo做測試的時候還發(fā)現(xiàn),如果沒有一個變量來接收的話,replace()方法是不起作用的,如:
var str="Hello World"; str.replace(/World/g, "dxy"); console.log(str);
這個時候打印出來的str還是”Hello World”,是沒有替換的,這里應(yīng)該用一個變量來作為接收,替換原來的變量,如:
var str="Hello World"; var a=str.replace(/World/g, "dxy"); console.log(a);
這個時候打印的結(jié)果就是”Hello dxy”。
總結(jié):這次在使用replace()方法的時候讓我注意到以下幾個問題:
1、在使用replace()方法的時候首先要確保不能在null或undefined類型的變量上調(diào)用。我們可以給它增加一個判斷,如果變量有值的時候才調(diào)用方法。
2、執(zhí)行replace()方法的時候的變量不僅是要有值,還必須是字符串類型的。
3、js不是自動賦值的,執(zhí)行一個方法,要么是在方法里直接執(zhí)行,要么是返回結(jié)果,返回結(jié)果的時候需要通過一個變量去接收。
4、如果第一個參數(shù)傳的是一個正則表達(dá)式的話,是不能加引號的。
以上所述是小編給大家介紹的使用JS中的Replace()方法遇到的問題小結(jié),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
javascript 制作坦克大戰(zhàn)游戲初步 圖片與代碼
javascript 制作坦克大戰(zhàn)游戲初步 圖片與代碼...2007-11-11layui自己添加圖片按鈕并點(diǎn)擊跳轉(zhuǎn)頁面的例子
今天小編就為大家分享一篇layui自己添加圖片按鈕并點(diǎn)擊跳轉(zhuǎn)頁面的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09ionic js 復(fù)選框 與普通的 HTML 復(fù)選框到底有沒區(qū)別
本文通過實例給大家演示ionic js 復(fù)選框 與普通的 HTML 復(fù)選框到底有沒區(qū)別的相關(guān)知識,非常不錯具有參考借鑒價值,感興趣的朋友一起學(xué)習(xí)吧2016-06-06JS中使用apply、bind實現(xiàn)為函數(shù)或者類傳入動態(tài)個數(shù)的參數(shù)
這篇文章主要介紹了JS中使用apply、bind實現(xiàn)為函數(shù)或者類傳入動態(tài)個數(shù)的參數(shù)的相關(guān)資料,需要的朋友可以參考下2016-04-04