android的WebView控件与网页,JS的交互
2018-04-09 13:58
441 查看
1.WebView用法一般如下:public class MainActivity extends AppCompatActivity {
EditText shuru;
WebView show;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
show = (WebView) findViewById(R.id.show);
//**********************************************************************
show.setWebViewClient(new WebViewClient());//不跳转到其他浏览器
/*show.setWebViewClient(new WebViewClient() { //不跳转到其他浏览器
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
});*/
//要支持缩放,肯定要先支持Javascript
WebSettings set = show.getSettings(); //得到webview的设置
set.setJavaScriptEnabled(true);
//支持屏幕自动缩放
set.setSupportZoom(true);
set.setBuiltInZoomControls(true); //必须加,不然缩放无效
set.setDisplayZoomControls(false); //隐藏缩放按钮
/*webView.setOnTouchListener(new OnTouchListener() { //设置只能触摸,不能点击
@Override
public boolean onTouch(View v, MotionEvent event) {
return true;
}
});*/
//**********************************************************************
//show.loadUrl("http://www.baidu.com");显示网络网页
//显示main/assets目录下的网页
show.loadUrl("file:///android_asset/myt.html");
//将java对象暴露给javascript脚本,js中可以调用该对象
show.addJavascriptInterface(new MyObject(this) , "myObj"); //jsyongbiem
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if(keyCode == KeyEvent.KEYCODE_BACK){//监听返回键,如果可以后退就后退
if(show.canGoBack()){
show.goBack();
// webView.goBack();//后退
// webView.goForward();//前进
// webView.reload();//刷新
return true;
}
}
return super.onKeyDown(keyCode, event);
}
}2.myt.html网页如下:<!DOCTYPE html>
<html lang="en">
<meta http-equiv="Content-Type" content="text/html" charset="UTF-8">
<body>
<button onclick="myObj.showToast('liuyan')">点我1</button>
<button onclick="myObj.showList()">点我2</button>
<button onclick="">dsg</button>
<br>
<button onclick="">确定对话框</button>
<button onclick="">对话框</button>
<script>...
</script>
</body>
</html>3.java暴露给js的对象:public class MyObject {
Context context;
public MyObject(Context c) {
this.context = c;
}
//要暴露给js调用的方法要加注解 @JavascriptInterface
@JavascriptInterface
public void showToast(String name){
Toast.makeText(context, name + " 你好!", Toast.LENGTH_SHORT).show();
}
@JavascriptInterface
public void showList(){
new AlertDialog.Builder(context)
.setTitle("列表")
.setItems(new String[] {"abc" , "123" , "6y7"} , null)
.setPositiveButton("确定" , null)
.create()
.show();
}
}4.上面的是javaascript调用java,接下来是java调用javascrip
alert为一个按钮
alert.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//JAVA调用JS
show.loadUrl("javascript:toast()");
}
});然后需要在之前网页的js语句中加入toast()方法。给java调用
<script language="javascript"> <!--让JAVA调用JS这个方法-->
function toast() {
alert("ni hao liuyan");
}
</script>
EditText shuru;
WebView show;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
show = (WebView) findViewById(R.id.show);
//**********************************************************************
show.setWebViewClient(new WebViewClient());//不跳转到其他浏览器
/*show.setWebViewClient(new WebViewClient() { //不跳转到其他浏览器
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
});*/
//要支持缩放,肯定要先支持Javascript
WebSettings set = show.getSettings(); //得到webview的设置
set.setJavaScriptEnabled(true);
//支持屏幕自动缩放
set.setSupportZoom(true);
set.setBuiltInZoomControls(true); //必须加,不然缩放无效
set.setDisplayZoomControls(false); //隐藏缩放按钮
/*webView.setOnTouchListener(new OnTouchListener() { //设置只能触摸,不能点击
@Override
public boolean onTouch(View v, MotionEvent event) {
return true;
}
});*/
//**********************************************************************
//show.loadUrl("http://www.baidu.com");显示网络网页
//显示main/assets目录下的网页
show.loadUrl("file:///android_asset/myt.html");
//将java对象暴露给javascript脚本,js中可以调用该对象
show.addJavascriptInterface(new MyObject(this) , "myObj"); //jsyongbiem
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if(keyCode == KeyEvent.KEYCODE_BACK){//监听返回键,如果可以后退就后退
if(show.canGoBack()){
show.goBack();
// webView.goBack();//后退
// webView.goForward();//前进
// webView.reload();//刷新
return true;
}
}
return super.onKeyDown(keyCode, event);
}
}2.myt.html网页如下:<!DOCTYPE html>
<html lang="en">
<meta http-equiv="Content-Type" content="text/html" charset="UTF-8">
<body>
<button onclick="myObj.showToast('liuyan')">点我1</button>
<button onclick="myObj.showList()">点我2</button>
<button onclick="">dsg</button>
<br>
<button onclick="">确定对话框</button>
<button onclick="">对话框</button>
<script>...
</script>
</body>
</html>3.java暴露给js的对象:public class MyObject {
Context context;
public MyObject(Context c) {
this.context = c;
}
//要暴露给js调用的方法要加注解 @JavascriptInterface
@JavascriptInterface
public void showToast(String name){
Toast.makeText(context, name + " 你好!", Toast.LENGTH_SHORT).show();
}
@JavascriptInterface
public void showList(){
new AlertDialog.Builder(context)
.setTitle("列表")
.setItems(new String[] {"abc" , "123" , "6y7"} , null)
.setPositiveButton("确定" , null)
.create()
.show();
}
}4.上面的是javaascript调用java,接下来是java调用javascrip
alert为一个按钮
alert.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//JAVA调用JS
show.loadUrl("javascript:toast()");
}
});然后需要在之前网页的js语句中加入toast()方法。给java调用
<script language="javascript"> <!--让JAVA调用JS这个方法-->
function toast() {
alert("ni hao liuyan");
}
</script>
相关文章推荐
- android控件之webview和js与java交互
- android vebview与js交互 webview与网页交互
- android控件webview与js交互
- Android app 与网页交互 WebView 与JS交互
- android webview 中网页数据与js交互
- Android的webview控件和js脚本语言交互小例子
- android webview js交互 第一节 (java和js交互)
- Android的WebView控件载入网页显示速度慢的究极解决方案
- android webview js交互, 响应webview中的图片点击事件
- Android WebView与Js交互
- Android的WebView控件载入网页显示速度慢的究极解决方案
- Android中webview和js之间的交互及注意事项
- android webview js交互, 响应webview中的图片点击事件
- android webview js交互, 响应webview中的图片点击事件
- Android的WebView控件载入网页显示速度慢的究极解决方案
- android WebView访问本地页面swf交互JS权限 #2060错误
- android webView js方法和java 方法交互
- WebView控件中的javascript与Android本地功能交互
- Android中webview和js之间的交互
- android webview js交互, 响应webview中的图片点击事件