一、js调用app
/**
* 向app发起请求
* actionName {String} 调用app的方法名
* @param args.__token {String} token为唯一标识,用来区别,同一方法的多次调用。
* @param args 其他的所有字段均为请求时需要的数据
*/
window.webkit.messageHandlers['actionName'].postMessage({
__token: 'token',
...args
});
window.AndroidInterface['actionName']({
__token: 'token',
...args
});
/**
* app处理完毕后回调js
* @param args.__name {String} js调用app时使用的方法名
* @param args.__token {String} js调用时传递的token
* @param args.__status {Number} 是否处理成功,Number类型 0为成功,其他值为失败
* @param args.__message {String} 可选,如果处理失败,则必须在这个字段中添加失败描述
* @param args 其他的所有字段均为处理后的返回结果
*/
window['koolearnApp2jsBridge.callback']({
__name: 'actionName',
__token: 'token',
__status: 0,
__message: '',
...args
});
二、APP调用js
/**
* 向js发起请求
* @param args.__name {String} js处理完毕后回调app的方法名
* @param args.__token {String} token为唯一标识,用来区别,同一方法的多次调用。
* @param args 其他的所有字段均为请求时需要的数据
*/
window['koolearnApp2jsBridge.trigger']({
__name: 'actionName',
__token: 'token',
...args
});
/**
* js处理完毕后回调app
* actionName {String} app发起调用时传递的方法名
* @param args.__token {String} app调用时传递的token
* @param args.__status {Number} 是否处理成功,Number类型 0为成功,其他值为失败
* @param args.__message {String} 可选,如果处理失败,则必须在这个字段中添加失败描述
* @param args 其他的所有字段均为处理后的返回结果
*/
window.webkit.messageHandlers['actionName'].postMessage({
__token: 'token',
__status: 0,
__message: '',
..args
});
window.AndroidInterface['actionName']({
__token: 'token',
__status: 0,
__message: '',
...args
});
三、 前端js模块的使用方法
var sendToApp = require('project/m-teach/1.x/common/send-to-app/2.x/send-to-app');
sendToApp('login', {}, true).then(
function(data){
console.log('登陆成功', data);
},
function(message){
console.log('登陆失败', message);
}
);
sendToApp.on('actionName', function(e, data){
var dfd = $.Deferred();
return dfd.promise();
});
四、常用接口示例
**登录接口的app回调**
window['testjsBridge.callback']({
__name: 'actionName',
__token: 'token',
__status: 0,
__message: '',
headImg: "http://img2.imgtn.bdimg.com/it/u=3588772980,2454248748&fm=27&gp=0.jpg",
userAccount: 0,
userId: 63938231,
userName: "张三"
});
下载地址:
https://download.csdn.net/download/lvluffy/10311552