比目鱼后端简介
一个完整的小程序系统,不但需要前端的展现,而且需要后端服务器的支撑,以提供数据服务。也就是说,开发一个真正完整的小程序应用,需要前后端的相互配合。
1.注册Bmob账号
输入网址(https://www.bmobapp.com/)点击注册按钮
扫码关注公众号
注册新账号
2.创建应用
3.获取微信小程序服务器域名和“应用密钥”
4.下载安装BmobSDK
首先,登录https://github.com/bmob/bmob-WeApp-sdk下载Bmod SDK,解压下载后的SDK,
bmob-WeApp-sdk下载Bmod SDK,解压下载后的SDK,把bmob. js和underscore. js文件放到相应的位置。例如,要放到小程序的utils目录中
app.js中加入以下代码:
var Bmob=require('./utils/bmob.js');
Bmob.initialize("8f7fd0cfa1cdbac714d8e5c00f76dbf9","44573bef4fa6dccd494996f8e102b2bd")
数据的增、删、改、查
1.创建表及字段
为了便于在Bmob中实现数据的增加、删除、修改、查询,我们在新建的应用中新增“test”表,并在表中添加id(编号)、title(标题)、content(内容)、image(图像)字段。
创建表如下:
创建列如下:
2.添加一条记录
代码如下:
//index.wxml
<button type="primary" bindtap='add'>添加记录</button>
//index.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('添加失败');
}
});
},
})
运行结果如下:
3.获取一条记录
代码如下:
//index.wxml
<button type="primary" bindtap='query'>获取记录</button>
//index.js
var Bmob = require("../../utils/bmob");
Page({
query:function(){
var Test=Bmob.Object.extend("test");
var query =new Bmob.Query(Test);
query.get("93cf7dfd11",{
success:function(result){
console.log("该记录标题为"+result.get("title"));
console.log("该记录的内容为"+result.get("content"));
},
error:function(result,error){
console.log("查询失败")
}
})
}
})
运行结果如下:
4.修改一条记录
代码如下:
//index.wxml
<button type="primary" bindtap='modi'>修改记录</button>
//index.js
const { Bmob } = require("../../utils/bmob")
Page({
modi:function(){
var Test=Bmob.Object.extend("test");
var query=new Bmob.Query(Test);
query.get("df23fed87c",{
success:function(result){
result.set('title',"WXSS");
result.set('content',"WenXin Style Sheets");
result.save();
console.log("修改成功")
console.log(("该记录标题修改为"+result.get("title")));
console.log(("该记录内容修改为"+result.get("content")));
},
error:function(Object,error){
console.log("修改失败")
}
})
}
})
运行结果如下:
5.删除一条记录
代码如下:
//index.wxml
<button type="primary" bindtap='del'>删除一行记录</button>
//index.js
const { Bmob } = require("../../utils/bmob")
Page({
del:function(){
var Test =Bmob.Object.extend("test");
var query=new Bmob.Query(Test);
query.get("62012fd854",{
success:function(object){
object.destroy({
success:function(deleteObject){
console.log("删除记录成功");
},
error:function(object,error){
console.log("删除记录失败");
}
});
},
error:function(object,error){
console.log("修改失败")
}
})
}
})
运行结果如下:
6.查询所有数据
代码如下:
//index.wxml
<button type="primary" bindtap='queryall'>获取所有数据记录</button>
//index.js
const { Bmob } = require("../../utils/bmob")
Page({
queryall:function(){
var Test=Bmob.Object.extend("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);
}
})
}
})
运行结果如下:
7.条件查询
代码如下:
//index.wxml
<button type="primary" bindtap='wherequery'>条件查询</button>
//index.js
const { Bmob } = require("../../utils/bmob")
Page({
wherequery:function(){
var Test=Bmob.Object.extend("test");
var query=new Bmob.Query(Test);
query.equalTo("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.分页查询
照指定条数为一页来显示,这时可以使用limit方法限制查询结果的数据条数来进行分页。默认情况下,limit的值为10,最大有效设置值为1000。
query.limit(10);
同时,skip方法可以做到跳过查询的前多少条数据来实现分页查询的功能。skip的默认值为10。
query.skip(10);
上传图片
1.上传一张图片并显示
代码如下:
//index.wxml
<button type="primary" bindtap='upimage'>上传一张图片</button>
<image src ="{{url}}"> </image>
//index.js
var Bmob =require('../../utils/bmob.js');
Page({
data:{
url:""
},
//上传一张图片
upimage:function(){
var that =this;
wx.chooseImage({
count:1,//默认值为9
sizeType: ['compressed'],//可以指定是原图还是压缩图,默认二者都有
sourceType: ['album','camera'],//可以指定来源是相册还是相机,默认二者都有
success:function(res){
var tempFilePaths = res.tempFilePaths;
if(tempFilePaths.length >0){
var newDate = new Date();
var newDateStr =newDate.toLocaleDateString();//获取当前日期为文件主名
var tempFilePath =[tempFilePaths[0]];
var extension = /\.([^.]*)$/.exec( tempFilePath[0]);//获取文件扩展名
if(extension){
extension =extension[1].toLowerCase();
}
var name = newDateStr + "." + extension;//上传的图片的别名
console.log("嘟嘟嘟"+name);
console.log("嘟嘟嘟"+tempFilePaths);
var file = new Bmob.File(name,tempFilePaths);
file.save().then(
function(res){
console.log("嘟嘟嘟"+res.name());
console.log("嘟嘟嘟"+res.url());
var url=res.url();
that.setData({
url:url
})
},
function(error){
console.log(error);
}
)
}
}
})
},
})
运行结果如下:
2.上传多张图片并显示
代码如下:
//index.wxml
<button type="primary" bindtap="uppic">上传多张照片</button>
<block wx:for="{{list}}" wx:key="this">
<image src="{{url}}"></image>
</block>
//index.js
const { File } = require('../../utils/bmob.js');
var Bmob =require('../../utils/bmob.js');
Page({
data:{
},
//上传多张照片
uppic:function(){
var that = this;
wx.chooseImage({
count:9,//默认值为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);
if(imgLength==j){
console.log(imgLength,urlArr);
//如果担心就可以去掉这几行注释
showPic(urlArr,that)//显示图片
}
},function(error){
console.log(error);
})
}
}
}
});
}
})
运行结果如下: