【微信小程序】第八章

8.1 比目后端云简介

一个完整的小程序系统,不但需要前端的展现,而且需要后端服务器的支撑,以提供数据服务。也就是说,开发一个真正完整的小程序应用,需要前后端的相互配合。小程序与远程服务器之间通过HTTPS传输协议进行数据交换

 

除了自己搭建服务端以外,还可以利用一些网络公司提供的云服务来进行小程序后端的相应开发。本章主要讲解利用比目网络科技有限公司提供的Bmob后端云进行小程序后端开发。
Bmob后端云专注于为移动应用提供一整套后端云服务,能帮助开发者免去几乎所有服务器端的编码工作,大幅度降低开发成本和开发时间。
Bmob提供了小程序软件开发工具包(Software Development Kit, SDK),让用户拥有强大的后端服务。嵌入Bmob小程序SDK后,开发工程师可以更加专注于编写前端代码和优化良好的用户体验,而不必担心后端的基础设施。
Bmob提供了成熟的WebSocket信道服务,降低了开发者使用WebSocket通信的门槛。同时也满足了小程序需要HTTPS与服务端通信的需求。

Bmob还提供了短信验证功能,只需几行简单的代码,即可实现微信小程序的用户登录、富媒体文件上传、发送短信通知和微信支付等功能。

 8.1.1 注册Bmob账号

首先,登录Bmob 后端云官网地址(https://www.bmobapp.com),点击右上角的注册按钮,在跳转页面填入姓名、邮箱,并设置密码,确认后到邮箱激活Bmob账户,即可拥有Bmob账号。 

 8.1.2 创建应用

点击左边的“应用”点击顶部的“+创建应用”,填写创建信息 

 8.1.3 配置小程序密钥
8.1.4 获取小程序服务器域名和“应用密钥” 

单击进入后台,选择应用项目,单击“设置”→“应用密钥”选项,可以直接获取应用项目的Application ID和SecretKey(在小程序开发中需要使用) 。

 8.1.5 小程序中配置“安全域名”

登陆微信公众号平台,单击“设置”——“开发设置”选项,在服务器域名中输入获取的合法域名。

8.1.6 下载及安装Bmob SDK 

首先,登录https://github.com/bmob/bmob-WeApp-sdk下载Bmod SDK 

第一步,bmob-WeApp-sdk下载Bmod SDK,解压下载后的SDK,把bmob. js和underscore. js文件放到相应的位置。例如,要放到小程序的utils目录中,则在其他需要使用的页面添加以下代码:

var Bmob = require('../../utils/bmob');

 第二步,在小程序项目中的app. js中加入下面两行代码进行全局初始化:

 

8.2 数据的增,删,改,查 

 为了便于在Bmob中实现数据的增加、删除、修改、查询,我们在新建的应用中新增“test”表,并在表中添加id(编号)、title(标题)、content(内容)、image(图像)字段。

8.2.1 创建表及字段 

在“test”表中添加id、title、content、image列,Bmob提供Number、String、Boolean、Date、File、Geopoint、Array、Object、Pointer、Relation共10种字段类型 

 创建列:

8.2.2 添加一条记录 

 .wxml

<button type="primary" bind:tap="add">添加记录</button>

.js

var Bmob = require('../../utils/bmob');
Page({
  
  data: {
    url:""
  },
  add:function(){
    var Test = Bmob.Object.extend("test");
    var test = new Test(); //创建对象
    test.set("title","WXML"); //添加title字段内容
    test.set("content","Weixin Markup Langusge微信标记语言") //添加content字段记录
     
    //添加数据,第一个入口参数是null
    test.save(null,{
      success:function(result){
        console.log("添加成功,objectId:"+result.id);
      },
      error:function(result,error){
        console.log('添加失败');
      }
    });
  }
})

效果如图: 

8.2.3 获取一条记录

 .wxml

<button type="primary" bind:tap="query">获取记录</button>

.js

query:function(){
    var Test = Bmob.Object.extend("test");
    var query = new Bmob.Query(Test);
    query.get("4f159bc408",{
      success:function(result){
        console.log("改记录标题为"+result.get("title"));
        console.log("该记录的内容为"+result.get("content"));
      },
      error:function(result,error){
        console.log("查询失败");
      }
    });
  }

效果如图:

 8.2.4 修改一条记录

.wxml

<button type="primary" bind:tap="modi">修改记录</button>

.js

modi:function(){
    var Test = Bmob.Object.extend("test");
    var query = new Bmob.Query(Test);
    query.get("4f159bc408",{
      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("修改失败")
      }
    });
  }

效果如图:

8.2.5 删除一条记录 

.wxml

<button type="primary" bind:tap="del">删除记录</button>

 .js

del:function(){
    var Test = Bmob.Object.extend("test");
    var query = new Bmob.Query(Test);
    query.get("4f159bc408",{
      success:function(object){
        object.destroy({
          success:function(deleteObject){
            console.log("删除记录成功");
          },
          error:function(object,errpr){
            console.log("删除记录失败");
          }
        });
      },
      error:function(object,error){
        console.log("删除失败");
      }
    });
  }

效果如图:

8.2.6 查询所有数据 

.wxml

<button type="primary" bind:tap="queryall">获取所有数据记录</button>

 .js

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 条件查询

 .wxml

<button type="primary" bindtap='wherequery'>条件查询</button>

.js

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.2 上传图片

8.3.1 上传一张图片并显示 

 Bmob提供了文件后端保存功能。利用这一功能,我们可以把本地文件上传到Bmob后台,并按上传日期为文件命名。

.wxml

<button type="primary" bindtap='upimage'>上传一张图片</button>
<image src ="{{url}}"> </image>

.js

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);
              }
            )
          }
        }
      })
    }

效果如图:

8.3.2 上传多张图片并显示 

 .wxml

<button type="primary" bindtap="uppic">上传多张照片</button>
<block wx:for="{{list}}" wx:key="this">
  <image src="{{url}}"></image>
</block>

.js

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);
          })
        }
      }
    }
    });
    }

效果如图:

  • 13
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值