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

目前成都創(chuàng)新互聯(lián)公司已為上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁空間、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、高陵網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
一.在webview中如果項(xiàng)目只是想簡(jiǎn)單用一下js和oc進(jìn)行交互,就沒有必要搞的那么麻煩,只需要用下面的方式進(jìn)行處理就行.
1.oc調(diào)用js;例如,在js中有一個(gè)叫commit的方法,在oc中咱們可以這樣來調(diào)用它
如果你調(diào)用的js函數(shù)需要傳入?yún)?shù),也不要緊,咱們只需要通過字符串拼接的方式將參數(shù)傳入即可。比如當(dāng)前有一個(gè)叫sum(a,b)的js函數(shù),在oc中咱們可以這樣來調(diào)用它---(注意:在內(nèi)部參數(shù)要用' '來將參數(shù)括起來,這是因?yàn)閔tml函數(shù)傳參方式跟oc的不同,我們必須要按照html的傳參方式傳入才會(huì)有效果)
2.js調(diào)用oc;以前js調(diào)用oc是通過在webview這邊攔截js那邊觸發(fā)的http請(qǐng)求的url地址來判斷是不是我們需要調(diào)用的時(shí)機(jī),然后再調(diào)用的oc。如果當(dāng)我們?cè)趙ebview上點(diǎn)擊一個(gè)按鈕的時(shí)候他會(huì)跳轉(zhuǎn)到這個(gè)頁面,那么我們?cè)趏c這邊就可以通過攔截這個(gè)地址做一些事情
二.其實(shí),通過上面的方法是可以達(dá)到j(luò)s和oc之間進(jìn)行通訊,但是它也是存在一些弊端,或者說有時(shí)候不是很方便的。在ios7以后蘋果官方將javascriptCore框架給開放出來了,我們這個(gè)通過這個(gè)框架就可以暢通無阻的讓js和oc之間進(jìn)行相互調(diào)用了。
1.通過javascriptCore來進(jìn)行js和oc互相調(diào)用。第一步就是要進(jìn)入javascriptCore這個(gè)框架.
之后就可以在需要使用的控制器中導(dǎo)入javascriptCore框架了,并且如果你需要js來調(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)起來的工具,所有的js和oc調(diào)用都需要通過它來完成。
然后在webViewDidFinishLoad:中我們需要進(jìn)行下面的步驟,關(guān)聯(lián)native方法,是在當(dāng)js方法中有native.submit()類型函數(shù)的時(shí)候才需要綁定的,如果沒有這種類型的就不需要綁定。
注:其實(shí)通過上面的方法把self.context的native方法跟self綁定是會(huì)發(fā)生很嚴(yán)重的內(nèi)存泄露問題的。因?yàn)檫@樣會(huì)造成self被相互持有,導(dǎo)致該對(duì)象無法被釋放,解決方案是native指定一個(gè)新的對(duì)象,然后在指定對(duì)象里實(shí)現(xiàn)JSExport協(xié)議。
接下來就是非native.submit()形式j(luò)s觸發(fā)函數(shù)調(diào)用oc的方式,我們這邊可以用block形式關(guān)聯(lián)javascript function.
通過上面的調(diào)用方式就可以獲取到j(luò)s調(diào)用時(shí)給oc傳過來的參數(shù),然后再進(jìn)行相關(guān)處理.當(dāng)js那邊是native.類型的函數(shù)的時(shí)候,js調(diào)用oc,我們就可以直接拿到j(luò)s跟oc綁定的那個(gè)方法來進(jìn)行處理。
到此,js和oc之間相互調(diào)用的內(nèi)容就差不多了,但是在使用的過程中有些情況下會(huì)發(fā)生莫名情況的野指針的情況 ,直接導(dǎo)致程序的崩潰。這個(gè)問題我是在webview中調(diào)用手機(jī)攝像頭拍照上傳的過程中發(fā)現(xiàn)的,具體流程是當(dāng)需要上傳圖片的時(shí)候js調(diào)用oc的方法,然后oc進(jìn)行拍照并且上傳,當(dāng)上傳圖片成功以后,再通過oc調(diào)用js通過js去回顯圖片,就是在回調(diào)js的過程中有時(shí)候就會(huì)發(fā)生莫名其妙的野指針崩潰,暫時(shí)我還沒找到能夠徹底解決這個(gè)問題的辦法,等找到相關(guān)方法,我再進(jìn)行公布。
續(xù):之前在webView中頻繁使用js和OC互相調(diào)用,出現(xiàn)了野指針問題,那么這個(gè)問題現(xiàn)在解決了。具體做法就是我們拿到webView所在的線程,讓你要執(zhí)行的方法在webView所在線程中執(zhí)行。例如:
通過上述方法就可以避免野指針問題,但是具體是因?yàn)槭裁丛蛟斐梢爸羔槅栴}的,我還沒弄明白,希望知道的高手指教。
語法特性可能會(huì)成為入門者的坑。
比如:
-變量提升 (hoisting)
-閉包
-弱類型
你好,學(xué)習(xí)java只要掌握好方式和方法,其實(shí)學(xué)起來并不是非常難。比如你可以自學(xué)也可以選擇機(jī)構(gòu)學(xué)。
java學(xué)的內(nèi)容主要有:
①JAVA編程基礎(chǔ)(基礎(chǔ)語法、面向?qū)ο蟆⒑椭C特性等)
②WEB應(yīng)用開發(fā)(靜態(tài)網(wǎng)頁制作、Oracle數(shù)據(jù)庫、Java Web開發(fā)技術(shù)、Linux技術(shù)、網(wǎng)站性能與安全、軟件工程開發(fā)流程、Java Web和諧等)
③企業(yè)級(jí)框架開發(fā)(數(shù)據(jù)結(jié)構(gòu)與算法、SSH框架、JavaEE和諧等)
④項(xiàng)目實(shí)訓(xùn)
想要系統(tǒng)學(xué)習(xí),你可以考察對(duì)比一下開設(shè)有相關(guān)專業(yè)的熱門學(xué)校。好的學(xué)校擁有根據(jù)當(dāng)下企業(yè)需求自主研發(fā)課程的能力,能夠在校期間取得大專或本科學(xué)歷,中博軟件學(xué)院、南京課工場(chǎng)、南京北大青鳥等開設(shè)相關(guān)專業(yè)的學(xué)校都是不錯(cuò)的,建議實(shí)地考察對(duì)比一下。
祝學(xué)有所成!望采納!
javascript他爹說了,當(dāng)初第一個(gè)版本就是花了一個(gè)星期搞出來的。人家是個(gè)lisp愛好者,但是用戶喜歡C語言,所以搞出了這么個(gè)東西。很多現(xiàn)在說是坑的東西,其實(shí)都是他為了趕deadline隨便弄出來的,沒空細(xì)想。
后來流行了,想改也晚了。web程序員喜歡說,我們就是要快,哈哈哈哈哈哈,做基礎(chǔ)設(shè)施怎么能求快呢,害人害己啊。
分享文章:javascript坑,js難點(diǎn)看這一篇就夠了
URL網(wǎng)址:http://chinadenli.net/article11/dsspjdd.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)、營銷型網(wǎng)站建設(shè)、虛擬主機(jī)、云服務(wù)器、面包屑導(dǎo)航、小程序開發(fā)
聲明:本網(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í)需注明來源: 創(chuàng)新互聯(lián)