`
zhengjj_2009
  • 浏览: 153085 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

android与原生的JS交互

 
阅读更多

package com.ada56.apps.taxi.ui.login;

 

import android.annotation.SuppressLint;

import android.app.Activity;

import android.content.Context;

import android.os.Bundle;

import android.view.View;

import android.webkit.JsResult;

import android.webkit.WebChromeClient;

import android.webkit.WebSettings;

import android.webkit.WebView;

import android.webkit.WebViewClient;

import android.widget.Toast;

 

import com.ada56.apps.taxi.passenger.R;

 

public class JSAndroidActivity extends Activity {

    private WebView myWebView = null;

    @SuppressLint("SetJavaScriptEnabled")

    @Override

    public void onCreate(Bundle savedInstanceState){

        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_jsdemo);

        myWebView = (WebView) findViewById(R.id.myWebView);

        WebSettings webSettings = myWebView.getSettings();// 得到设置属性的对象

        webSettings.setJavaScriptEnabled(true);// 使能JavaScript

        webSettings.setDefaultTextEncodingName("GBK");//支持中文,否则页面中中文显示乱码

        // 限制在WebView中打开网页,而不用默认浏览器

        myWebView.setWebViewClient(new WebViewClient());

 

        // 如果不设置这个,JS代码中的按钮会显示,但是按下去却不弹出对话框

        // Sets the chrome handler. This is an implementation of WebChromeClient

        // for use in handling JavaScript dialogs, favicons, titles, and the

        // progress. This will replace the current handler.

        myWebView.setWebChromeClient(new WebChromeClient() {

            @Override

            public boolean onJsAlert(WebView view, String url, String message, JsResult result) {

                return super.onJsAlert(view, url, message, result);

            }

 

        });

 

        // 用JavaScript调用Android函数:

        // 先建立桥梁类,将要调用的Android代码写入桥梁类的public函数

        // 绑定桥梁类和WebView中运行的JavaScript代码

        // 将一个对象起一个别名传入,在JS代码中用这个别名代替这个对象,可以调用这个对象的一些方法

        //myWebView.addJavascriptInterface(new WebAppInterface(this), "myInterfaceName");

        myWebView.addJavascriptInterface(new WebViewNative(this), "Native");

 

        //myWebView.loadUrl("file:///android_asset/sample.html");// 载入页面:本地html资源文件

        myWebView.loadUrl("http://192.168.211.61:8080/taxi/jsAndroid.html");

    }

    

    public void callJSMethod(View view){

    //用Android代码调用JavaScript函数:

        myWebView.loadUrl("javascript:myFunction('<<callJSMethod>>')");

        //这里实现的效果和在网页中点击第一个按钮的效果一致

    }

 

    /**

     * 自定义的Android代码和JavaScript代码之间的桥梁类

     */

    public class WebViewNative {

        Context mContext;

        /** Instantiate the interface and set the context */

        WebViewNative(Context c) {

            mContext = c;

        }

        /** Show a toast from the web page */

        public void showToast(String toast) {

            Toast.makeText(mContext, toast, Toast.LENGTH_LONG).show();

        }

    }

 

}

 

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

<?xml version="1.0" encoding="utf-8"?>

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"

    xmlns:tools="http://schemas.android.com/tools"

    android:id="@+id/myRelativeLayout"

    android:layout_width="match_parent"

    android:layout_height="match_parent" >

 

    <TextView

        android:id="@+id/textView1"

        android:layout_width="wrap_content"

        android:layout_height="wrap_content"

        android:padding="40dp"

        android:text="@string/hello_world"

        tools:context=".WebJSActivity" />

 

    <Button

        android:id="@+id/button1"

        android:layout_width="wrap_content"

        android:layout_height="wrap_content"

        android:layout_toRightOf="@id/textView1"

        android:onClick="callJSMethod"

        android:text="android_Button" />

 

    <WebView

        android:id="@+id/myWebView"

        android:layout_width="fill_parent"

        android:layout_height="fill_parent"

        android:layout_below="@id/textView1" />

 

</RelativeLayout>

 

===========================================================================================================================

<html>

<head>

<meta charset="UTF-8">

<!-- JavaScript脚本,主要包括了按钮要执行的函数,显示对话框等 -->

<script type="text/javascript">

    //JavaScript方法,弹出对话框显示信息

    function myFunction(msg){

        alert("myFunction is called, msg="+msg);

    }

    function onAlert()

    {

        console.log("onAlert method");//显示调试信息

        alert("This is a alert sample from html");

    }

    function onConfirm()

    {

        console.log("onConfirm method");

        var b = confirm("are you sure to login?");

        alert("your choice is " + b);

    }

    function onPrompt()

    {

        console.log("onPrompt method");

        var b = prompt("please input your password", "aaa");

        alert("your input is " + b);

    }

 

    //调用绑定的Java对象的方法,即调用Android代码显示对话框

    function showAndroidToast(toast)

    {

        console.log("showAndroidToast method");

        //myInterfaceName.showToast(toast);//注意此处的myInterfaceName要和外部传入的名字一致,大小写正确

        Native.showToast(toast);

    }

</script>

</head>

<body>

    

    <p>

        <!-- 前四个按钮调用JS函数 -->

        JavaScript函数调用 <br />

        <button onclick="myFunction()">点击这里!</button>

        <br /> 

        <input type="button" value="alert" onclick="onAlert()" /> <br />

        <input type="button" value="confirm" onclick="onConfirm()" /> <br />

        <input type="button" value="prompt" onclick="onPrompt()" /><br />

        <!-- 上面用了两种定义按钮的方式,效果一样的 -->

    </p>

    

    <p>

        <!-- 这个Say hello 按钮调用Android代码中的方法 -->

        用JavaScript按钮调用Android代码 <br /> 

        <input type="button"

            value="Say hello" onClick="showAndroidToast('Hello Android!')" />

    </p>

 

    <a href="http://www.google.com" />Google

    </a>

 

</body>

</html>

分享到:
评论

相关推荐

    uniApp或者vue 与 Android或者ios原生交互

    uniApp或者vue 与 Android或者ios实现原生交互,使用bridge.js可以轻松实现。

    android原生与js交互第三方库

    总的来说,"android原生与js交互第三方库",如DSBridge-Android,是混合开发中的重要工具,它们简化了Android与JavaScript之间的交互,促进了两者之间的高效协同。通过合理利用这类库,开发者可以构建出功能丰富、...

    android原生和js交互传递参数 包含特殊字符

    android原生和js交互传递参数 包含特殊字符 例如"\'"等情况 避免Uncaught SyntaxError: missing ) after argument list 避免JSON.parse失败等情况 利于快速和webview交互 加速开发过程

    Android中Webview与原生界面交互及二维码扫描功能实现

    总之,"Android中Webview与原生界面交互及二维码扫描功能实现"项目涵盖了Android开发中的关键技术点,包括WebView的使用、JavaScript与原生代码的交互,以及二维码扫描功能的集成。通过学习和实践这个项目,开发者...

    ReactNative与Android原生简单交互

    在ReactNative中与Android原生代码进行交互是非常常见的需求,这主要涉及到以下知识点: 1. **桥接机制**:ReactNative通过JavaScriptCore执行JavaScript代码,并通过一个称为“Bridge”的机制与原生平台通信。...

    Android与js交互拍照上传资料

    这个话题主要涉及Android原生代码与JavaScript代码之间的通信,以便利用各自的优势。本篇将深入探讨如何实现Android调用JavaScript接口启动照相机拍照,并将拍摄的照片上传至服务器。 一、Android与JavaScript交互...

    android原生与js互调

    在Android开发中,有时我们需要实现Android原生代码与JavaScript之间的交互,这主要涉及到Webview组件的使用和两者之间的通信机制。Webview是一个可以加载和显示网页的控件,它不仅能够展示HTML内容,还能让我们通过...

    Js与Android原生交互

    JavaScript(Js)与Android原生应用的交互是移动开发中常见的需求,特别是在构建混合应用程序时。WebView组件是Android提供的一种可以加载和显示网页内容的视图,它使得在Android应用中运行JavaScript代码成为可能。...

    android原生与HTML之间的交互

    本篇将详细介绍如何使用JavaScript来实现Android原生与HTML之间的交互。 首先,Android提供了WebView组件,它是加载网页内容的核心工具。通过在布局XML文件中添加WebView,我们可以将HTML页面嵌入到Android应用中。...

    Android与JS交互例子

    在Android应用开发中,有时我们需要在原生的Android代码与JavaScript之间进行交互,这在混合式应用开发或者处理复杂的用户界面逻辑时尤为常见。本文将详细介绍如何实现Android与JavaScript之间的交互,包括Android...

    Android与JS的交互

    Android与JS的交互的具体讲解请参考 1、Android与JS的交互(上) 链接:http://blog.csdn.net/u010857510/article/details/52761602 2、Android与JS的交互(下) 链接:...

    Ioinc 和原生android交互broadcaster

    本话题主要探讨如何在IONIC5项目中,利用Cordova插件与Android原生代码进行交互,特别是通过`cordova-broadcaster`插件实现消息广播(Broadcast Receiver)机制。 首先,我们要理解IONIC5的基本架构。IONIC5基于...

    android与js交互的三种方式

    本文将详细介绍三种常见的Android与JavaScript交互的方式,帮助开发者更好地掌握这种跨平台的数据通信。 一、WebView注入JavaScript接口 Android中的WebView组件可以加载网页内容,同时它提供了与JavaScript交互的...

    android webview与js交互简单demo

    当Android的WebView与JavaScript交互时,开发者可以实现更丰富的功能,如调用Android原生方法、获取网页数据等。下面我们将深入探讨这个“android webview与js交互简单demo”所涉及的知识点。 1. Android WebView...

    Android-Android和Js交互Demo

    在Android应用开发中,Web视图(WebView)是一种强大的组件,它允许开发者在原生应用中展示网页内容,甚至实现JavaScript与Java代码的交互。这个"Android-Android和Js交互Demo"是关于如何利用WebView来实现这种交互...

    android与js基本交互

    1. **WebView组件**: Android中的`WebView`是实现Android与JavaScript交互的基础。它是一个可以加载和显示网页的视图,同时提供了与JavaScript交互的能力。 2. **loadUrl方法**: 使用`WebView.loadUrl("javascript:...

    EasyJSWebViewSample 仿android 原生js交互的框架

    `EasyJSWebViewSample`是一个专为iOS设计的框架,旨在模仿Android平台上的原生JS交互机制,使开发者能够更加便捷地在Objective-C或Swift中与嵌入的WebView进行通信。下面我们将详细探讨这个框架的核心概念、实现原理...

    android插件,与原生的衔接

    本文将深入探讨如何在使用Ionic与Cordova的项目中创建自定义插件,并实现与Android原生代码的交互。 1. ** Ionic和Cordova简介:** Ionic是一个基于AngularJS的开源HTML5移动应用框架,用于构建混合移动应用。它...

    android与js交互的demo

    综上所述,“android与js交互的demo”涵盖了Android与JavaScript交互的关键技术点,包括WebView的使用、交互接口的设置以及安全策略。通过深入理解这些知识点,开发者可以有效地构建混合式移动应用,结合Web的动态性...

    Android高级应用源码-Android webView和js交互的Demo.rar

    在Android开发中,WebView是一个非常...通过学习和分析这份源码,开发者不仅可以掌握基本的`WebView`操作,还能深入了解Android应用与网页之间交互的实现机制,这对于开发混合型应用或者增强原生应用的功能非常有帮助。

Global site tag (gtag.js) - Google Analytics