WKWebView之oc調用js以及WKUserScript JS注入

oc調用js就特別簡單了哨毁,只需WKWebView調用

  • (void)evaluateJavaScript:completionHandler:方法即可。
/* @abstract Evaluates the given JavaScript string.
 @param javaScriptString The JavaScript string to evaluate.
 @param completionHandler A block to invoke when script evaluation completes or fails.
 @discussion The completionHandler is passed the result of the script evaluation or an error.
*/
- (void)evaluateJavaScript:(NSString *)javaScriptString completionHandler:(void (^ _Nullable)(_Nullable id, NSError * _Nullable error))completionHandler;

WKUserScript JS注入

在WebKit框架中,我們還可以預先添加JS方法竿裂,供其他人員調用许帐。WKUserScript就是幫助我們完成JS注入的類,它能幫助我們在頁面填充前或js填充完成后調用主经。核心方法荣暮。

/*! @abstract Returns an initialized user script that can be added to a @link WKUserContentController @/link.
 @param source The script source.
 @param injectionTime When the script should be injected.
 @param forMainFrameOnly Whether the script should be injected into all frames or just the main frame.
 */
- (instancetype)initWithSource:(NSString *)source injectionTime:(WKUserScriptInjectionTime)injectionTime forMainFrameOnly:(BOOL)forMainFrameOnly;
#pragma mark - get方法
- (WKWebView *)webView {
    if (_webView == nil) {
        // js配置
        WKUserContentController *userContentController = [[WKUserContentController alloc] init];
        [userContentController addScriptMessageHandler:self name:@"jsCallOC"];
        // js注入,注入一個alert方法罩驻,頁面加載完畢彈出一個對話框穗酥。
        NSString *javaScriptSource = @"alert(\"WKUserScript注入js\");";
        WKUserScript *userScript = [[WKUserScript alloc] initWithSource:javaScriptSource injectionTime:WKUserScriptInjectionTimeAtDocumentEnd forMainFrameOnly:YES];// forMainFrameOnly:NO(全局窗口),yes(只限主窗口)
        [userContentController addUserScript:userScript];

        // WKWebView的配置
        WKWebViewConfiguration *configuration = [[WKWebViewConfiguration alloc] init];
        configuration.userContentController = userContentController;

        // 顯示W(wǎng)KWebView
        _webView = [[WKWebView alloc] initWithFrame:self.view.frame configuration:configuration];
        [self.view addSubview:_webView];
    }
    return _webView;
}

同時實現(xiàn)代理WKUIDelegate的方法:

#pragma mark alert彈出框
- (void)webView:(WKWebView *)webView runJavaScriptAlertPanelWithMessage:(NSString *)message initiatedByFrame:(WKFrameInfo *)frame completionHandler:(void (^)(void))completionHandler {
    NSLog(@"%s",__FUNCTION__);
    // 確定按鈕
    UIAlertAction *alertAction = [UIAlertAction actionWithTitle:@"OK" style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) {
        completionHandler();
    }];
    // alert彈出框
    UIAlertController *alertController = [UIAlertController alertControllerWithTitle:message message:nil preferredStyle:UIAlertControllerStyleAlert];
    [alertController addAction:alertAction];
    [self presentViewController:alertController animated:YES completion:nil];
}
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末惠遏,一起剝皮案震驚了整個濱河市砾跃,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌节吮,老刑警劉巖蜓席,帶你破解...
    沈念sama閱讀 216,692評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異课锌,居然都是意外死亡厨内,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評論 3 392
  • 文/潘曉璐 我一進店門渺贤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來雏胃,“玉大人,你說我怎么就攤上這事志鞍〔t亮!?“怎么了?”我有些...
    開封第一講書人閱讀 162,995評論 0 353
  • 文/不壞的土叔 我叫張陵固棚,是天一觀的道長统翩。 經(jīng)常有香客問我仙蚜,道長,這世上最難降的妖魔是什么厂汗? 我笑而不...
    開封第一講書人閱讀 58,223評論 1 292
  • 正文 為了忘掉前任委粉,我火速辦了婚禮,結果婚禮上娶桦,老公的妹妹穿的比我還像新娘贾节。我一直安慰自己,他們只是感情好衷畦,可當我...
    茶點故事閱讀 67,245評論 6 388
  • 文/花漫 我一把揭開白布栗涂。 她就那樣靜靜地躺著,像睡著了一般祈争。 火紅的嫁衣襯著肌膚如雪斤程。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,208評論 1 299
  • 那天菩混,我揣著相機與錄音暖释,去河邊找鬼。 笑死墨吓,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的纹磺。 我是一名探鬼主播帖烘,決...
    沈念sama閱讀 40,091評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼橄杨!你這毒婦竟也來了秘症?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,929評論 0 274
  • 序言:老撾萬榮一對情侶失蹤式矫,失蹤者是張志新(化名)和其女友劉穎乡摹,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體采转,經(jīng)...
    沈念sama閱讀 45,346評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡聪廉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,570評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了故慈。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片板熊。...
    茶點故事閱讀 39,739評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖察绷,靈堂內(nèi)的尸體忽然破棺而出干签,到底是詐尸還是另有隱情,我是刑警寧澤拆撼,帶...
    沈念sama閱讀 35,437評論 5 344
  • 正文 年R本政府宣布容劳,位于F島的核電站喘沿,受9級特大地震影響,放射性物質發(fā)生泄漏竭贩。R本人自食惡果不足惜蚜印,卻給世界環(huán)境...
    茶點故事閱讀 41,037評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望娶视。 院中可真熱鬧晒哄,春花似錦、人聲如沸肪获。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽孝赫。三九已至较木,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間青柄,已是汗流浹背伐债。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留致开,地道東北人峰锁。 一個月前我還...
    沈念sama閱讀 47,760評論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像双戳,于是被迫代替她去往敵國和親虹蒋。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,647評論 2 354

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