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

如何使用JavaScript调用手机平台上的原生API

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

如何使用JavaScript调用手机平台上的原生API

这篇文章主要为大家展示了“如何使用JavaScript调用手机平台上的原生API”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用JavaScript调用手机平台上的原生API”这篇文章吧。

您也许会有一些需求,需要在您的前端应用里使用到手机平台的一些原生API,比如使用手机Mobile操作系统提供的传感器(Sensor)。这些任务是JavaScript不能直接完成的,必须借助Cordova里Custom Plugin(自定义插件)来完成。注意看下图红色高亮的Custom Plugin,起到了一个桥梁的作用,沟通了Cordova应用中的前端JavaScript代码和手机操作系统中的原生API。

如何使用JavaScript调用手机平台上的原生API

我们现在就来做一个实际的例子,我们选择Android平台为例。我在Android平台用Java实现两个整数相加,来模拟Android平台上的native API。我将会在我的前端应用里用JavaScript代码来调用我在Android平台上用Java实现的这个加法器。

先使用npm安装Cordova插件管理器。

命令行:npm -g install plugman

如何使用JavaScript调用手机平台上的原生API

插件管理器成功下载后,就可以用它创建一个自定义插件了。

命令行:plugman create -name Adder -plugin_id jerry.adder -plugin_version 1.0,0

如何使用JavaScript调用手机平台上的原生API

这个命令会自动创建一个名叫Adder的插件,插件id为jerry.adder, 版本号为1.0.0。

plugman会自动生成很多插件能够工作的资源文件,全部放在名为Adder的文件夹内。

如何使用JavaScript调用手机平台上的原生API

我希望这个Adder插件在安卓平台上工作,因此进入Adder文件夹,添加该插件对Android平台的支持:plugman platform add –platform_name android

如何使用JavaScript调用手机平台上的原生API

执行完毕后,Adder文件夹下自动生成子文件夹class="lazy" data-src/android和插件实现文件Adder.java。现在我可以在里面开始写代码了。

如何使用JavaScript调用手机平台上的原生API

用Java实现两个整数的加法运算。操作数都是通过JavaScript用参数args传入的,计算结果通过回调上下文CallbackContext返回给JavaScript端。

public class Adder extends CordovaPlugin {    @Override    public Boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {        if (action.equals("performAdd")) {            int arg1 = args.getint(0);            int arg2 = args.getint(1);            int result = arg1 + arg2;            callbackContext.success("result calculated in Java: " + result);            return true;        }        return false;    }}

插件实现完毕,可以开始打包了。使用命令行plugman createpackagejson ./

这个命令会自动生成一个package.json文件。

如何使用JavaScript调用手机平台上的原生API

Once done, the package.json file is generated within plugin folder.

如何使用JavaScript调用手机平台上的原生API

把这个自定义的插件安装到Cordova应用去,命令行:cordova plugin add Adder。

一切正常的话,能看到BUILD SUCCESSFUL的提示。

如何使用JavaScript调用手机平台上的原生API

如何用前端应用的JavaScript消费这个Java实现的插件呢?

在你Cordova项目文件夹<project folder>/platforms/android/assets/www/js的index.js里,将下列JavaScript代码粘贴进去:

var app = {initialize: function() {    document.addEventListener('deviceready', this.onDeviceReady.bind(this), false);},onDeviceReady: function() {    this.receivedEvent('deviceready');},receivedEvent: function(id) {    function success(result){        debugger;        alert("Jerry plugin result: " + result);    }    ;    setTimeout( function(){        Cordova.exec(success, null, "Adder", "performAdd", [10,20]);    }    , 10000);}};app.initialize();

关键代码就这一句:Cordova.exec(success, null, "Adder", "performAdd", [10,20]);

意思是调用名为Adder的插件,执行插件暴露的performAdd方法,传入两个参数10和20进去。Java插件的计算结果通过JavaScript回调函数success返回到前端应用中,用alert打印出结果。

如何使用JavaScript调用手机平台上的原生API

使用cordova compile打包Cordova应用,生成APK文件。执行该应用,能观察到10和20两个操作数传入到Java实现的插件中,结果30返回到前端并通过alert弹窗显示,我们的自定义插件开发成功!

如何使用JavaScript调用手机平台上的原生API

最后一步就是命令行cordova compile, 生成了最终的APK文件,然后就可以安装到安卓手机上了。

以上是“如何使用JavaScript调用手机平台上的原生API”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

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

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

如何使用JavaScript调用手机平台上的原生API

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

下载Word文档

猜你喜欢

如何使用JavaScript调用手机平台上的原生API

这篇文章主要为大家展示了“如何使用JavaScript调用手机平台上的原生API”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用JavaScript调用手机平台上的原生API”这篇文章吧。
2023-06-05

如何开始在三星手机上使用javascript

三星手机是现代人们最常用的智能手机之一,它具有最新的技术和功能,而且许多人都希望能够充分利用这些功能。其中一个重要的功能是javascript。许多人可能已经知道javascript的基础知识,但可能不知道如何开始在三星手机上使用它。因此,本文将为您介绍如何开始在三星手机上使用javascript。1. 了解javascript的基础知识Javascript是一种编程语言,用于
2023-05-14

使用Cordova将您的前端JavaScript应用打包成手机原生应用

假设我用JavaScript和HTML开发了一个前端应用,我想把该应用打包成能直接在手机上安装和运行(不通过浏览器)的原生应用,例如像下面这样。对应用的用户来说,他们得到的用户体验和真正的用Android Studio或者XCode开发的原
2023-06-05

大师调解win10系统台式机使用无线网卡上网的如何还原

  大师调解win10系统台式机使用无线网卡上网的如何还原?随着电脑的使用率越来越高,我们有时候可能会遇到对win10系统台式机使用无线网卡上网进行设置,如果我们需要对win10系统台式机使用无线网卡上网进行设置时,要怎么处理win10系统
2023-07-10

如何在 Mac 上使用 Windows 平台上的 Bazel 运行 Go 代码?

欢迎各位小伙伴来到编程网,相聚于此都是缘哈哈哈!今天我给大家带来《如何在 Mac 上使用 Windows 平台上的 Bazel 运行 Go 代码?》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注
如何在 Mac 上使用 Windows 平台上的 Bazel 运行 Go 代码?
2024-04-04

如何使用SAP云平台的destination消费Internet上的OData service

如何使用SAP云平台的destination消费Internet上的OData service,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。通过SAP云平台上的
2023-06-04

如何使用Java+SAP云平台+SAP Cloud Connector调用ABAP On-Premise系统里的函数

小编给大家分享一下如何使用Java+SAP云平台+SAP Cloud Connector调用ABAP On-Premise系统里的函数,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!为了确保Internet应用能够访问Cor
2023-06-04

如何使用Api分析器与Windows兼容包来编写智能的跨平台.NET Core应用

本篇文章为大家展示了如何使用Api分析器与Windows兼容包来编写智能的跨平台.NET Core应用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。正文:这是最近这几周你应该知道的一对.Net Co
2023-06-19

如何通过使用JDBC操作部署在SAP云平台上的HANA数据库

如何通过使用JDBC操作部署在SAP云平台上的HANA数据库,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。我介绍了如何通过JPA和EclipseLink操作部署
2023-06-02

详细介绍如何使用手机下载Gitee上的代码

在移动互联网时代,我们不再局限于使用电脑进行编程,手机也可以成为我们进行代码管理与开发的利器。而作为国内著名的代码托管平台,Gitee也提供了在手机上下载代码的功能。本文将详细介绍如何使用手机下载Gitee上的代码。一、前置条件在使用Git
2023-10-22

手机上如何使用阿里云服务器的FTP服务?

随着移动设备的普及,越来越多的用户开始在手机上进行远程服务器管理。其中,FTP服务是远程文件传输的重要工具之一。然而,对于一些新手用户来说,如何在手机上使用阿里云服务器的FTP服务可能会有些困难。本文将详细说明如何进行操作。一、在手机上使用阿里云服务器的FTP服务的步骤如下:首先,你需要在手机上下载并安装一个FT
手机上如何使用阿里云服务器的FTP服务?
2023-10-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录