Explain in detail how JS interacts with the app (code attached)
The following is the method of interaction between JS and app that I have compiled for you. Interested students can take a look.
1. Interconnection of code on H5
Key points: 1. Parameter passing of Object type, 2. The same JS method that interacts with the app, 3. Script method It needs to be embedded in the head.
<html> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <script type="text/javascript"> var share = JSON.stringify({"title":"Migi000", "desc":"简书", "shareUrl":"http://www.jianshu.com/p/f896d73c670a" }); //IOS function startFunction(share){ window.android.startFunction(share)//android } </script> <script> // testFunction() </script> <divonClick="testFunction()">dffddjjjjlj;ljlhhnljkhljhkjf</div> <divid="app-root"></div> <script type="text/javascript"src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> <script> var _hmt = _hmt || [];(function() {var hm= document.createElement("script");hm.src ="//hm.baidu.com/hm.js?f84dde8c08e5b9c97f9c39e2fcb4d658";var s =document.getElementsByTagName("script")[0];s.parentNode.insertBefore(hm, s);})(); </script> <scripttype="text/javascript"> function loadURL(url) { var iFrame; iFrame =document.createElement("iframe"); iFrame.setAttribute("src", url); iFrame.setAttribute("style","display:none;"); iFrame.setAttribute("height", "0px"); iFrame.setAttribute("width", "0px"); iFrame.setAttribute("frameborder", "0"); document.body.appendChild(iFrame); // 发起请求后这个iFrame就没用了,所以把它从 dom上移除掉 iFrame.parentNode.removeChild(iFrame); iFrame = null; } function testFunction(share) { loadURL("testfunction://?title=分享的标题&content=分享的内容&url=链接地址&imagePath=图片地址"); } var share =JSON.stringify({"title": "分享的标题","content":"分享的内容","url":"http://www.jianshu.com/p/f896d73c670a"}); testFunction(share) </script> </head> <body> <br/> <h1>Objective-C和JavaScript交互的那些事 </h1> <br/> <input type="button" value="Share" onClick="startFunction(share)" >点击调用原生代码并传递参数</a> </body> </html>
2. Code docking on IOS
Note: #import
#import"ViewController.h" #import<JavaScriptCore/JavaScriptCore.h> @interfaceViewController ()<UIWebViewDelegate>@property (nonatomic)UIWebView*webView; @property(nonatomic)JSContext *jsContext; @property(nonnull,strong) UIButton *btn; @end @implementationViewController -(void)viewDidLoad{ [super viewDidLoad]; self.webView = [[UIWebViewalloc]initWithFrame:self.view.bounds]; self.webView.delegate = self; [self.view addSubview:_webView]; NSString *str = [[NSBundle mainBundle]pathForResource:@"migi" ofType:@"html"]; [self.webView loadRequest:[NSURLRequestrequestWithURL:[NSURL fileURLWithPath:@"f"]]]; // 在上面添加一个按钮,实现oc端控制h5实现弹alert方法框 self.btn = [[UIButton alloc]initWithFrame:CGRectMake(100,400,100, 40)]; self.btn.backgroundColor = [UIColorredColor]; [self.btn addTarget:selfaction:@selector(showAlert) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:self.btn]; } -(void)showAlert { //要将script的alert()方法转化为string类型 NSString *alertJs=@"alert('Hello Word')"; [_jsContext evaluateScript:alertJs]; } -(void)webViewDidFinishLoad:(UIWebView*)webView{ _jsContext = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"]; _jsContext[@"startFunction"] =^(id obj){ ////这里通过block回调从而获得h5传来的json数据 /*block中捕获JSContexts 我们知道block会默认强引用它所捕获的对象,如下代码所示,如果block中直接使用context也会造成循环引用,这使用我们最好采用[JSContext currentContext]来获取当前的JSContext: */ [JSContext currentContext]; NSData *data = [(NSString *)objdataUsingEncoding:NSUTF8StringEncoding ]; NSDictionary *dict =[NSJSONSerialization JSONObjectWithData:dataoptions:NSJSONReadingMutableContainers error:nil]; NSLog(@"data %@ ====== ShareUrl %@",obj,dict[@"shareUrl"]); }; // _jsContext.exceptionHandler = ^(JSContext*context, JSValue *exceptionValue) { context.exception = exceptionValue; //比如把js中的方法名改掉,OC找不到相应方法,这里就会打印异常信息 NSLog(@"异常信息:%@", exceptionValue); }; _jsContext[@"testFunction"] =^(id obj){ //这里通过block回调从而获得h5传来的json数据 [JSContext currentContext]; NSData *data = [(NSString *)objdataUsingEncoding:NSUTF8StringEncoding ]; NSDictionary *dict = [NSJSONSerializationJSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil]; // NSLog(@" data %@ ====== ShareUrl%@",obj,dict[@"shareUrl"]); UIAlertView *alertView = [[UIAlertViewalloc] initWithTitle:dict[@"title"]message:dict[@"content"]delegate:nilcancelButtonTitle:@"cancel"otherButtonTitles:nil,nil]; [alertView show]; }; } -(BOOL)webView:(UIWebView *)webViewshouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType { NSURL * url = [requestURL]; //NSLog(@"scheme信息:%@", [urlscheme]); if ([[url scheme] isEqualToString:@"testfunction"]) { NSArray *params =[url.querycomponentsSeparatedByString:@"&"]; NSMutableDictionary *tempDic = [NSMutableDictionarydictionary]; for (NSString *paramStrin params) { NSArray *dicArray = [paramStrcomponentsSeparatedByString:@"="]; if (dicArray.count >1) { NSString *decodeValue =[dicArray[1]stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; [tempDic setObject:decodeValueforKey:dicArray[0]]; } } UIAlertView *alertView = [[UIAlertViewalloc] initWithTitle:tempDic[@"title"]message:tempDic[@"content"]delegate:selfcancelButtonTitle:@"收到"otherButtonTitles:nil]; [alertView show]; NSLog(@"tempDic:%@",tempDic); return NO; } return true; //为yes加载内容,否则不 }
3. Android code Interaction on
mWebH5.addJavascriptInterface(new MyJavaScriptInterface(this), "android"); mWebH5.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { //返回值是true的时候控制去WebView打开,为false调用系统浏览器或第三方浏览器 view.loadUrl(url); return true; } });
@JavascriptInterface publicvoid startFunction(String json){ if(SharedPrefs.getInstance().getUserAccessToken()==null){ Gson gson=new Gson(); finalShareLinkBean shareLinkBean =gson.fromJson(json, ShareLinkBean.class); LogUtils.i("test",json); mActivity.runOnUiThread(new Runnable() { @Override publicvoid run() { //跑相关逻辑 } }); }
The above is the method of interaction between JS and app that I compiled for everyone. I hope it will be helpful to everyone in the future.
Related articles:
Explain in detail the use of Js apply() (including code)
Easy to understand, self-study javascript Study Notes
# Several solutions to automatically execute (load) js on the page, detailed code analysis
The above is the detailed content of Explain in detail how JS interacts with the app (code attached). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Some users encountered errors when installing the device, prompting error code 28. In fact, this is mainly due to the driver. We only need to solve the problem of win7 driver code 28. Let’s take a look at what should be done. Do it. What to do with win7 driver code 28: First, we need to click on the start menu in the lower left corner of the screen. Then, find and click the "Control Panel" option in the pop-up menu. This option is usually located at or near the bottom of the menu. After clicking, the system will automatically open the control panel interface. In the control panel, we can perform various system settings and management operations. This is the first step in the nostalgia cleaning level, I hope it helps. Then we need to proceed and enter the system and

What to do with blue screen code 0x0000001? The blue screen error is a warning mechanism when there is a problem with the computer system or hardware. Code 0x0000001 usually indicates a hardware or driver failure. When users suddenly encounter a blue screen error while using their computer, they may feel panicked and at a loss. Fortunately, most blue screen errors can be troubleshooted and dealt with with a few simple steps. This article will introduce readers to some methods to solve the blue screen error code 0x0000001. First, when encountering a blue screen error, we can try to restart

The win10 system is a very excellent high-intelligence system. Its powerful intelligence can bring the best user experience to users. Under normal circumstances, users’ win10 system computers will not have any problems! However, it is inevitable that various faults will occur in excellent computers. Recently, friends have been reporting that their win10 systems have encountered frequent blue screens! Today, the editor will bring you solutions to different codes that cause frequent blue screens in Windows 10 computers. Let’s take a look. Solutions to frequent computer blue screens with different codes each time: causes of various fault codes and solution suggestions 1. Cause of 0×000000116 fault: It should be that the graphics card driver is incompatible. Solution: It is recommended to replace the original manufacturer's driver. 2,

Termination Code 0xc000007b While using your computer, you sometimes encounter various problems and error codes. Among them, the termination code is the most disturbing, especially the termination code 0xc000007b. This code indicates that an application cannot start properly, causing inconvenience to the user. First, let’s understand the meaning of termination code 0xc000007b. This code is a Windows operating system error code that usually occurs when a 32-bit application tries to run on a 64-bit operating system. It means it should

If you need to program any device remotely, this article will help you. We will share the top GE universal remote codes for programming any device. What is a GE remote control? GEUniversalRemote is a remote control that can be used to control multiple devices such as smart TVs, LG, Vizio, Sony, Blu-ray, DVD, DVR, Roku, AppleTV, streaming media players and more. GEUniversal remote controls come in various models with different features and functions. GEUniversalRemote can control up to four devices. Top Universal Remote Codes to Program on Any Device GE remotes come with a set of codes that allow them to work with different devices. you may

Blue screen is a problem we often encounter when using the system. Depending on the error code, there will be many different reasons and solutions. For example, when we encounter the problem of stop: 0x0000007f, it may be a hardware or software error. Let’s follow the editor to find out the solution. 0x000000c5 blue screen code reason: Answer: The memory, CPU, and graphics card are suddenly overclocked, or the software is running incorrectly. Solution 1: 1. Keep pressing F8 to enter when booting, select safe mode, and press Enter to enter. 2. After entering safe mode, press win+r to open the run window, enter cmd, and press Enter. 3. In the command prompt window, enter "chkdsk /f /r", press Enter, and then press the y key. 4.

Quickly get started with Python drawing: code example for drawing Bingdundun Python is an easy-to-learn and powerful programming language. By using Python's drawing library, we can easily realize various drawing needs. In this article, we will use Python's drawing library matplotlib to draw a simple graph of ice. Bingdundun is a cute panda who is very popular among children. First, we need to install the matplotlib library. You can do this by running in the terminal

What does the 0x000000d1 blue screen code mean? In recent years, with the popularization of computers and the rapid development of the Internet, the stability and security issues of the operating system have become increasingly prominent. A common problem is blue screen errors, code 0x000000d1 is one of them. A blue screen error, or "Blue Screen of Death," is a condition that occurs when a computer experiences a severe system failure. When the system cannot recover from the error, the Windows operating system displays a blue screen with the error code on the screen. These error codes
