混合应用中的javascript实践

混合应用(hybird app) 在几年前便进入大众视野,近来更是越发风生水起,深受人民群众的喜爱。

目录

概念

交互

调试

其他

概念

什么是混合应用

混合应用(hybird app) 顾名思义,便是将web app与native app混合在一起,既享受html快速开发、快速版本迭代带来的便利,也能使用原生app调用系统接口和第三方SDK的强大扩展能力。

混合方式

如同茴字有几种写法一般,构建混合应用也有不同的方式。其中一种是主要使用静态html,用 phonegapcordova 加壳的方式打包成app。另一种则是小部分webview直接引入服务端渲染的html,其他功能都是原生app开发。

其中前一种方式最为出名的解决方案便是使用 angular.js + cordovaionic,而使用后一种方式的app则数不胜数。

但是无论使用哪一种方式,都面临一个问题,html和app的交互。html自己不会动起来,本文将浅谈javascript如何交互app和html。

交互

方法注入

常见的app和html交互有 使用url互相调用方法 两种方式。

使用url 这种方式比较简单,通过 location.href = 'url' ,即可将方法和参数传递给app,但是无法传递复杂的数据。

互相调用方法 这种方式则较为复杂,除了需要app端写好调用的方法注入到 window 对象之外,还需要JavaScript暴露方法给app使用。以常见的评论交互为例:

// 点击“发表评论”,js需要调用app的评论框
$('.js-comment').click(function(){
window.appMethod.comment();
}); // app端在用户点击“发送”按钮时,再调用javascript的插入评论方法(我不会app开发,以下是伪代码)
function comment(){
TEXTAREA.OPEN();
}
SUBMIT_BUTTON.CLICK(function(){
NSString * result = [self.webView stringByEvaluatingJavaScriptFromString:@"window.jsMethod.comment()"];
})

其中 window.appMethod 这个方法,是一个从 iOS 和 android 方法中提取而来的方法,根据手机系统不同,使用不同策略,例如:

var window.appMethod = null;

var androidMethod = {
comment: function(){
window.android.comment();
}
}; var iOSMethod = {
comment: function(){
location.href = 'ios://comment?'
}
}; window.appMethod = iOS_DEVICE ? iOSMethod : androidMethod;

相比方法的注入点,策略处理,方法的调用时机更为重要。在js中调用一个不存在方法,会发生错误从而导致代码无法继续向下执行。

比如进入页面时,app需要告诉html一些登录信息,以初始化点赞,收藏等组件。如果由app直接调用js方法去通知,那么很可能页面还没加载完,而发生上面提到的错误。

所以好的时机是让js主动去向app发起请求,示例:

// 不和谐:app直接通知js更新用户登录状态,可能会发生错误
eval('window.jsMethod.setUser();') // 和谐:js主动去向app发起请求
$(function(){
window.appMethod.getUser();
}) // app端在接收到getUser方法后,调用js方法(我不会app开发,以下是伪代码)
function getUser(){
// 获取user状态,然后执行
NSString * result = [self.webView stringByEvaluatingJavaScriptFromString:@"window.jsMethod.setUser()"];
}

参数传递

以上的示例中的方法并没有进行参数传递,是为了留到这里。

相比JavaScript,在android和iOS方法中传递参数显得极为严格,除了要指定参数个数,还要指定参数类型。

虽然可以通过数组的方式进行不定个数参数的传递,但是指定参数类型还是挺烦人的。所以建议始终使用 String 类型作为参数进行传递,复杂的json格式参数使用 JSON.stringify。使用url传递则需要对参数进行 encode 编码。

以上面的发表评论为例:

# 本段代码使用了jquery

// js给app传参
var androidMethod = {
comment: function(params){
window.android.comment( JSON.stringify(params) );
}
}; var iOSMethod = {
comment: function(params){
location.href = 'ios://comment?'+$.param(params)
}
}; ... ... $('.js-comment').click(function(){
var params = {
"user_id": 30,
"article_id": 958,
"article_type": "news"
};
window.appMethod.comment(params);
}); // app给js传参
SUBMIT_BUTTON.CLICK(function(){
var params = {
"comment_id": 5484,
"comment_content": "我不会写app,姑且用js写伪代码"
};
NSString * result = [self.webView stringByEvaluatingJavaScriptFromString:@"window.jsMethod.comment( JSON.stringify(params) )"];
})

方法监听

这里的方法监听指的是app对js方法的单向监听。

因为需要app监听的js方法,都是显示的调用了app方法,或是跳转到了一个url。调用app的方法自不待言,url的监听却有多种。

一种是a链接的 http GET 请求的监听,多见于 下一篇文章 , 相关文章 等跳转页面的方法。一般来说不用带参数。还有一种是自定义的 schema 监听,使用这种方式一般是不带或带较少的参数,比如 myiOS://mymethod?

资源加载

把资源加载放到交互里面,我也不知道合不合适。对于 第一种混合方式 来说,可以把更多的静态资源放到本地,然后通过app接口加载。对于第二种,更多的还是从服务端渲染并加载资源。

对于一些交互类的数据,而非资源,既可以选择存放在浏览器的localStorge中,也可以选择存放于app本地文件,这取决于哪一方进行操作运算了。

调试

html的移动端调试时很困难的,嵌入app的html调试更是难上加难。因为js和app的方法相互调用,任何一方出错,都会导致程序不按套路运行。

除了仔细的约定两端的方法和检查代码的错误外,还需要一个强力的工具。在这里推荐使用 vConsole ,可以比较直观的定位到错误。

其他

兼容性

html在app中的兼容性取决于app内嵌浏览器内核。iOS系统默认的浏览器是safari,而andriod系统默认的浏览器则五花八门。

如果选择系统默认浏览器作为内嵌浏览器的话,ios一般兼容性较好,能取得和PC端一致的效果。android机型则会比较悲剧,使用 crosswalk方案 或许是个正确的选择。

特性启用

在内嵌浏览器中,html5的某些特性默认是关闭的,比如 localStorge , 需要app端手动去开启。所以在开发中一定要做好可用性检测,减少出现bug的几率。

局部视图

当html作为webview的局部视图被加载时,由于app虽然可以获取到页面加载后的高度,但是无法获取动态改变后的高度,使得局部滚动失效。

所以在作为局部视图加载时,如果需要页面高度会根据比如评论,动画效果而发生改变的话,需要及时通知app更新webview高度。

混合应用中的javascript实践的更多相关文章

  1. Web API应用架构在Winform混合框架中的应用(4)--利用代码生成工具快速开发整套应用

    前面几篇介绍了Web API的基础信息,以及如何基于混合框架的方式在WInform界面里面整合了Web API的接入方式,虽然我们看似调用过程比较复杂,但是基于整个框架的支持和考虑,我们提供了代码生成 ...

  2. 在Swift中使用JavaScript的方法和技巧

    本文作者Nate Cook是一位独立的Web及移动应用开发者,是继Mattt大神之后NSHipster的主要维护者,也是非常知名活跃的Swift博主,并且还是支持自动生成Swift在线文档的Swift ...

  3. HTML中的javascript交互

    在Android开发中,越来越多的商业项目使用了Android原生控件与WebView进行混合开发,当然不仅仅就是显示一个WebView那么简单,有时候还需要本地Java代码与HTML中的javasc ...

  4. Hybrid混合开发中schema协议的使用与封装

    混合开发中JS与APP通信的实现原理: JS通过schema协议,传递参数和全局回调函数给APP端 APP执行完(如微信扫一扫)后,调用协议中传入的回调函数,在前端执行回调处理. 默认写法: < ...

  5. 在 Swift 專案中使用 Javascript:編寫一個將 Markdown 轉為 HTML 的編輯器

    原文:Using JavaScript in Swift Projects: Building a Markdown to HTML Editor 作者:GABRIEL THEODOROPOULOS ...

  6. JavaScript高级程序设计-(1)html中使用JavaScript

    html中使用JavaScript 1.延迟脚本 script标签定义了defer属性,脚本会被延迟到整个页面都解析完毕后运行 详细内容如下: 2.异步脚本 script标签定义了async属性,as ...

  7. 在HTML中使用JavaScript元素

    script属性<script async = async charset="utf-8" defer="defer" src="index.h ...

  8. 2在HTML中使用JavaScript

    像HTML页面中插入JavaScrip的主要方法,就是使用<script>元素.HTML4.01为<script>定义了6个属性:async:可选,表示应该立即下载脚本,当不妨 ...

  9. javascript高级编程3第二章:在html中使用javascript

    2.1 <script>元素 向html页面中插入javascript的主要方法,就是使用<script>元素.这个元素被加入到正式的html规范中.html4.01为< ...

随机推荐

  1. pythonchallenge(三)

    PythonChallenge_3 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou,密码shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux ...

  2. Boostrap(4)

    1.按钮 <!doctype html> <html> <head> <meta charset="utf-8"> <titl ...

  3. php 判断是否get传值的参数是否存在

    if(is_array($_GET)&&count($_GET)>0)//先判断是否通过get传值了    {        if(isset($_GET["id&qu ...

  4. hdu3374 KMP+最大最小表示法

    这题要求的是字符串左移时字典序最小和最大的第几次出现,并求出现次数.考虑一会可以发现,出现次数和循环节是有关系的. 出现了几次,就是循环了几次,如果循环节是他本身,也就是无循环,那这个字符串不管怎么移 ...

  5. JavaWeb 项目开发中的技术总结

    前言: 在项目开发过程中的一点点指导思想 1.环境准备 win系统 Eclipse 开发平台 maven tomcat Mysql 数据库,mysql5.6 操作数据库的jar 包 JDBC 连接数据 ...

  6. 浅谈Logistic回归及过拟合

    判断学习速率是否合适?每步都下降即可.这篇先不整理吧... 这节学习的是逻辑回归(Logistic Regression),也算进入了比较正统的机器学习算法.啥叫正统呢?我概念里面机器学习算法一般是这 ...

  7. POJ2411 Mondriaan's Dream

    Description Squares and rectangles fascinated the famous Dutch painter Piet Mondriaan. One night, af ...

  8. codeforces 359D 二分答案+RMQ

    上学期刷过裸的RMQ模板题,不过那时候一直不理解>_< 其实RMQ很简单: 设f[i][j]表示从i开始的,长度为2^j的一段元素中的最小值or最大值 那么f[i][j]=min/max{ ...

  9. [NOIP2011] 普及组

    数字反转 小模拟 #include<cstdio> #include<iostream> #include<cstring> using namespace std ...

  10. TCP/IP详解 学习六

    从ip层看路由表  选路策略 选路策略:决定把哪些路由放到路由表的规则. Ip执行选路机制,而路由守护程序则提供选路策略. Netstat –rn 打印路由表,如果没有-n命令会搜索配置文件,将网络地 ...