原生Android和IOS开发耗时比较久,混编相对而言就有了优势,混编工具框架很多,个人觉得APiCloud相对简单容易。开发过程比较上手也有几个坑,在使用一年后简单做个总结。官方文档API:https://docs.apicloud.com/
1开发工具http://www.apicloud.com/devtools
APICloud Studio 1 简洁稳定,代码管理直接在apicloud云端应用,代码提示不智能,建议需求稳定性者使用。
APICloud Studio 2 操作复杂,代码管理需先从第三方git/svn仓库选择一种检出,代码提示比较智能。
2.模块开发http://docs.apicloud.com/Module-Dev/module-dev-guide-for-android
eclipse和Androidstudio都可以进行原生开发后上传模块,注意模块名必须不能重复,详情看链接介绍
3.在线社区https://community.apicloud.com/bbs/forum.php
由于用的人不多百度很少人回答,通过在线社区是一个不错的解决问题方法
4.常用方法函数
常用css:position如果选择固定位置fixed;float如果选择左排列偏移left;overflow如果内容满出可滑动scroll;white-space如果不换行单行nowrap;display如果行内元素inline-block;设置行数:style="overflow: hidden;-webkit-line-clamp:1;display: -webkit-box;-webkit-box-orient: vertical;"常用居中:<center></center>常用判断:if (/Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent)) {//当前是手机端}
①网络请求:jquery框架比自带的请求好用
function aja(){
$.ajax({
url: "xx",
type: "post",
dataType: "json",
async:false,
crossDomain:true,//支持跨域 后台设header("Access-Control-Allow-Origin: *");
beforeSend: function(request) {
request.setRequestHeader("access-token", $api.getStorage('ACCESS_TOKEN'));//head
},
data: {
username: "admin",//参数
password: 1,
},
error:function(err){
alert("网络出错:"+JSON.stringify(err.status));
},
success: function (data) {
$api.setStorage('ACCESS_TOKEN', data.data);//apicode储存简单数据
alert( JSON.stringify( data ) );
}
});
};
----------------------------------------------------------------------------------------------------
window.onscroll=function(){
if(window.pageYOffset>=document.body.clientHeight-document.documentElement.clientHeight){//滑到底了
aja();
}
};
<form action="xx" target="iframe" method="post" enctype="multipart/form-data" onsubmit="aja()">
<input type="file" name="file" pattern="" title="不符合" autocomplete="off">
<input type="submit"> //不跳转action: target="iframe" 拦截表单action: onsubmit="xx();return false"
</form>
②页面跳转和分享
api.openWin({
name: 'h5',
url: './h5.html',//像原生一样开启一个新页面
pageParam:{
name:'传给页面的数据',//新页面调用api.pageParam.name
},
});
apiready=function(){
$api.byId("h").innerHTML=document.location ="https://www.baidu.com";//开启页面时立即自动在指定位置显示指定网址
$api.byId("h").innerHTML="请稍候,loading...";
};
var sharedModule = api.require('shareAction');//分享功能
sharedModule.share({
text: '纯文本信息,这是一条分享信息',
type: 'url',
path:"https://www.baidu.com/",
thumbnail:"widget://a.png",
});
api.addEventListener({
name:'viewappear'
},function(ret,err){
alert('系统监听到显示页面');
});
api.addEventListener({
name:'keyback'
},function(ret,err){
alert('系统监听到返回键');
});//自定义广播api.sendEvent();
③select和checkbox全选单选:Vue框架使用更方便
<div id="app"> //oncontextmenu="return false"禁止长按或右键 onselectstart="return false"禁止复制
<select v-model='items' @change="mycity(items)">
<option id='yes' v-if="sub.NAME.indexOf('yes')>-1==true" v-for='(sub,index) in result'>{{sub.NAME}}</option>
</select>
<img :src="VUEIMG" onerror="this.src='../image/xx'" :class="{ 'classA':isA,'classB':isB}">
</div>
<script type="text/javascript" src="../script/vue.js" ></script>
<script type="text/javascript">
var vm=new Vue({
el:'#app',//Vue作用域
data:{//Vue数据
items:"city",
result:[],
},
methods:{//Vue方法
mycity:function(texts){
alert(texts);
},
},
});
apiready=function(){
vm.result=ajaxcity();//初始化时自定义方法获取数据
}
</script>
<div style="margin: 0.8rem"><input type="checkbox" id="qx" @click="all()"></div>
<div style="margin: 0.8rem"><input type="checkbox" name="dx" @click="one()"></div>
<div style="margin: 0.8rem"><input type="checkbox" name="dx" @click="one()"></div>
<input type="radio" name="radiogroup" @change='mycity()' checked="">
<script type="text/javascript">
var all=document.getElementById("qx");//全选框设置唯一的id
var one=document.getElementsByName("dx");//多个多选框设置相同name
function one(){//checkbox多选框联动
var data=[];
var selcount=0;
for(var i=0;i<one.length;i++) {
data.splice(i,0,one[i].checked);
if(one[i].checked){
selcount++;
}
if(!one[i].checked){
selcount--;
}
if(selcount==one.length){
all.checked=true;
}else{
all.checked=false;
}
}
return data;
}
function all(){//checkbox全选框联动
if(all.checked){
for(var i=0;i<one.length;i++) {
one[i].checked=true;
}
}else{
for(var i=0;i<one.length;i++) {
one[i].checked=false;
}
}
}
</script>
④导入地图框架
<script type="text/javascript" src="http://libs.baidu.com/jquery/1.7.2/jquery.min.js"></script>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=ZKvE25QNawwRm3EFb7hLnliSHTXReN60"></script>
<script type="text/javascript">
// 百度地图API功能
var map = new BMap.Map("line_map");//指定区域ID显示地图
var point = new BMap.Point(116.400244,39.92556);//经纬度
map.centerAndZoom(point, 12);//显示中心区域
var marker = new BMap.Marker(point,{icon:new BMap.Icon("../image/G.png",new BMap.Size(28,38))});//画标注
marker.id="xx";//给marker赋值//marker=new BMap.Polyline([prev,next ],{strokeColor:"#3391cc",strokeWeight: 2,strokeOpacity:0.5});//画线
map.addOverlay(marker);// 将标注添加到地图中,如要删除map.clearOverlays();
marker.enableDragging(); // 可拖拽
marker.addEventListener("click", getAttr);//点击图标
function getAttr() {
alert(JSON.stringify(marker.id));
};
marker.addEventListener("dragend", function () {//拖拽图标
var p = marker.getPosition();//获取marker的位置
alert("marker的位置是" + p.lng + "," + p.lat);
});
</script>
⑤定时器
△setInterval(code,millisec) 按照周期不停地调用函数,直到调用clearInterval(name)或窗口关闭
code 必需。要调用的函数function () { //要执行的代码; }
millisec 必须。周期性执行之间的时间间隔,以毫秒计。
获取时间var d=new Date();d.getFullYear();d.getMonth()+1;d.getDate();d.getHours();d.getMinutes();d.getSeconds();
△setTimeout(code,millisec) 在指定的毫秒数后调用函数
code 必须。要调用的函数function () { //要执行的代码; }
millisec 必须。在执行代码前需等待的毫秒数。
⑥类型转换和数组操作
for (var i = 0; i < array.length; i++) {
Boolean(100); //true – non-zero number
Boolean(null); //false - null
Boolean(0); //false - zero
Number(false); //0
Number(true); //1
Number("5 "); //5
Number( "5.5 "); //5.5
}
数组pop:删除原数组最后一项,并返回删除元素的值,如数组为空返回undefined
pop();
数组push:将参数添加到原数组末尾,并返回数组的长度
push();
数组splice:删除指定位置元素或增加指定位置元素
splice(index,howmany,item1,.....,itemN)
index必需。整数,删除项目的下标,使用负数可从数组结尾处规定位置。
howmany 必需。要删除的项目数量。如果设置为 0,则不会删除项目。
item1, ..., itemX 可选。向数组添加的新项目。
数组reverse:将数组反序
reverse();
数组sort(orderfunction):按指定的参数对数组进行排序
sort();
⑦图片预览图片上传
<label for="DIY" style="border:1px red solid;border-radius: 5px">自定义选择按钮</label>
<input type="file" accept="image/*" capture="camera" id="DIY" style="position:absolute;clip:rect(0 0 0 0);"><!--照相-->
<input type="file" accept="video/*" capture="camcorder"><!--录影-->
<input type="file" accept="audio/*" capture="microphone"><!--录音-->
<img id="image"src=""/>
var image = '';
$("#DIY").change(function(){
image=selectImage(this);
});
function selectImage(file){
if(!file.files || !file.files[0]){
return null;
}
var reader = new FileReader();
reader.onload = function(evt){
document.getElementById('image').src = evt.target.result;//图片预览数据
return evt.target.result;//得到的数据
}
reader.readAsDataURL(file.files[0]);//base64格式""
};
function save(url) {// 创建隐藏的下载
var eleLink = document.createElement('a');
eleLink.download = "";
eleLink.style.display = 'none';
eleLink.href = url;//支持本地在线路径图片下载
document.body.appendChild(eleLink);
eleLink.click();//点击
document.body.removeChild(eleLink);
};
<script src="https://cdn.bootcss.com/html2canvas/0.5.0-beta4/html2canvas.min.js"></script>
var imgUri = canvas.toDataURL("image/png").replace("image/png", "image/octet-stream"); // 截图src
⑧打印日志log(工具栏->启动日志)打印cookie
alert(document.getElementById("myid").value);//显示input的值。
alert(document.getElementById("hid").innerText);//显示标签innerHTML值。
console.log($('#myid').val());//打印日志显示input的值。
console.log($('#hid').text());//打印日志显示标签html()值。
var xxx='测试打印大于3000个字符长度的log';
var index=0;
if(xxx.length<3000){
console.log('打印短的:'+xxx);
}else if(xxx.length>=3000){
while(xxx.length>index){
console.log('打印长的:'+xxx.substring(index,index+3000));
index+=3000;
}
};
document.cookie;//获取cookie字符串
document.cookie="name=abc";//设置cookie
⑨支持各浏览器代码复制文字到粘贴板
/*document.getElementById("xx").onclick=function(e){
var targ = e.target;//获取当前事件点击元素Element
targ.className = 'bgover';//改变整个类css样式
//document.getElementById('xx').style.display="none"//改变单个css样式
}*/
function copyTextToClipboard(text) {
var textArea = document.createElement("textarea")
textArea.style.width = '1px'
textArea.style.height = '1px'
textArea.style.border = 'none'
textArea.style.outline = 'none'
textArea.style.boxShadow = 'none'
textArea.style.background = 'transparent'
textArea.value = text
document.body.appendChild(textArea)
textArea.select()
if(document.execCommand('copy')){
alert("复制到粘贴板了");
}
document.body.removeChild(textArea)
}
⑩显示标签内容不被转义
var temp = document.createElement("div");
temp.innerHTML = 'html标签格式的内容';
var output= temp.innerText || temp.textContent;
temp = null;
//document.getElementById("goods_id").innerHTML=output;