Android开发经验谈Android开发Bmob后端云-让移动开发更简单

如何开发小程序中的朋友圈功能

2018-06-06  本文已影响36人  大王12

一、开发功能分析:
1.各条内容以列表展示
2.点击,可展示内容详情
3.评论功能


1.png
2.png
3.png

二、数据库建立
这里列表与详细,我们用一个表来实现,评论用第二个表。总计2个表
1.post 表
我们可以直接这样导入一个JSON,但由于首页的资讯这样操作,导致数据都一模一样,这次我们使用云函数定时采集数据到数据库。
2.采集数据
数据结构地址:

var url = 'https://apiquan.ithome.com/api/post?categoryid=0&type=0&orderTime=1526981875455&visistCount=&pageLength='

如果手动导入可以导入此数据结构:

[
    {
        "id":266716,
        "t":"普通联通卡可以转米粉卡吗?",
        "c":"[杂谈]",
        "cn":"畅谈",
        "uid":100058,
        "un":"中国火箭军",
        "rn":"诺基亚 Lumia 930",
        "pt":"/Date(1527057744773)/",
        "rt":"/Date(1527060538403)/",
        "vc":0,
        "rc":17,
        "IC":false,
        "IH":false,
        "ot":"/Date(-62135596800000)/"
    }
 ]

云函数获取网址数据代码:

function onRequest(request, response, modules) {
var http = modules.oHttp;
var url = 'https://apiquan.ithome.com/api/post?categoryid=0&type=0&orderTime=1526981875455&visistCount=&pageLength='
    http(url, function(error, res, body) {
        response.end(body);
    });
}

点击测试看结果:


4.png

这样就可以拿到目标网址数据.
如何插入到数据库,看下面代码:

db.insert({
  "table":"XXX",             //表名
  "data":{"a":"XXXX","b":"XXXX"}            //需要更新的数据,格式为JSON
},function(err,data){         //回调函数
});

上面是插入单行数据,如果批量插入,可以使用下面代码:

function onRequest(request, response, modules) {
var http = modules.oHttp;
   var db = modules.oData;
    var url = 'https://apiquan.ithome.com/api/post?categoryid=0&type=0&orderTime=1526981875455&visistCount=&pageLength='
    http(url, function(error, res, body) {
        
        //结果转为对象类型
        var results =JSON.parse(body);
        
        var arr = [];
        //循环更新数据
        for (var i in results) {
            newdata = {
                "method": "post",
                "path": "/1/classes/post",
                "body":results[i]
            };
            arr.push(newdata)
        }
        
        //获取数组对象
        var bat = modules.oBatch;
        //批量操作
        bat.exec({
            "data": {
                "requests": arr
            }
        }, function (err, data) {
            //回调函数
            response.end(data);
            return;
        });
        
                response.end(JSON.stringify(results.length));
            });
    }

点击测试,效果下如图:


5.png

3.定时任务
当然你也可以设置个定时任务,我这里设置结果:


6.png

当然你也可以设置每小时,每天,每分钟,每秒,每隔5分钟等等,规则可以自己定义,具体请看云函数文档,文档地址:
定时任务云函数文档

这里我们把朋友圈的数据表建立,并采集了相关数据,下次我们在讲修改mpvue小程序代码。

上一篇 下一篇

猜你喜欢

热点阅读