JS代碼和OC代碼的相互調用

来源:http://www.cnblogs.com/liyy2015/archive/2016/10/13/5952816.html
-Advertisement-
Play Games

JS調用OC 很多應用裡面或多或少的調用了網頁,來達到絢麗的效果,所謂的JS調用OC.....舉個例子吧,網頁上有個按鈕 點擊按鈕跳轉界面,跳轉的動作由OC的代碼實現。 OC調用JS 還是舉個例子,我們OC代碼創建了輸入框比如輸入用戶名,輸入完成後顯示在網頁上,顯示用戶的用戶名 一.利用webVie ...


JS調用OC

很多應用裡面或多或少的調用了網頁,來達到絢麗的效果,所謂的JS調用OC.....舉個例子吧,網頁上有個按鈕

點擊按鈕跳轉界面,跳轉的動作由OC的代碼實現。

OC調用JS

還是舉個例子,我們OC代碼創建了輸入框比如輸入用戶名,輸入完成後顯示在網頁上,顯示用戶的用戶名

一.利用webView的代理方法實現OC和JS的相互調用

創建屬性

@property(nonatomic,strong)UIWebView * webView;

遵守webView的協議UIWebViewDelegate

-(void)webViewLoad{
    
    NSURL * url = [[NSURL alloc]initWithString:@"http://www.baidu.com"];
    self.webView = [[UIWebView alloc]initWithFrame:self.view.bounds];
    NSURLRequest * request = [[NSURLRequest alloc]initWithURL:url];
    self.webView.delegate = self;
    [self.webView loadRequest:request];
    
    [self.view addSubview:self.webView];
    
}

//JS調用OC
-(BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{
    NSString * str = request.URL.relativeString;
    if ([str isEqualToString:@"http://www.baidu.com/"]) {
       NSLog(@"來找度娘");
    }
    return YES;
}
//OC調用JS
-(void)webViewDidFinishLoad:(UIWebView *)webView{
   NSString * str = [self.webView stringByEvaluatingJavaScriptFromString:@"document.getElementById(""\"index-kw""\").value=""\"li""\""];
    NSLog(@"webViewDidFinishLoad=%@",str);
    
}

二.利用第三方的框架實現(需要你和html端的人統一方法的名稱)

-(void)webViewBridge{
    self.webView = [[UIWebView alloc]initWithFrame:[UIScreen mainScreen].bounds];
    
    NSString * path = [[NSBundle mainBundle]pathForResource:@"ExampleApp.html" ofType:nil];
    NSURL * url = [[NSURL alloc]initFileURLWithPath:path];
    
    [self.webView loadRequest:[NSURLRequest requestWithURL:url]];
    self.webView.delegate = self;
    [self.view addSubview:self.webView];
    //設置能夠橋接
    [WebViewJavascriptBridge enableLogging];
    //設置橋接
     self.bridge  =   [WebViewJavascriptBridge bridgeForWebView:self.webView];
    //設置代理
    [self.bridge setWebViewDelegate:self];
    //JS調用OC(testObjcCallback是和html統一的方法名字)
    [self.bridge registerHandler:@"testObjcCallback" handler:^(id data, WVJBResponseCallback responseCallback) {
        NSLog(@"按鈕點擊了");
        self.view.backgroundColor= [UIColor blackColor];
        responseCallback(@"按鈕點擊了");
    }];
    
    
}


//OC調用JS

-(void)webViewDidFinishLoad:(UIWebView *)webView{
    NSLog(@"webViewDidFinishLoad");
    [self.bridge callHandler:@"registerHandler"];
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • (1)自身類作為事件監聽器 package cn.edu.gdmec.s07150745.work5; import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View; ...
  • 伺服器上的項目是使用svn進行管理的。 本來本地的項目也是通過svn進行管理的,但是後來使用svn的分支功能進行項目的測試/新功能等等時,總是會出現各種各樣的問題,遂轉投git。 因為git的分支機制和svn的分支機制不一樣,git的更加靈活,強大和穩定。 首先建立一個本地化的git倉庫(需要在空文 ...
  • 使用方法: 繼承這個activity,重寫onclick()方法 ...
  • 項目中上拉刷新和下拉載入一直都是比較常見的;以前一般都是重寫ListView或直接用PullToRefreshListView的框架;最近嘗試用RecyclerView來實現下拉載入上拉刷新也是不錯的。 如圖是Demo的效果圖: 第一個效果圖是用RecyclerView實現加的幾個靜態數據; 第二個 ...
  • 視圖容器scroll-view :官方文檔 Demo Code var order = ['red', 'yellow', 'blue', 'green', 'red'] Page({ data: { toView: 'red', scrollTop: 100 }, upper: function( ...
  • 首先確定sdk是最新的 其次接下來是檢查xml文件,文件名不能大寫 如果xml文件太多,可以clean項目,然後觀察 Console 信息 修改Console提示的xml的錯誤後 重新clean 項目 ...
  • 在實際開發中可能需要用到兩個Service相互監視的情況,本示例就是實現此功能以作參考。 服務B: IBridgeInterface.aidl 界面: AndroidManifest.xml 由於涉及到跨進程,onServiceConnected() 方法中使用 而不能直接類型轉換 onStartC ...
  • package com.sinostride.smartcity.util;import java.io.UnsupportedEncodingException;/** * Created by lhd on 2016/10/12. * 基本類型轉換的工具類 */ public class Bas ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...