javascript大坑,javascript太難了

那些年趟過(guò)的OC與JS交互的坑

以前在項(xiàng)目中很少用到OC和JS交互,所以對(duì)這方面沒(méi)有進(jìn)行更加深入的了解,最近公司安排的一個(gè)項(xiàng)目;一半的內(nèi)容是用h5寫的;所以在這個(gè)過(guò)程中需要OC和JS進(jìn)行無(wú)縫對(duì)接,互相頻繁調(diào)用。在做的過(guò)程中出現(xiàn)了一些問(wèn)題,這里總結(jié)出現(xiàn),希望能給大家一些啟示。

創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的恩施土家網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

一.在webview中如果項(xiàng)目只是想簡(jiǎn)單用一下js和oc進(jìn)行交互,就沒(méi)有必要搞的那么麻煩,只需要用下面的方式進(jìn)行處理就行.

1.oc調(diào)用js;例如,在js中有一個(gè)叫commit的方法,在oc中咱們可以這樣來(lái)調(diào)用它

如果你調(diào)用的js函數(shù)需要傳入?yún)?shù),也不要緊,咱們只需要通過(guò)字符串拼接的方式將參數(shù)傳入即可。比如當(dāng)前有一個(gè)叫sum(a,b)的js函數(shù),在oc中咱們可以這樣來(lái)調(diào)用它---(注意:在內(nèi)部參數(shù)要用' '來(lái)將參數(shù)括起來(lái),這是因?yàn)閔tml函數(shù)傳參方式跟oc的不同,我們必須要按照html的傳參方式傳入才會(huì)有效果)

2.js調(diào)用oc;以前js調(diào)用oc是通過(guò)在webview這邊攔截js那邊觸發(fā)的http請(qǐng)求的url地址來(lái)判斷是不是我們需要調(diào)用的時(shí)機(jī),然后再調(diào)用的oc。如果當(dāng)我們?cè)趙ebview上點(diǎn)擊一個(gè)按鈕的時(shí)候他會(huì)跳轉(zhuǎn)到這個(gè)頁(yè)面,那么我們?cè)趏c這邊就可以通過(guò)攔截這個(gè)地址做一些事情

二.其實(shí),通過(guò)上面的方法是可以達(dá)到j(luò)s和oc之間進(jìn)行通訊,但是它也是存在一些弊端,或者說(shuō)有時(shí)候不是很方便的。在ios7以后蘋果官方將javascriptCore框架給開放出來(lái)了,我們這個(gè)通過(guò)這個(gè)框架就可以暢通無(wú)阻的讓js和oc之間進(jìn)行相互調(diào)用了。

1.通過(guò)javascriptCore來(lái)進(jìn)行js和oc互相調(diào)用。第一步就是要進(jìn)入javascriptCore這個(gè)框架.

之后就可以在需要使用的控制器中導(dǎo)入javascriptCore框架了,并且如果你需要js來(lái)調(diào)用oc,并且在js中的觸發(fā)函數(shù)是native.submit(a,b)類型的,那么你需要將js方法和oc方法進(jìn)行關(guān)聯(lián),這樣處理以后,調(diào)用js對(duì)應(yīng)的方法就會(huì)觸發(fā)oc對(duì)應(yīng)的方法,當(dāng)然,JSContext對(duì)象也是必須的,這個(gè)對(duì)象是js和oc關(guān)聯(lián)起來(lái)的工具,所有的js和oc調(diào)用都需要通過(guò)它來(lái)完成。

然后在webViewDidFinishLoad:中我們需要進(jìn)行下面的步驟,關(guān)聯(lián)native方法,是在當(dāng)js方法中有native.submit()類型函數(shù)的時(shí)候才需要綁定的,如果沒(méi)有這種類型的就不需要綁定。

注:其實(shí)通過(guò)上面的方法把self.context的native方法跟self綁定是會(huì)發(fā)生很嚴(yán)重的內(nèi)存泄露問(wèn)題的。因?yàn)檫@樣會(huì)造成self被相互持有,導(dǎo)致該對(duì)象無(wú)法被釋放,解決方案是native指定一個(gè)新的對(duì)象,然后在指定對(duì)象里實(shí)現(xiàn)JSExport協(xié)議。

接下來(lái)就是非native.submit()形式j(luò)s觸發(fā)函數(shù)調(diào)用oc的方式,我們這邊可以用block形式關(guān)聯(lián)javascript function.

通過(guò)上面的調(diào)用方式就可以獲取到j(luò)s調(diào)用時(shí)給oc傳過(guò)來(lái)的參數(shù),然后再進(jìn)行相關(guān)處理.當(dāng)js那邊是native.類型的函數(shù)的時(shí)候,js調(diào)用oc,我們就可以直接拿到j(luò)s跟oc綁定的那個(gè)方法來(lái)進(jìn)行處理。

到此,js和oc之間相互調(diào)用的內(nèi)容就差不多了,但是在使用的過(guò)程中有些情況下會(huì)發(fā)生莫名情況的野指針的情況 ,直接導(dǎo)致程序的崩潰。這個(gè)問(wèn)題我是在webview中調(diào)用手機(jī)攝像頭拍照上傳的過(guò)程中發(fā)現(xiàn)的,具體流程是當(dāng)需要上傳圖片的時(shí)候js調(diào)用oc的方法,然后oc進(jìn)行拍照并且上傳,當(dāng)上傳圖片成功以后,再通過(guò)oc調(diào)用js通過(guò)js去回顯圖片,就是在回調(diào)js的過(guò)程中有時(shí)候就會(huì)發(fā)生莫名其妙的野指針崩潰,暫時(shí)我還沒(méi)找到能夠徹底解決這個(gè)問(wèn)題的辦法,等找到相關(guān)方法,我再進(jìn)行公布。

續(xù):之前在webView中頻繁使用js和OC互相調(diào)用,出現(xiàn)了野指針問(wèn)題,那么這個(gè)問(wèn)題現(xiàn)在解決了。具體做法就是我們拿到webView所在的線程,讓你要執(zhí)行的方法在webView所在線程中執(zhí)行。例如:

通過(guò)上述方法就可以避免野指針問(wèn)題,但是具體是因?yàn)槭裁丛蛟斐梢爸羔槅?wèn)題的,我還沒(méi)弄明白,希望知道的高手指教。

JavaScript 語(yǔ)句后應(yīng)該加分號(hào)么?

分號(hào)加與不加完全取決于個(gè)人習(xí)慣,但為了代碼穩(wěn)定(解析出錯(cuò))還是建議使用分號(hào)斷句。

JavaScript自動(dòng)加分號(hào)規(guī)則:

1.當(dāng)有換行符(包括含有換行符的多行注釋),并且下一個(gè)token沒(méi)法跟前面的語(yǔ)法匹配時(shí),會(huì)自動(dòng)補(bǔ)分號(hào)。

2.當(dāng)有}時(shí),如果缺少分號(hào),會(huì)補(bǔ)分號(hào)。

3.當(dāng)程序源代碼結(jié)束時(shí),如果缺少分號(hào),會(huì)補(bǔ)分號(hào)。

結(jié)論:

1.在return、break、continue、后自增、后自減五種語(yǔ)句中,換行符可以完全替代分號(hào)的作用。

2.var if do while for continue break return with switch throw try debugger幾種關(guān)鍵字開頭的語(yǔ)句,以及空語(yǔ)句,上一行加不加分號(hào)影響不大。

3.凡表達(dá)式語(yǔ)句和函數(shù)表達(dá)式語(yǔ)句,后面不加分號(hào)非常危險(xiǎn),情況極其復(fù)雜。

4.凡(和[開頭的語(yǔ)句,前面不加分號(hào)極度危險(xiǎn)。

求大神看看,我被JS坑了多少?

好吧,電源絕對(duì)被坑大發(fā)了,網(wǎng)上航嘉500W的電源才350塊左右.......顯卡可以這個(gè)價(jià)位入手,但是就是不知道這塊卡是不是翻新的,如果全新的這個(gè)價(jià)位還是值得的。建議把CPU換了,這么高端的CPU完全沒(méi)必要啊,上塊I3-3220就夠了而且我覺(jué)得4400的價(jià)位弄套這樣的配置性價(jià)比不是很高誒。

所以總的來(lái)說(shuō)你被奸商坑大了!

當(dāng)前名稱:javascript大坑,javascript太難了
分享路徑:http://muchs.cn/article2/phijic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、Google虛擬主機(jī)、靜態(tài)網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)公司、手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)