WKWebView與JS交互內(nèi)存不釋放問題探究

最近在做一個項目唆铐,里面用到了與H5的交互爹耗,準(zhǔn)確的說是JS端要調(diào)用本地的代碼,這里要說一下潭兽,wkWebView的JS交互與普通的UIWebView是不一樣的,而且在JS端代碼的編寫也是有所不同的斗遏,希望大家能跟后臺人員做良好的溝通。 廢話不多說诵次,直接上代碼枚碗。。铸本。。

  • 先說說wkWebView與JS交互的方法吧
WKWebViewConfiguration *config = [[WKWebViewConfiguration alloc] init];

[config.userContentController addScriptMessageHandler:self name:@"與后臺約定的方法名"];

//創(chuàng)建webView

WKWebView *webView = [[WKWebView alloc] initWithFrame:self.view.frame configuration:config];

webView.navigationDelegate = self;

在上面的這個方法里面去創(chuàng)建一個webView箱玷,并且約定方法名稱。

執(zhí)行本地的方法時候調(diào)用下面的這個方法

- (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message {
//message.body 可以打印JS端給你傳過來的數(shù)據(jù)锡足,可以根據(jù)數(shù)據(jù)去執(zhí)行相應(yīng)的方法
}

你以為JS調(diào)用本地的方法就完事了嗎?
舶得。
掰烟。
扩灯。
媚赖。

錯誤珠插,你會發(fā)現(xiàn)這樣調(diào)用方法之后惧磺,內(nèi)存根本不釋放。也就是說dealloc方法不會執(zhí)行捻撑。

前方高能磨隘,請仔細(xì)查看。顾患。番捂。。

問題就出現(xiàn)在
[config.userContentController addScriptMessageHandler:self name:@"與后臺約定的方法名"];
這句代碼上面江解,準(zhǔn)確的說是“self”的身上设预。

那么怎么解決呢?
我們可以把self換掉犁河,就是說用其他換掉self鳖枕,這里面就要新建一個類
在.h里面是這樣的

#import <WebKit/WebKit.h>

@interface XLWeakScriptMessageDelegate : NSObject<WKScriptMessageHandler>


@property (nonatomic,weak)id<WKScriptMessageHandler> scriptDelegate;

- (instancetype)initWithDelegate:(id<WKScriptMessageHandler>)scriptDelegate;

@end

在.m里面是這樣的

#import "XLWeakScriptMessageDelegate.h"

@implementation XLWeakScriptMessageDelegate

- (instancetype)initWithDelegate:(id<WKScriptMessageHandler>)scriptDelegate{
    self = [super init];
    if (self) {
        _scriptDelegate = scriptDelegate;
    }
    return self;
}

- (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message{
    [self.scriptDelegate userContentController:userContentController didReceiveScriptMessage:message];
}

@end

新建的類我都寫在這里了,大家可以拿過去直接用桨螺。
下面說的是最重要的改動宾符,就是把

WKWebViewConfiguration *config = [[WKWebViewConfiguration alloc] init];

[config.userContentController addScriptMessageHandler:self name:@"與后臺約定的方法名"];

這里面的代碼改造成

WKWebViewConfiguration *config = [[WKWebViewConfiguration alloc] init];
    [config.userContentController addScriptMessageHandler:[[XLWeakScriptMessageDelegate alloc] initWithDelegate:self] name:@"callback"];
    //創(chuàng)建webView
    WKWebView *webView = [[WKWebView alloc] initWithFrame:self.view.frame configuration:config];
    webView.navigationDelegate = self;

這樣以來,你就會發(fā)現(xiàn)灭翔,內(nèi)存釋放了魏烫,dealloc的方法可以快快樂樂的執(zhí)行了。

第一次發(fā)簡書,寫的不好大家多多見諒哄褒,如有什么問題給我留言稀蟋,我看到一定第一時間給大家回復(fù)。

能幫到你呐赡,才是我最大的成就:巍!72铡!绎谦!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末管闷,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子窃肠,更是在濱河造成了極大的恐慌包个,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,546評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件冤留,死亡現(xiàn)場離奇詭異碧囊,居然都是意外死亡,警方通過查閱死者的電腦和手機纤怒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評論 3 395
  • 文/潘曉璐 我一進(jìn)店門糯而,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人泊窘,你說我怎么就攤上這事熄驼。” “怎么了烘豹?”我有些...
    開封第一講書人閱讀 164,911評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長携悯。 經(jīng)常有香客問我,道長龟劲,這世上最難降的妖魔是什么逊彭? 我笑而不...
    開封第一講書人閱讀 58,737評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮避矢,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘亥宿。我一直安慰自己砂沛,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,753評論 6 392
  • 文/花漫 我一把揭開白布映企。 她就那樣靜靜地躺著堰氓,像睡著了一般。 火紅的嫁衣襯著肌膚如雪双絮。 梳的紋絲不亂的頭發(fā)上得问,一...
    開封第一講書人閱讀 51,598評論 1 305
  • 那天宫纬,我揣著相機與錄音,去河邊找鬼哪怔。 笑死,一個胖子當(dāng)著我的面吹牛胚委,可吹牛的內(nèi)容都是我干的叉信。 我是一名探鬼主播,決...
    沈念sama閱讀 40,338評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼硅急,長吁一口氣:“原來是場噩夢啊……” “哼佳遂!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起荚板,我...
    開封第一講書人閱讀 39,249評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎跪另,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體唧席,經(jīng)...
    沈念sama閱讀 45,696評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡淌哟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,888評論 3 336
  • 正文 我和宋清朗相戀三年绞绒,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,013評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡彤枢,死狀恐怖筒饰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情瓷们,我是刑警寧澤,帶...
    沈念sama閱讀 35,731評論 5 346
  • 正文 年R本政府宣布碘裕,位于F島的核電站攒钳,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏文兢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,348評論 3 330
  • 文/蒙蒙 一姆坚、第九天 我趴在偏房一處隱蔽的房頂上張望兼呵。 院中可真熱鬧兔辅,春花似錦幢妄、人聲如沸茫负。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽饿序。三九已至,卻和暖如春原探,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背咽弦。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評論 1 270
  • 我被黑心中介騙來泰國打工型型, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人闹蒜。 一個月前我還...
    沈念sama閱讀 48,203評論 3 370
  • 正文 我出身青樓绷落,卻偏偏與公主長得像,于是被迫代替她去往敵國和親砌烁。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,960評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 前言 關(guān)于UIWebView的介紹疏唾,相信看過上文的小伙伴們槐脏,已經(jīng)大概清楚了吧,如果有問題顿天,歡迎提問堂氯。 本文是本系列...
    CoderLF閱讀 8,968評論 2 12
  • 公司最近的項目用到的webview越來越多咽白,各種方法回調(diào)和js交互 先總結(jié)一下webview協(xié)議方法的使用鸟缕,再比較...
    OwenKing閱讀 1,133評論 0 5
  • 由于業(yè)務(wù)需要懂从,最近開發(fā)并總結(jié)了關(guān)于JavaScript和原生app的交互的一些實現(xiàn)方式。 通常情況下番甩,我們加載一個...
    __huangkun__閱讀 6,304評論 2 15
  • 前言 關(guān)于UIWebView的介紹牺汤,相信看過上文的小伙伴們浩嫌,已經(jīng)大概清楚了吧,如果有問題码耐,歡迎提問。 本文是本系列...
    Dark_Angel閱讀 28,882評論 67 291
  • 初見時 你我都曾是各自世界的星辰 再見時 我們已是同一片天空的行云 檸檬的味道敦间,散發(fā)在空氣里 引誘眼淚泛濫 這個夏...
    言舒華閱讀 233評論 1 2