8.1 比目后端云简介
8.1.1 注册bmob账号
8.1.2 创建应用
8.1.3 配置小程序密钥
8.1.4 获取微信小程序服务器域名和"应用密钥"
8.1.5 小程序配置"安全域名"
8.1.6 下载及安装bomb sdk
登录https:// github.com/bmob/bmob-WeApp-sdk 下载Bmod SDK,解压下载后的 SDK把 bmob-min.js和 underscore.js 文件放到相应的位置。例如,要放到小程序的 utils 目录中则在其他需要使用的页面添加以下代码:
var Bmob=require('../../utils/bmob.js');
同时,在小程序项目中的 app.js 中加入下面两行代码进行全局初始化:
var Bmob=require('utils/bmob.js');
Bmob.initialize("你的Applcation ID","你的REST API Key");
8.2 数据的增、删、改、查8.2.1 创建表及字段
在“test”表中添加id、title、content、image列,Bmob提供Number、String、Boolean、Data、File、Geopoint、Array、Object、Pointer、Relation共10中字段类型
8.2.2 添加一条记录
.xwml代码
<button type="primary" bindtap='add'>添加记录</button>
.js代码
var Bmob=require('../../utils/bmob.js');
Page({
data:{
},
add:function(){
var Test =Bmob.Object.extend("test");//创建类
var test=new Test();//创建对象
test.set("title","WXML");//添加title 字段内容
test.set("content","Weixin Markup Language 微信标记语言");//添加content字段内容/添加数据,第一个入口参数是nu11
test.save(null,{
success:function(result){
//添加成功,返回成功之后的 objectId(注意:返回的属性名字是 id,不是 objec-Id),你还可以在Bmob的web管理后台看到对应的数据
console.log("添加成功,objectId:"+result.id);
},
error:function(result,error){
//添加失败
console.log('添加失败');
}
});
},
})
8.2.3 获取一条记录
. wxml
<button type="primary" bindtap='query'>获取记录</button>
.js
var Bmob =require('../../utils/bmob.js');
Page({
data:{
},
query:function(){
var Test =Bmob.Object.extend("test");
var query = new Bmob.Query(Test);
query.get("1a67adc746",{
success:function(result){
//The object was retrieved successfully.
console.log("该记录标题为"+result.get("title"));
console.log("该记录的内容为"+result.get("content"));
},
error:function(result,error){
console.log("查询失败");
}
});
}
})
8.2.4 修改一条记录
.wxml
<button type="primary" bindtap='modi'>修改记录</button>
.js
var Bmob =require('../../utils/bmob.js');
Page({
data:{
},
modi:function(){
var Test = Bmob.Object.extend("test");
var query =new Bmob.Query(Test);
//这个id是要修改条目的id,当该id生成并存储成功时可以获取到
query.get("1a67adc746",{
success:function(result){
//回调中可以取得这个diary对象的一个实例,然后就可以修改它了
result.set('title',"WxSS");
result.set('content',"WenXin Style Sheets");
result.save();
//The object was retrieved successfully.
console.log("修改成功")
console.log("该记录标题修改为"+result.get("title"))
console.log("该记录内容修改为"+result.get("content"))
},
error:function(object,error){
console.log("修改失败")
}
});
}
}
)
8.2.5 删除一条记录
.wxml
<button type="primary" bindtap='del'>删除记录</button>
.js
var Bmob =require('../../utils/bmob.js');
Page({
data:{
},
del:function( ){
var Test = Bmob.Object.extend("test");
var query = new Bmob.Query(Test);
query.get("1a67adc746",{
success:function(object){
//The object was retrieved successfully.
object.destroy({
success:function(deleteObject){
console.log("删除记录成功");
},
error:function(error){
console.log("删除记录失败");
}
});
},
error:function(object,error){
console.log("修改失败")
},
});
},
})
8.2.6 查询所有数据
.wxml
<button type="primary" bindtap='queryall'>获取所有数据记录</button>
.js
var Bmob =require('../../utils/bmob.js');
Page({
data:{
},
queryall:function(){
var Test = Bmob.Object.extend("test");
//test数据表
var query = new Bmob.Query(Test);//查询所有数据
query.find({
success:function(results){
console.log("共查询到"+results.length+"条记录");//循环处理查询到的数据
for(var i=0; i<results.length;i ++){
var object =results[i];
console.log(object.id +'-' + object.get('title') +'-'+object.get('content'));
}
},
error:function(error){
console.log("查询失败:"+error.code +""+error.message);
}
},
)}
})
8.2.7 条件查询
Bmob中提供的查询方法主要有:等于(equalTo)、不等于(notEqualTo)、小于(lessThan)、小于等于(lessThanOrEqualTo)、大于(greaterThan)、大于等于(greaterThanOrEqualTo)等
.wxml
<button type="primary" bindtap='wherequery'>条件查询</button>
.js
var Bmob =require('../../utils/bmob.js');
Page({
data:{
},
//条件查询
wherequery:function(){
var Test = Bmob.Object.extend("test"); var query =new Bmob.Query(Test);
query.equalTo("title","WXML"); //查询 title等于“WXML”的记录//查询所有数据
query.find({
success:function(results){
console.log("共查询到"+results.length+"条记录");//循环处理查询到的数据
for(var i=0; i < results.length;i ++){
var object =results[i];
console.log(object.id +'- '+ object.get('title'));
}
},
error:function(error){
console.log("查询失败:"+error.code +"" + error.message);
}
});
}
})
8.2.8 分页查询
照指定条数为一页来显示,这时可以使用limit方法限制查询结果的数据条数来进行分页。默认情况下,limit的值为10,最大有效设置值为1000。
query.limit(10);
同时,skip方法可以做到跳过查询的前多少条数据来实现分页查询的功能。skip的默认值为10
query.skip(10);
8.3 上传图片
8.3.1 上传一张图片并显示
Bmob提供了文件后端保存功能。利用这一功能,我们可以把本地文件上传到Bmob后台,并按上传日期为文件命名
.wxml
<button type="primary" bind:tap="upimage">上传一张图片</button>
<image src="{{url}}"/>
.js
上传多张图片并显示
Bmob 支持一次上传多张图片,并将图片保存到素材库中。
//wxml
<button type="primary" bind:tap="uppic">上传多张图片</button>
<block wx:for="{{list}}" wx:key="this">
<image src="{{item.url}}" />
</block>
//js
uppic:function(){
var that = this;
wx.chooseImage({
count:9,
sizeType:['compressed'],
sourceType:['album','camera'],
success:function(res){
wx.showNavigationBarLoading()
that.setData({
loading:false
})
var urlArr = new Array();
var tempFilePaths = res.tempFilePaths;
console.log(tempFilePaths)
var imgLength = tempFilePaths.length;
if (imgLength >0){
var newDate = new Date();
var newDateStr = newDate.toLocaleDateString();
var j=0;
for(var i=0;i<imgLength;i++){
var tempFilePath = [tempFilePaths[i]];
var extension = /\.([^.]*)$/.exec(tempFilePath[0]);
if(extension){
extension = extension[1].toLowerCase();
}
var name = newDateStr +"." +extension;
var file = new Bmob.File(name,tempFilePath);
file.save().then(function(res){
wx.hideNavigationBarLoading()
var url = res.url();
console.log("第" +i+"张Url" + url);
that.setData({
url:url
})
urlArr.push({"url" :url});
that.setData({
list:urlArr
})
console.log(list)
j ++;
console.log(j,imgLength);
})
}
}
}
})
}