- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过单击网站上的按钮从两个文本框中获取简单的值。
我关注了这个 - https://developer.android.com/guide/webapps/webview.html#BindingJavaScript
基本上将我的客户端 Android 代码绑定(bind)到网站上的 JavaScript 函数。
这是我的 Android 代码 -
package course.org.webviewtesting;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.webkit.CookieManager;
import android.webkit.CookieSyncManager;
import android.webkit.JavascriptInterface;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.ImageView;
import android.widget.Toast;
/**
* Created by User on 12/29/2016.
*/
public class WebViewTest extends Activity {
WebView mWebView;
ImageView logo;
@Override
public void onCreate(Bundle savedInstanceState) {
final Activity mActivity = this;
CookieSyncManager.createInstance(mActivity);
CookieSyncManager.createInstance(getApplicationContext());
CookieSyncManager.getInstance().sync();
CookieManager.getInstance().setAcceptCookie(true);
this.getWindow().requestFeature(Window.FEATURE_PROGRESS);
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
logo = (ImageView) findViewById(R.id.logo);
logo.setVisibility(View.VISIBLE); //logo as a loading screen
// Makes Progress bar Visible
getWindow().setFeatureInt(Window.FEATURE_PROGRESS, Window.PROGRESS_VISIBILITY_ON);
mWebView = (WebView) findViewById(R.id.webview);
mWebView.addJavascriptInterface(new WebAppInterface(this), "android");
mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.loadUrl("myURLhere");
mWebView.setWebChromeClient(new WebChromeClient() {
public void onProgressChanged(WebView view, int progress) {
//Make the bar disappear after URL is loaded, and changes string to Loading...
mActivity.setTitle("Loading...");
mActivity.setProgress(progress * 100); //Make the bar disappear after URL is loaded
if (progress == 100) {
mActivity.setTitle(R.string.app_name);
logo.setVisibility(View.GONE);
}
}
});
mWebView.setWebViewClient(new WebViewClient() {
@Override
public void onPageFinished(WebView view, String url) {
System.out.println(" url is " + url);
}
});
}
// this is from the Android Docs
public class WebAppInterface {
Context mContext;
/** Instantiate the interface and set the context */
WebAppInterface(Context c) {
mContext = c;
}
/** Show a toast from the web page */
@JavascriptInterface
public void showFields(String email, String name) {
Toast.makeText(mContext, email+" "+name , Toast.LENGTH_SHORT).show();
System.out.println("Email " + email + "Name - "+name);
}
}
}
我的 HTML 如下:
<input type="email" id="loginEmail" name="loginEmail" ng-model="loginEmail" ng-required="true" />
<input type="name" id="name" name="name" ng-model="name" ng-required="true" />
<button type="submit" class="btn btn-large" ng-click="showValues();" onClick="showValuesAndroid()">Check Values</button>
以及相应的 JavaScript :
<script type="text/javascript">
function showValuesAndroid() {
var a = document.getElementById("loginEmail").value;
var b = document.getElementById("name").value;
Android.showFields(a,b);
};
</script>
我的函数获取变量 a 和 b 中的值,但我似乎无法在单击“检查值”按钮时在 WebView 上获取 toast 消息。另外 - System.out.println 似乎也没有显示任何值。
我已经被困在这个问题上近两个小时了,我错过了什么/做错了什么??
最佳答案
一旦 JavaScript 区分大小写,文档就会错误。如果您注意 Logcat,您可能会看到类似以下的消息:
com.androidbuts.sample I/chromium: [INFO:CONSOLE(XX)] "Uncaught ReferenceError: Android is not defined", source: ...
那是因为Android
object is not properly set .
正如 @Jonas w 所说,将 addJavascriptInterface()
配置更改为:
mWebView.addJavascriptInterface(new WebAppInterface(this), "Android");
...它会工作得很好! :)
关于javascript - 从文本框获取值 - Android WebView 和 JavascriptInterface 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41385490/
我有一个问题,如果我从 javascript 文件调用 android 函数并将参数传递给它,所有参数都将作为字符串传递吗? 例如 Javascript var cars = ["Saab", "Vo
我正在使用 Android 使网页与我的应用交互。因此,我浏览了文档和教程并最终提出了 this site .在其中,开发人员列出了您应该在希望 WebView 访问的任何函数之前包含 @Javasc
我正在使用 WebView 在我的应用程序中执行一些 JS 代码。到目前为止,这在我的 KitKat (targetSdk) 设备以及 2.2 (minSdk) 模拟器上运行良好。 但在 4.3 Ne
我有 WebView 来显示我的网页,并且我想使用 Javascript 运行 Navigation Drawer。 我的 logcat 没有显示任何错误消息,但它没有运行/ 我的 JavaScrip
我的 Android 应用程序中有一个 WebView 。我只想在浏览器上查看网页时才显示横幅。我创建了一个界面,它测试得很好,但由于网页无法识别该功能,因此页面上的其他 javascript 无法加
我刚刚将我的 Galaxy Tab2 从 ICS 软件更新到 Jelly Bean。我正在开发一个应用程序,我在其中加载一些带有一些 js 文件的 Html,调用一些用 Javascript 文件编写
Phonegap 还是 JavascriptInterface? 我要开发一个 Android Web 应用程序,并且想知道是否应该使用 PhoneGap,还是使用 JavascripInterfac
我有一个 webview 忽略了我所有的 javascript 接口(interface)方法,或者至少看起来是这样。当我从普通浏览器运行该网站时,它会抛出错误,因为没有按预期定义接口(interfa
正如在 official docs 上明确指出的那样,API 级别 JELLY_BEAN_MR1 及更高级别需要使用 @JavascriptInterface,以便从 webview 端访问 java
我目前正在 web View 中以 HTML 的形式向用户显示一堆数据。我在每个条目下方都有一些链接,单击这些链接应该在我的应用程序中调用一个方法。 Android WebView 的 javascr
我是 android 开发的新手,我正在尝试制作一个允许我启动 android 相机应用程序的 WebView。如何使用我的 JavaScriptInterface 调用主类中的方法? 谢谢。 pub
我正在尝试将 TextView 动态添加到线性布局中。但有一个问题。 在我的按钮中,这段代码运行得很好: TextView ASDF = (TextView) getLayoutInflater().
我有一个应用程序,它像浏览器一样运行并在 android webview 中显示结果。其中,一些结果是从我自己的服务器呈现的,并使用 javascriptInterface 对象调用 Java 方法。
我的 MainActivity 中有: webView.addJavascriptInterface( new JavaScriptInterface( this ), "ajaxHandler"
为了向 javascript 公开 java 方法,我使用了 mWebview.addJavascriptInterface(new JSInterface(this),"Android"); 当我实
我有以下 Java 接口(interface), public interface JavascriptInterface { public MyIterator getItems(); }
我有一个非常奇怪的问题,我的应用程序是一个电子阅读器。为了调用 Web View 的函数,我使用 JavaScript 类: public class MyJavaScriptInterfac
嘿,我正在使用一个必须与一些 javascript (coffeescript) 代码交互的应用程序。代码 JS 代码如下所示: $(".content").on "click", ".feedbac
我需要在 WebView 中调用一个包含一些 javascript 的网站。 JavaScript 调用嵌套对象中的方法,如下所示: window.plugins.anObject.method();
我想在 WebView 环境中获取并显示来自服务器的文本,同时在 WebView 中获取消息我想使用 显示相同的消息 toast 类。我写了下面的代码但是它不显示带有 Toast 类的文本。 和 p
我是一名优秀的程序员,十分优秀!