webView与js交互

本文详细介绍如何在UIWebView上实现iOS应用与网页元素的交互,包括App调用JS方法和JS调用App方法的具体实现步骤。通过实例演示了如何在点击事件中弹出UITextField进行回复,并使用post请求发送。
摘要由CSDN通过智能技术生成

问:在UIWebView上点击回复,如何使用UITextField进行回复?

答:UIWebView有一个stringByEvaluatingJavaScriptFromString方法,可以将js嵌入页面中,通过这个方法,我们可以在iOS中与web的网页元素交互。通过js获取点击时间,弹出UITextField,输入字符串后,可以通过post请求发送回复。

 

  

一、App调用JS方法

    首先app调用js方法使用系统自带的stringByEvaluatingJavaScriptFromString,这里简单实现就在webView加载完成的时候调用js内部alert方法 

- (void)webViewDidFinishLoad:(UIWebView *)webView {
    
    // 第一步 app call js method
    [self.webView stringByEvaluatingJavaScriptFromString:@"alert()"];
}

  

二、JS调用App方法

   实现思路:使用webView代理方法webView:shouldStartLoadWithRequest:navigationType:(是否允许加载某个请求)拦截JS重定向的URL,然后对URL进行解析

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
    // 第二步  js all app method
    
    NSURL *url = [request URL];

    NSString *urlStr = [url absoluteString];
    NSLog(@"absoluteString --> %@",urlStr);
    
    if ([[url scheme] isEqualToString:@"jscalloc"]) {
        NSArray *arr = [urlStr componentsSeparatedByString:@"://"];
        NSString *methodName = [arr lastObject];
        
        SEL sel = NSSelectorFromString(methodName);
        
        [self performSelector:sel];
    }
    
    return YES;
}

- (void)test {
    
    NSLog(@"i love jiang beibei");
}

  下面是html部分代码

<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
    
<script>
    function action() {
        window.location.href = "jscalloc://test";
    }
</script>

</head>

<body>

<p>我爱姜贝贝</p>
<p>我爱姜贝贝</p>
<p>我爱姜贝贝</p>

<button οnclick="action()">btnbtn</button>

</body>
</html>

 

 

本文  Demo传送门

转载于:https://www.cnblogs.com/jiangzzz/p/5610292.html

在 Android 中,WebView 是一个内置的浏览器控件,可以加载网页并在应用程序中显示。WebView 与 JavaScript 的交互是常见的需求,主要有以下几种方式: 1. 通过 WebView 中的 loadUrl() 方法调用 JavaScript 函数。 可以使用 WebView 的 loadUrl() 方法加载一个包含 JavaScript 代码的 URL,实现与 JavaScript 的交互。例如,在 JavaScript 中定义一个函数: ```javascript function showToast(message) { alert(message); } ``` 然后在 Android 中使用 loadUrl() 方法调用这个函数: ```java webView.loadUrl("javascript:showToast('Hello World!')"); ``` 2. 在 WebView 中启用 JavaScript,并使用 addJavascriptInterface() 方法将 Java 对象注入到 JavaScript 中。 可以在 WebView 中启用 JavaScript 支持,并使用 addJavascriptInterface() 方法将 Java 对象注入到 JavaScript 中。这样,JavaScript 就可以调用 Java 对象的方法。例如,在 Java 中定义一个类: ```java public class MyJavaScriptInterface { private Context context; public MyJavaScriptInterface(Context context) { this.context = context; } @JavascriptInterface public void showToast(String message) { Toast.makeText(context, message, Toast.LENGTH_SHORT).show(); } } ``` 然后在 WebView 中启用 JavaScript 支持,并将 MyJavaScriptInterface 对象注入到 JavaScript 中: ```java webView.getSettings().setJavaScriptEnabled(true); webView.addJavascriptInterface(new MyJavaScriptInterface(this), "Android"); ``` 在 JavaScript 中就可以调用 MyJavaScriptInterface 对象的 showToast() 方法: ```javascript Android.showToast("Hello World!"); ``` 3. 使用 evaluateJavascript() 方法执行 JavaScript 代码并获取返回值。 可以使用 WebView 的 evaluateJavascript() 方法执行 JavaScript 代码,并通过回调函数获取返回值。例如,在 JavaScript 中定义一个函数: ```javascript function add(a, b) { return a + b; } ``` 然后在 Android 中使用 evaluateJavascript() 方法执行这个函数,并获取返回值: ```java webView.evaluateJavascript("add(1, 2)", new ValueCallback<String>() { @Override public void onReceiveValue(String value) { // value = "3" } }); ``` 以上就是 WebView 与 JavaScript 的交互方式,开发者可以根据需求选择适合自己的方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值