我的编程空间,编程开发者的网络收藏夹
学习永远不晚

浅谈Android程序与JavaScript脚本的交互

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

浅谈Android程序与JavaScript脚本的交互

我们都知道,手机时代的来临的主要标志是啥?能够方便的接入互联网!互联网展现给我们的方式一般都是网页,网页中又必不可少的拥有javascript,所以说,android提供对javascript的支持那是迫在眉睫了,幸好,android早就给我们提供了无缝连接。让我们可以通过android与javascript进行交互。

我们的应用很简单,如图:

2016411174422406.gif (326×62)

我们有一个输入框,旁边有个按钮,点击按钮就会提示我们输入的内容。当然这只是html中最简单的程序了,但是你将这个程序放入android手机中访问下试试,它是不会进行提示的。要想让其以android的形式提示用户,我们就需要用到android和javascript的交互。对了,这里展示的是一个网页哦,代码如下:

js.html


<html> 
<head> 
<title>js交互android</title> 
<mce:script type="text/javascript"><!-- 
 function show(){ 
 var a = document.getElementById("text").value; 
 alert(a); 
 } 
// --></mce:script> 
</head> 
<body> 
<form action=""> 
 <input type="text" id="text" value=""/> 
 <input type="button" id="button" onclick="window.chenzheng_java.show()" value="clickme"/> 
</form> 
</body> 
</html> 

再看看我们的activity代码:


package cn.com.chenzheng_java.js; 
import android.app.Activity; 
import android.os.Bundle; 
import android.os.Handler; 
import android.util.Log; 
import android.webkit.JsResult; 
import android.webkit.WebChromeClient; 
import android.webkit.WebSettings; 
import android.webkit.WebView; 
import android.widget.Toast; 
public class JavaScriptActivity extends Activity { 
 WebView webView; 
 Handler handler = new Handler(); 
 @Override 
 public void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.main); 
  webView = (WebView) findViewById(R.id.webView1); 
   
  WebSettings webSettings = webView.getSettings(); 
  webSettings.setJavaScriptEnabled(true); 
  webView.loadUrl("file:///data/js.html"); 
   
  class MyWebChromeClient extends WebChromeClient { 
   @Override 
   public boolean onJsAlert(WebView view, String url, String message, 
     JsResult result) { 
    Toast.makeText(getApplicationContext(), message, 
      Toast.LENGTH_LONG).show(); 
    return true; 
   } 
  } 
  webView.setWebChromeClient(new MyWebChromeClient()); 
   
  webView.addJavascriptInterface(new Object() { 
   public void show() { 
    handler.post(new Runnable() { 
     @Override 
     public void run() { 
      Log.i("通知", "调用了该方法哦"); 
       
      webView.loadUrl("javascript:show()"); 
     } 
    }); 
   } 
  }, "chenzheng_java"); 
 } 
} 


注意:

1)为了让WebView从apk文件中加载assets,Android SDK提供了一个schema,前缀为"file:///android_asset/"。WebView遇到这样的schema,就去当前包中的assets目录中找内容。如上面的"file:///android_asset/demo.html"

2)addJavascriptInterface方法中要绑定的Java对象及方法要运行另外的线程中,不能运行在构造他的线程中,这也是使用Handler的目的。

3)如果你要访问网络,请在androidManifest.xml中加上权限<uses-permission android:name="android.permission.INTERNET"></uses-permission>

API
我们在程序中可以看到,android访问网页以及与javascript交互主要用到了这么几个类:

WebView :我们可以认为它就是一个浏览器,会对用户访问的网址进行解析,下载,渲染……,然后返回给用户一个网页。  其内部使用的是webkit渲染引擎,它还包含了一些我们经常使用的功能,比如放大、缩小网页(需要在webSetting中先设置WebSettings.setBuiltInZoomControls(boolean));前进、后退……。

      默认情况下,webView对javascript和页面的错误都是忽略的。很多时候,如果我们想要加载一个uri,可能我们更多的会使用这种形式:

Uri uri = Uri.parse("http://www.example.com"); Intent intent = new Intent(Intent.ACTION_VIEW, uri); startActivity(intent);  

api中为我们提供了一个通过webView加载页面的例子,

2016411174508881.gif (813×187)

我们可以看到,主要有loadUrl()和loadData()方法。这里请注意各个参数的含义哦、

拓展

此外,android还为我们提供了一些类来辅助我们的webview的使用。

WebViewClient:

。WebViewClient就是帮助WebView处理各种通知、请求事件的,具体来说包括:

  onLoadResource:通知webView加载url指定的资源时触发   onPageStart:页面开始加载时触发   onPageFinish:页面加载完毕时触发   onReceiveError:出现错误时触发   WebChromeClient:

WebChromeClient是辅助WebView处理Javascript的对话框,网站图标,网站title,加载进度等

   onCloseWindow(关闭WebView)   onCreateWindow()   onJsAlert (WebView上alert是弹不出来东西的,需要定制你的WebChromeClient处理弹出)   onJsPrompt   onJsConfirm   onProgressChanged   onReceivedIcon   onReceivedTitle

api中提供给我们一个实例:

2016411174534890.gif (852×365)

WebSetting:和WebView是一一绑定的,控制webview的一些基础设置信息,如是否识别javascript,网页是否可放大缩小等。

如果我们想通过webview进行历史网页查看时,一定要注意,先通过如下方法判断下是否可执行该操作才好:

2016411174556464.gif (427×186)

然后就可通过

void goBack() void goBackOrForward(int steps)
void goForward()

三个方法进行操作了,字面意思很容易看懂,其中goBackOrForward传递进负数时为back操作,正数为forward操作。

您可能感兴趣的文章:android中webview控件和javascript交互实例Android中Java和JavaScript交互实例Android WebView使用方法详解 附js交互调用方法解析Android中webview和js之间的交互Android WebView上实现JavaScript与Java交互Android中WebView与Js交互的实现方法Android webview与js的数据交互Android中js和原生交互的示例代码android和js的交互之jsbridge使用教程


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

浅谈Android程序与JavaScript脚本的交互

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

浅谈Android程序与JavaScript脚本的交互

我们都知道,手机时代的来临的主要标志是啥?能够方便的接入互联网!互联网展现给我们的方式一般都是网页,网页中又必不可少的拥有javascript,所以说,android提供对javascript的支持那是迫在眉睫了,幸好,android早就给
2022-06-06

浅谈Android Activity与Service的交互方式

实现更新下载进度的功能1. 通过广播交互 Server端将目前的下载进度,通过广播的方式发送出来,Client端注册此广播的监听器,当获取到该广播后,将广播中当前的下载进度解析出来并更新到界面上。 优缺点分析: 通过广播的方式实现Activ
2022-06-06

浅谈Shell脚本参数与交互及常见问题

目录一、Shell编程-脚本参数与交互及常见问题1.1 向脚本传递参数1.2 用户交互1.3 特殊变量1.4 Shell编程常见问题1.4.1 如何屏蔽命令的输出结果1.4.2 如何把一条命令分成多行编写一、Shell编程-脚本参数与交互及
2022-06-04

浅谈shell脚本免交互的四大方法

在写shell脚本的过程中,我们经常碰到一些操作需要我们取实时指定一些参数,这就需要用到免交互了。免交互让我们的shell脚本更加强大。介绍几种免交互的方式 1.管道符不同命令间协调工作,位于 | 左侧命令的输出结果,将作为右侧命令的输入(
2022-06-04

Android编程使用WebView实现与Javascript交互的方法【相互调用参数、传值】

本文实例讲述了Android编程使用WebView实现与Javascript交互的方法。分享给大家供大家参考,具体如下: Android中可以使用WebView加载网页,同时Android端的Java代码可以与网页上的JavaScript代
2022-06-06

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录