APICloud开发小技巧(一)
apicloud开发文档中,前端开发框架指的就是,类似jq\js的语法: https://docs.apicloud.com/Front-end-Framework/framework-dev-guide。
api对象就只的是:app的方法。
1.安卓滑动关闭窗口
在IOS设备上可以通过滑动来关闭win,在安卓默认是不可以。细看下文档其实也很的简单,监听事件里面的swiperight:
如果一个窗口是先打开win再嵌套frame的打开的方法如下
apiready = function(){
api.addEventListener({
name:'swiperight'
},function(ret,err){
api.closeWin({
name: 'win窗口name'
});
})
};
如果是直接用win打开的窗口
apiready = function(){
api.addEventListener({
name:'swiperight'
},function(ret,err){
api.closeWin({});
})
};
2.安卓点击两次退出应用
//两次退出
var first = null;
function back(){
api.addEventListener({
name: 'keyback'
}, function(ret, err){
if (!first) {
first = new Date().getTime();
api.toast({
msg: '再按一次退出',
duration:,
location: 'bottom'
});
setTimeout(function() {
first = null;
}, );
} else {
if (new Date().getTime() - first < ) {
api.closeWidget({
silent:true
});
}
}
});
} 把back方法放在apiready里面就OK了
3.安全保存你的各种key
在app中,有时我们会使用到一些第三方的key,如果让这些KEY更安全呢,其实官方也有提高,很多朋友却没有留意
在res文件夹中新建一个key.xml
<?xml version="1.0" encoding="UTF-8"?>
<security>
<item name="key0" value="value0"/>
<item name="key1" value="value1"/>
<item name="key2" value="value2"/>
<item name="key3" value="value3"/>
</security> 然后通过
api.loadSecureValue({
key:'key名'
}, function(ret, err) {
var value = ret.value;
}); 来调用。云编译的时候会自动加密的,不过在真机测试的时候是没有用的,需要云编译才可以。在打包的时候可以统一配置下
4。利用本地文件存储实现秒开和离线浏览
在api对象里面有两个方法readFile和writeFile,我们可以利用这两个来搞一下,而且还会对图片自动缓存的
通常我们的列表页数据是json的,我们可以对这个json数据循环下
function writeFile(json){
var cacheDir = api.cacheDir;
for(var i=;i<json.length;i++) {
var id = json.id;//你的内容id
var data = json;//内存数据
api.writeFile({
path: cacheDir+'/'+id+'.json',
data: JSON.stringify(data)
}, function(ret, err){
})
}
}
注意要通过JSON.stringify转换下格式,否在在IOS上写入不成功
然后在打开内容页的时候先看下有没有对应id文件存在
function readFile(){
var cacheDir = api.cacheDir;
api.readFile({
path: cacheDir+'/'+id+'.json'
}, function(ret, err){
if(ret.status){
var jsonData = JSON.parse(ret.data);
} else{
//从服务器读取
}
});
} 还要注意,再次转换下数据格式
5.打开页面有闪动?那让他闪的个性点
很多开发者在开发的时候会遇到页面打开闪动的问题,不管是从服务器读取还是从本地缓存读取都有可能会闪动。既然解决比较麻烦,我们就利用CSS3动画,让他闪的个性点。很简单,给元素ID加个fade效果
比如你的页面内容全部在<div id="wrap"></div>里面。那么我们就给wrap弄个CSS动画,渐入效果,下面是css代码
#wrap {-webkit-animation: fadeIn .5s ease both;animation: fadeIn .5s ease both;}
@-webkit-keyframes fadeIn {
from { opacity: 0.3; }
to { }
}
@keyframes fadeIn {
from { opacity: 0.3; }
to { }
}
6.安卓最小化你的APP
在安卓开发的时候我们会使用最小化应用,不让其退出,其实官方已经提供了这个api方法,只是可能隐蔽点不容易发现
api.toLauncher();
7.安卓上巧实现日期加时间的选择
在使用openPicker时我们知道安卓设备是不支持同时选择日期加时间的,也就是date_time属性。又不想使用插件,也不想选择完日期后在点击按钮选择时间,那么我们将openPicker稍微改一下实现时间+日期的选择
思路:判断如果是安卓设备,则先openPicker打开时间选择,时间选择完成后在openPicker一下选择日期。
if(api.systemType=='android'){
api.openPicker({
type: 'date',
title:'选择时间'
},function(ret,err){
var year = ret.year;
var month = ret.month;
var day = ret.day;
//这是选择的是日期
var value1 = year+'-'+month+'-'+day;
//选择时间
api.openPicker({
type: 'time',
title:'选择时间'
},function(ret,err){
var hour = ret.hour;
var minute = ret.minute;
//选择的时间
var value2 = hour+':'+minute;
//组装一下
alert(''+value1+' '+value2+'');
});
});
}
使用此代码,可自动循环播放视频了哦,不需要全屏
<video id="player" src="widget://res/video.mp4" loop autoplay webkit-playsinline></video>
在IOS上可以自动播放,在安卓下还需要加一句 $api.byId('player').play(); (这代码需要视频加载完后才能调用,不过我都是包内的视频源,没有测需要缓冲的视频)
如果要缓冲,在安卓下可以 <video id="player" src="widget://res/video.mp4" loop controls webkit-playsinline></video> 让用户自己通过点击再播放
9、fastclick 的使用方法
$(function(){
FastClick.attach(document.body);
});
10、页面跳转,并传递参数
function openWin(id) {
api.openWin({
name : 'list_window',
url : 'list_window.html',
bounces : false,
animation : {
type : "push",
duration :
},
//出境国内周边 游轮 分别对应一个 id
pageParam : {
key : id
}
});
};
下个页面接受参数
var typeName = api.pageParam.key;
11、多个li点击某一个,那个元素高亮显示(toggle)
<ul class="choose_det">
<li tapmode="" onclick="chooseType(this);">2天</li>
<li tapmode="" onclick="chooseType(this);">3天</li>
<li tapmode="" onclick="chooseType(this);">4天</li>
<li tapmode="" onclick="chooseType(this);">10天</li>
<li tapmode="" onclick="chooseType(this);">10天以上</li>
</ul>
function chooseType(obj){
$api.toggleCls(obj, 'active');
};
上面的方法是 toggle 的方法,点击某一个,某个高亮,其余恢复默认代码如下
function cPhoneType(obj){
var ele = $api.byId('phoneTypeHtml');
var selectList = $api.domAll(ele, '.tabThree');
for(var i = ; i < selectList.length; i++){
$api.removeCls(selectList[i], 'activeC');
}
$api.addCls(obj, 'activeC');
}
12、某些页面数据变化,例如规格选择,选的比较多,改变之后在列表页要监听到选择的规格,这个时候传递参数会比较多,就用一个监听事件
在选择规格的页面,点击确定的时候,发送一个全局的监听事件
api.sendEvent({
name: 'myChoose',
extra: {
days: '',
data: '2013-2-3'
}
});
在列表页获取这个监听事件,当传递的值发生变化的时候,做出一些相应的改变或者动作
api.addEventListener({
name: 'chooseData'
}, function(ret, err) {
//alert(JSON.stringify(ret.value));
});
13、获取点击的对象的自定义属性。
<li class="'+ classLiName +'" dateId="'+ dateId +'" onclick="chooseDay(this)" tapmod="">
tapmod是为了点击更顺利。
function chooseDay(obj){
var dateId = $api.attr(obj,'dateId');
console.log(dateId)
}
还有一种直接传递的方式
<li class='list-item' onclick='openDetailWin(\"" + item.id + "\",\"" + item.title + "\");'>
function openDetailWin(zxId, title) {
var delay = ;
if ("ios" != api.systemType) delay = ;
api.openWin({
name : 'news_detail_module',
url : 'zx/news_detail_module.html',
delay : delay,
bounces: false,
pageParam: { id: zxId, title: title }
});
}
14、apicloud中,例如头部有一个返回的这种,一般来说都是两个页面,头部是一个页面,然后中间在加载一个frame。
打开关闭window
api.openWin({
name : 'line_detail',
url : 'line_detail.html',
bounces: false,
animation:{
type: "push",
duration:
},
pageParam : {
key : id
}
});
api.closeWin({
bounces: false,
animation:{
type: "push",
duration:,
subType:"from_left"
}
});
15、常用弹出
/*** 提示信息 ***/
api.toast({
msg: '手机号格式有误',
duration: ,
location: 'middle'
});
/*** 加载动画 ***/
api.showProgress({
title : ' ',
text : '玩命加载中...',
modal : true
}); api.hideProgress();
APICloud开发小技巧(一)的更多相关文章
- APICloud开发小技巧(二)
1.apicloud中 json.字符串之间的互转 $api.jsonToStr(ret); $api.strToJson(ret) 2.页面的来回跳转 例如已经打开了一个页面,跳转走,改变数据在跳 ...
- Windows统一平台: 开发小技巧
Windows统一平台: 开发小技巧 技巧一: 在手机端拓展你应用的显示区域.(WP8.1中也适用) 对于Windows Phone系统的手机, 手机屏幕最上方为系统状态栏(System Tray), ...
- flex开发小技巧集锦
关于flex开发网上有非常多的相关信息介绍,因此我们要想学习关于flex开发的知识信息技能是一件非常简单和方便的事情.而针对于flex开发小编要告诉大家的是一些flex开发小技巧.利用这些小技巧能够有 ...
- TP开发小技巧
TP开发小技巧原文地址http://wp.chenyuanzhao.com/wp/2016/07/23/tp%E5%BC%80%E5%8F%91%E5%B0%8F%E6%8A%80%E5%B7%A7/ ...
- 移动Web开发小技巧
移动Web开发小技巧 添加到主屏后的标题(IOS) name="apple-mobile-web-app-title" content="标题"> 启用 ...
- BizTalk开发小技巧
BizTalk开发小技巧 随笔分类 - Biztalk Biztalk 使用BizTalk实现RosettaNet B2B So Easy 摘要: 使用BizTalk实现RosettaNet B2B ...
- Java开发小技巧(三):Maven多工程依赖项目
前言 本篇文章基于Java开发小技巧(二):自定义Maven依赖中创建的父工程project-monitor实现,运用我们自定义的依赖包进行多工程依赖项目的开发. 下面以多可执行Jar包项目的开发为例 ...
- iOS开发小技巧 - UILabel添加中划线
iOS开发小技巧 遇到的问题: 给Label添加中划线,然后并没有效果 NSString *str = [NSString stringWithFormat:@"合计金额 ¥%.2f&quo ...
- PHP开发小技巧②—实现二维数组根据key进行排序
在PHP中内置了很多对数组进行处理的函数,有很多时候我们直接使用其内置函数就能达到我们的需求,得到我们所想要的结果:但是,有的时候我们却不能通过使用内置函数实现我们的要求,这就需要我们自己去编写算法来 ...
随机推荐
- 重置root管理员密码(RedHat、CentOS、Fedora)
重启Linux系统主机并出现引导画面时,按下键盘上的e键进入内核编辑界面. 在Linux16参数这行后面追加"rd.break"参数,然后按下Ctrl+x组合键来运行修改后的内核程 ...
- Linux系统学习之 三:新手必须掌握的Linux命令3
内容预览 1.输入输出重定向 2.管道命令符 3.命令行的通配符 4.常用的转义符号 5.重要的环境变量 一.输入输出重定向 重定向技术的5种模式:1 标准覆盖输出重定向 错误覆盖输出重定向 错误追加 ...
- poj 2763(LCA + dfs序 +树状数组)
算是模板题了 可以用dfs序维护点到根的距离 注意些LCA的时候遇到MAXM,要-1 #include<cstdio> #include<algorithm> #include ...
- Oracle笔记 多表查询
Oracle笔记 多表查询 本次预计讲解的知识点 1. 多表查询的操作.限制.笛卡尔积的问题: 2. 统计函数及分组统计的操作: 3. 子查询的操作,并且结合限定查询.数据排序.多表查询.统计查 ...
- redis-不常用的命令
在不重启redis服务器的情况下,动态的修改Redis的配置 redis> config set loglevel warning
- 反射常用API
反射所有功能都是通过class API来实现的 class常用API有: 1.class.GETINTERFACES():获得这个类实现的接口. 2.class.getMethods() Method ...
- 【小超_Android】android上开源的酷炫的交互动画和视觉效果:Interactive-animation
1.交互篇 2.视觉篇 交互篇 1.SlidingUpPanelLayout 项目介绍:他的库提供了一种简单的方式来加入一个可拖动滑动面板(由谷歌音乐推广,谷歌地图和Rdio)你的Android应用程 ...
- Ubuntu下启动Eclipse报错:A Java RunTime Environment (JRE) or Java Development Kit (JDK) must
原以为是jdk的环境变量配置错误了,于是从网上找了各种配置环境变量的方法.也注意空格的问题,可无论怎么改,还是这样报错!后来在网上看到一种奇怪的方法.我也不知道为什么这样就OK了? 方法:进入你的ec ...
- 为大家推荐一本书《jQuery Mobile 即学即用》
这是人民邮电出版社出版的一本面向前端开发者的书. 非常喜欢书名"即学即用"这是每一个程序开发者的理想模式. 不同国家的人有不同的思维方式.这本书的作者是 [阿根廷] Maximil ...
- rk3288的pcba模块编译调试笔记【学习笔记】
平台信息:内核:linux3.0.68 系统:android/android6.0平台:rk3288 作者:庄泽彬(欢迎转载,请注明作者) 邮箱:2760715357@qq.com 摘要:最近在负责r ...