Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2090728
  • 博文数量: 229
  • 博客积分: 7217
  • 博客等级: 上校
  • 技术积分: 3224
  • 用 户 组: 普通用户
  • 注册时间: 2009-02-19 17:23
个人简介

个人主页https://xugaoxiang.com,微信公众号: Dev_Club 或者搜索 程序员Club

文章分类

全部博文(229)

文章存档

2017年(1)

2016年(20)

2015年(23)

2013年(1)

2012年(23)

2011年(68)

2010年(62)

2009年(31)

分类: Android平台

2015-05-14 15:18:00

本篇通过一个实例来说明如何在javascript中去调用android的函数,其实方法也比较简单,只要调用addJavascriptInterface方法即可映射一个java对象到javascript对象。

Android代码

点击(此处)折叠或打开

  1.         package com.macernow.djstava;

  2.         import android.support.v7.app.ActionBarActivity;
  3.         import android.os.Bundle;
  4.         import android.util.Log;
  5.         import android.view.Menu;
  6.         import android.view.MenuItem;
  7.         import android.webkit.JavascriptInterface;
  8.         import android.webkit.WebView;
  9.     
  10.     
  11.         public class MainActivity extends ActionBarActivity {

  12.      private static final String TAG = "MainActivity";
  13.      private WebView webView;

  14.      @Override
  15.      protected void onCreate(Bundle savedInstanceState) {
  16.      super.onCreate(savedInstanceState);
  17.      setContentView(R.layout.activity_main);

  18.      webView = (WebView)findViewById(R.id.webView);
  19.      webView.getSettings().setJavaScriptEnabled(true);
  20.      webView.addJavascriptInterface(this,"djstava");
  21.      webView.loadUrl("");

  22.         }

  23.      @JavascriptInterface
  24.      public void jsextent() {
  25.      Log.e(TAG,"========== js extension success.");
  26.      }

  27.      @Override
  28.      public boolean onCreateOptionsMenu(Menu menu) {
  29.      // Inflate the menu; this adds items to the action bar if it is present.
  30.      getMenuInflater().inflate(R.menu.menu_main, menu);
  31.      return true;
  32.      }

  33.      @Override
  34.      public boolean onOptionsItemSelected(MenuItem item) {
  35.      // Handle action bar item clicks here. The action bar will
  36.      // automatically handle clicks on the Home/Up button, so long
  37.      // as you specify a parent activity in AndroidManifest.xml.
  38.      int id = item.getItemId();

  39.      //noinspection SimplifiableIfStatement
  40.      if (id == R.id.action_settings) {
  41.      return true;
  42.      }

  43.      return super.onOptionsItemSelected(item);
  44.          }
  45.      }
WebView一定要使能javascript。在Android 4.2之后,抛出给javascript的java方法必须加上@JavascriptInterface。

布局文件

点击(此处)折叠或打开

  1. <RelativeLayout xmlns:android=""
  2.      xmlns:tools="" android:layout_width="match_parent"
  3.      android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
  4.      android:paddingRight="@dimen/activity_horizontal_margin"
  5.      android:paddingTop="@dimen/activity_vertical_margin"
  6.      android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
  7.     
  8.      <WebView
  9.      android:id="@+id/webView"
  10.      android:layout_width="fill_parent"
  11.      android:layout_height="fill_parent">
  12.      </WebView>
  13. </RelativeLayout>


测试调用

在javascript脚本中调用java方法


点击(此处)折叠或打开

  1. window.djstava.jsextent()

扫描关注微信公众号


阅读(2845) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~