Android webview - JavaScript 回调不起作用?
Android webview - JavaScript callback not working?
我正在使用 WebView 在 android 应用程序上显示网页。 https://developer.android.com/guide/webapps/webview.html
单击 HTML 中的按钮后,我可以成功到达 Android class WebAppInterface(来自示例)和显示 "Toast" 警报,但尝试回调到我的网页中定义的 javacsript 函数无效。
这是网页的代码:(Android.html)
<input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" />
<script type="text/javascript">
function showAndroidToast(toast) {
if (typeof Android != 'undefined')
Android.showToast(toast);
}
function ChangeColor()
{
document.body.style.background = 'pink';
}
</script>
这是Android应用的MainActivity的代码。它加载 url 并显示它。
public class MainActivity extends AppCompatActivity {
WebView m_Webview;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
m_Webview = (WebView) findViewById(R.id.webview);
WebSettings webSettings = m_Webview.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setDomStorageEnabled(true);
m_Webview.setWebViewClient(new WebViewClient());
m_Webview.loadUrl("android.html");
WebView webView = (WebView) findViewById(R.id.webview);
webView.addJavascriptInterface(new WebAppInterface(this,webView), "Android");
}
}
这是 Android 应用程序上的 WebAppInterface:
public class WebAppInterface {
Context mContext;
WebView mView;
/** Instantiate the interface and set the context */
WebAppInterface(Context c,WebView w) {
mContext = c;
mView = w;
}
/** Show a toast from the web page */
@JavascriptInterface
public void showToast(String toast) {
Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
mView.loadUrl("javascript:ChangeColor()");
}
}
JavaScript 函数 ChangeColor 在 toast 显示后未被调用。
有关更多参考,请参阅:
谢谢!
解决方案是像这样使用 "post" 函数:
public void showToast(String toast) {
Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
// WebView Web = new WebView(mContext);
// mView.getSettings().setUserAgentString("Android WebView");
mView.post(new Runnable() {
public void run() {
mView.loadUrl("javascript:ChangeColor()");
}
});
}
同样在 KitKat 和 forward 上你需要使用 evaluateJavascript:
mView.evaluateJavascript("ChangeColor();",null);
我正在使用 WebView 在 android 应用程序上显示网页。 https://developer.android.com/guide/webapps/webview.html
单击 HTML 中的按钮后,我可以成功到达 Android class WebAppInterface(来自示例)和显示 "Toast" 警报,但尝试回调到我的网页中定义的 javacsript 函数无效。
这是网页的代码:(Android.html)
<input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" />
<script type="text/javascript">
function showAndroidToast(toast) {
if (typeof Android != 'undefined')
Android.showToast(toast);
}
function ChangeColor()
{
document.body.style.background = 'pink';
}
</script>
这是Android应用的MainActivity的代码。它加载 url 并显示它。
public class MainActivity extends AppCompatActivity {
WebView m_Webview;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
m_Webview = (WebView) findViewById(R.id.webview);
WebSettings webSettings = m_Webview.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setDomStorageEnabled(true);
m_Webview.setWebViewClient(new WebViewClient());
m_Webview.loadUrl("android.html");
WebView webView = (WebView) findViewById(R.id.webview);
webView.addJavascriptInterface(new WebAppInterface(this,webView), "Android");
}
}
这是 Android 应用程序上的 WebAppInterface:
public class WebAppInterface {
Context mContext;
WebView mView;
/** Instantiate the interface and set the context */
WebAppInterface(Context c,WebView w) {
mContext = c;
mView = w;
}
/** Show a toast from the web page */
@JavascriptInterface
public void showToast(String toast) {
Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
mView.loadUrl("javascript:ChangeColor()");
}
}
JavaScript 函数 ChangeColor 在 toast 显示后未被调用。
有关更多参考,请参阅:
谢谢!
解决方案是像这样使用 "post" 函数:
public void showToast(String toast) {
Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
// WebView Web = new WebView(mContext);
// mView.getSettings().setUserAgentString("Android WebView");
mView.post(new Runnable() {
public void run() {
mView.loadUrl("javascript:ChangeColor()");
}
});
}
同样在 KitKat 和 forward 上你需要使用 evaluateJavascript:
mView.evaluateJavascript("ChangeColor();",null);