WebView加载页面,常见的问题
2015-11-09 11:51
337 查看
一、错误1:
Uncaught TypeError: Object [object Object] has no method “xxx”
这是因为 Android 版本的问题
在Android 4.2 以前,注入步骤如下:
wst.setJavaScriptEnabled(true);
webview.addJavascriptInterface(new DemoJavaScriptInterface(), "demo");
final class DemoJavaScriptInterface{
DemoJavaScriptInterface(){
}
public void clickOnAndroid(){
handler.post(new Runnable() {
@Override
public void run() {
webview.loadUrl("javascript:wave()");
}
});
}
}
在 Android 4.2 以后则要这样注入:
wst.setJavaScriptEnabled(true);
webview.addJavascriptInterface(new DemoJavaScriptInterface(), "demo");
final class DemoJavaScriptInterface{
DemoJavaScriptInterface(){ }
@JavascriptInterface
public void clickOnAndroid(){
handler.post(new Runnable() {
@Override
public void run() {
webview.loadUrl("javascript:wave()");
}
});
}
}
发现区别没?4.2之前向webview注入的对象所暴露的接口没有注释语句@JavascriptInterface,而4.2及以后的则多了注释语句@JavascriptInterface
二 、返回键的处理:
Uncaught TypeError: Object [object Object] has no method “xxx”
这是因为 Android 版本的问题
在Android 4.2 以前,注入步骤如下:
wst.setJavaScriptEnabled(true);
webview.addJavascriptInterface(new DemoJavaScriptInterface(), "demo");
final class DemoJavaScriptInterface{
DemoJavaScriptInterface(){
}
public void clickOnAndroid(){
handler.post(new Runnable() {
@Override
public void run() {
webview.loadUrl("javascript:wave()");
}
});
}
}
在 Android 4.2 以后则要这样注入:
wst.setJavaScriptEnabled(true);
webview.addJavascriptInterface(new DemoJavaScriptInterface(), "demo");
final class DemoJavaScriptInterface{
DemoJavaScriptInterface(){ }
@JavascriptInterface
public void clickOnAndroid(){
handler.post(new Runnable() {
@Override
public void run() {
webview.loadUrl("javascript:wave()");
}
});
}
}
发现区别没?4.2之前向webview注入的对象所暴露的接口没有注释语句@JavascriptInterface,而4.2及以后的则多了注释语句@JavascriptInterface
二 、返回键的处理:
//改写物理按键——返回的逻辑 @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // TODO Auto-generated method stub if(keyCode==KeyEvent.KEYCODE_BACK) { if(webView.canGoBack()) { webView.goBack();//返回上一页面 return true; } else { System.exit(0);//退出程序 } } return super.onKeyDown(keyCode, event); }
3、重新 自定义 WebChromeClient 对象
webview.setWebChromeClient(new MyWebChromeClient());
final class MyWebChromeClient extends WebChromeClient {
@Override
public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
final AlertDialog.Builder builder = new AlertDialog.Builder(view.getContext());
builder.setTitle("")
.setMessage(message)
.setPositiveButton("确定", null);
// 不需要绑定按键事件
// 屏蔽keycode等于84之类的按键
builder.setOnKeyListener(new OnKeyListener() {
public boolean onKey(DialogInterface dialog, int keyCode,KeyEvent event) {
// Log.v("onJsAlert", "keyCode==" + keyCode + "event="+ event);
return true;
}
});
// 禁止响应按back键的事件
builder.setCancelable(false);
AlertDialog dialog = builder.create();
dialog.show();
result.confirm();
return true;
}
相关文章推荐
- 怎样进行微信营销才比较好
- android 注册广播代码(备用)
- 深入浅出 - Android系统移植与平台开发(十)- Android编译系统与定制Android平台系统
- Android:LayoutInflater 如何使用
- swift 对象方法
- swift 对象方法
- 深入浅出 - Android系统移植与平台开发(十一)- Android系统的定制
- iOS开发 - Xcode7下解决使用三方库出现的warning问题
- (三期)Hybrid混合开发之Appcan技术
- iOS自动布局Auto Layout 与 SizeClass
- 简要的汇总Android
- swift 运算属性
- swift 运算属性
- android textview 行间距设置
- 学习笔记Cocos2d-x之内存管理
- iphone手机端图片错位修正的js代码
- swift 属性值监测
- swift 属性值监测
- Android的AIDL 解释Demo
- swift 结构体