• 微信小程序连接数据库与WXS的使用


     

    🎉🎉欢迎来到我的CSDN主页!🎉🎉

    🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚

    🌟推荐给大家我的专栏《微信小程序开发实战》。🎯🎯

    👉点击这里,就可以查看我的主页啦!👇👇

    Java方文山的个人主页

    🎁如果感觉还不错的话请给我点赞吧!🎁🎁

    💖期待你的加入,一起学习,一起进步!💖💖

    请添加图片描述

    前言

          很多同志们再写小程序的过程中,不知道该怎么发起HTTP请求到后端,在Web环境中发起HTTPS请求是很常见的,但是微信小程序是腾讯内部的产品,不能直接打开一个外部的链接。例如,在微信小程序中不能直接打开www.taobao.com网站,但是,在小程序开发的时候,如果需要请求一个网站的内容或者服务,如何实现?虽然微信小程序里面不能直接访问外部链接,但是腾讯为开发者封装好了一个wx.request(object)的API。

    一、搭建数据库连接

    1.接口地址URL

    其他的东西还是基本与我们发送ajax请求一致的。

     为了后期方便维护,我们先将所有的后端接口通过一个文件来保存,在根目录下新建config文件夹随后建立api.js文件。

    1. // 以下是业务服务器API地址
    2. // 本机开发API地址
    3. var WxApiRoot = 'http://localhost:8080/wx/';
    4. // 测试环境部署api地址
    5. // var WxApiRoot = 'http://192.168.0.101:8070/demo/wx/';
    6. // 线上平台api地址
    7. //var WxApiRoot = 'https://www.oa-mini.com/demo/wx/';
    8. module.exports = {
    9. IndexUrl: WxApiRoot + 'home/index', //首页数据接口
    10. SwiperImgs: WxApiRoot+'swiperImgs', //轮播图
    11. MettingInfos: WxApiRoot+'meeting/list', //会议信息
    12. };

    先定义本机开发的API地址,具体的请求在下面定义方便管理。

    2.请求方式的封装

    1. loadMeetingInfos(){
    2. let that=this;
    3. wx.request({
    4. url: api.IndexUrl,
    5. dataType: 'json',
    6. success(res) {
    7. console.log(res)
    8. that.setData({
    9. lists:res.data.data.infoList
    10. })
    11. }
    12. })
    13. }

    以上是我们发送请求的代码,虽然比较简短但还是要在需要的地方进行编写,简单的代码反复性高那我们就可以对它进行封装。

    在/utils/util.js中添加下列代码

    1. /**
    2. * 封装微信的request请求
    3. */
    4. function request(url, data = {}, method = "GET") {
    5. return new Promise(function (resolve, reject) {
    6. wx.request({
    7. url: url,
    8. data: data,
    9. method: method,
    10. header: {
    11. 'Content-Type': 'application/json',
    12. },
    13. success: function (res) {
    14. if (res.statusCode == 200) {
    15. resolve(res.data);//会把进行中改变成已成功
    16. } else {
    17. reject(res.errMsg);//会把进行中改变成已失败
    18. }
    19. },
    20. fail: function (err) {
    21. reject(err)
    22. }
    23. })
    24. });
    25. }

    注意在module.exports中导出和需要使用的页面js中使用实const util = require("../../utils/util")

    1. //首页会议信息的ajax
    2. loadMeetingInfos() {
    3. let that = this;
    4. util.request(api.IndexUrl).then(res => {
    5. this.setData({
    6. lists: res.data.infoList
    7. })
    8. })
    9. }

    是不是看起来又少了很多代码

    3.后端代码

    后端SpringBoot搭建的,引入了mysql、mybatisplus、swagger、lombok等依赖。

    数据库表结构:

    部分代码:

    1. @RestController
    2. @RequestMapping("/wx/home")
    3. public class WxHomeController {
    4. @Autowired
    5. private InfoMapper infoMapper;
    6. @RequestMapping("/index")
    7. public Object index(Info info) {
    8. List infoList = infoMapper.list(info);
    9. Map data = new HashMap();
    10. data.put("infoList",infoList);
    11. return ResponseUtil.ok(data);
    12. }
    13. }

    这里我相信大家都懂不必多说!!!!!

     4.前端代码

    wxml

    1. <view>
    2. <swiper autoplay="true" indicator-dots="true">
    3. <block wx:for="{{imgSrcs}}" wx:key="text">
    4. <swiper-item>
    5. <view>
    6. <image src="{{item.img}}" class="swiper-item" />
    7. view>
    8. swiper-item>
    9. block>
    10. swiper>
    11. view>
    12. <view class="mobi-title">
    13. <text class="mobi-icon">text>
    14. <text class="mobi-text">会议信息text>
    15. view>
    16. <block wx:for-items="{{lists}}" wx:for-item="item" wx:key="item.id">
    17. <view class="list" data-id="{{item.id}}">
    18. <view class="list-img">
    19. <image class="video-img" mode="scaleToFill" src="{{item.image !=null? item.image : '/static/persons/6.png'}}">image>
    20. view>
    21. <view class="list-detail">
    22. <view class="list-title"><text>{{item.title}}text>view>
    23. <view class="list-tag">
    24. <view class="state">{{item.state}}view>
    25. <view class="join"><text class="list-num">{{item.num}}text>人报名view>
    26. view>
    27. <view class="list-info"><text>{{item.location}}text>|<text>{{item.starttime}}text>view>
    28. view>
    29. view>
    30. block>
    31. <view class="section">
    32. <text>到底啦text>
    33. view>

    wxss

    1. /**index.wxss**/
    2. .section{
    3. color: #aaa;
    4. display: flex;
    5. justify-content: center;
    6. }
    7. .list-info {
    8. color: #aaa;
    9. }
    10. .list-num {
    11. color: #e40909;
    12. font-weight: 700;
    13. }
    14. .join {
    15. padding: 0px 0px 0px 10px;
    16. color: #aaa;
    17. }
    18. .state {
    19. margin: 0px 6px 0px 6px;
    20. border: 1px solid #93b9ff;
    21. color: #93b9ff;
    22. }
    23. .list-tag {
    24. padding: 3px 0px 10px 0px;
    25. display: flex;
    26. align-items: center;
    27. }
    28. .list-title {
    29. display: flex;
    30. justify-content: space-between;
    31. font-size: 11pt;
    32. color: #333;
    33. font-weight: bold;
    34. }
    35. .list-detail {
    36. display: flex;
    37. flex-direction: column;
    38. margin: 0px 0px 0px 15px;
    39. }
    40. .video-img {
    41. width: 80px;
    42. height: 80px;
    43. }
    44. .list {
    45. display: flex;
    46. flex-direction: row;
    47. border-bottom: 1px solid #6b6e74;
    48. padding: 10px;
    49. }
    50. .mobi-text {
    51. font-weight: 700;
    52. padding: 15px;
    53. }
    54. .mobi-icon {
    55. border-left: 5px solid #e40909;
    56. }
    57. .mobi-title {
    58. background-color: rgba(158, 158, 142, 0.678);
    59. margin: 10px 0px 10px 0px;
    60. }
    61. .swiper-item {
    62. height: 300rpx;
    63. width: 100%;
    64. border-radius: 10rpx;
    65. }
    66. .userinfo {
    67. display: flex;
    68. flex-direction: column;
    69. align-items: center;
    70. color: #aaa;
    71. }
    72. .userinfo-avatar {
    73. overflow: hidden;
    74. width: 128rpx;
    75. height: 128rpx;
    76. margin: 20rpx;
    77. border-radius: 50%;
    78. }
    79. .usermotto {
    80. margin-top: 200px;
    81. }

    效果展示:

     其实我们这个页面还存在着一些的问题,比如说这个会议的状态不应该显示数字,而是数字对应的状态是什么?参会的人数有多少?会议的时间显示等问题...下面就用wxs带大家解决该问题。

    二、WXS的使用

    WXS(WeChat Mini Program Storage)是微信小程序提供的本地存储方案,用于在小程序中进行数据的存储和管理。相比远程数据库,WXS更适合于小规模、简单的数据存储需求。

    1.wxs 文件

    在微信开发者工具里面,右键可以直接创建 .wxs 文件,在其中直接编写 WXS 脚本。

    1. // /pages/comm.wxs
    2. var foo = "'hello world' from comm.wxs";
    3. var bar = function(d) {
    4. return d;
    5. }
    6. module.exports = {
    7. foo: foo,
    8. bar: bar
    9. };
    • exports: 通过该属性,可以对外共享本模块的私有变量与函数。

    在需要使用的页面进行引用即可

    1. <wxs src="./../tools.wxs" module="tools" />
    2. <view> {{tools.msg}} view>
    3. <view> {{tools.bar(tools.FOO)}} view>

    页面输出:

    1. some msg
    2. 'hello world' from tools.wxs

    学会了基本的wxs的使用,我们在刚刚的页面中进行操作一手。

    2.解决数据显示数字问题

    1. function getState(state){
    2. // 状态:0取消会议1待审核2驳回3待开4进行中5开启投票6结束会议,默认值为1
    3. if(state == 0 ){
    4. return '取消会议';
    5. }else if(state == 1 ){
    6. return '待审核';
    7. }else if(state == 2 ){
    8. return '驳回';
    9. }else if(state == 3 ){
    10. return '待开';
    11. }else if(state == 4 ){
    12. return '进行中';
    13. }else if(state == 5 ){
    14. return '开启投票';
    15. }else if(state == 6 ){
    16. return '结束会议';
    17. }
    18. return '其它';
    19. }

     3.解决统计人数问题

    1. function formatNumber(liexize,canyuze,zhuchiren) {
    2. var person = liexize+","+canyuze+","+zhuchiren;
    3. return person.split(',').length;
    4. }

    4.解决时间进制问题

    1. function formatDate(ts, option) {
    2. var date = getDate(ts)
    3. var year = date.getFullYear()
    4. var month = date.getMonth() + 1
    5. var day = date.getDate()
    6. var week = date.getDay()
    7. var hour = date.getHours()
    8. var minute = date.getMinutes()
    9. var second = date.getSeconds()
    10. //获取 年月日
    11. if (option == 'YY-MM-DD') return [year, month, day].map(formatNumber).join('-')
    12. //获取 年月
    13. if (option == 'YY-MM') return [year, month].map(formatNumber).join('-')
    14. //获取 年
    15. if (option == 'YY') return [year].map(formatNumber).toString()
    16. //获取 月
    17. if (option == 'MM') return [mont].map(formatNumber).toString()
    18. //获取 日
    19. if (option == 'DD') return [day].map(formatNumber).toString()
    20. //获取 年月日 周一 至 周日
    21. if (option == 'YY-MM-DD Week') return [year, month, day].map(formatNumber).join('-') + ' ' + getWeek(week)
    22. //获取 月日 周一 至 周日
    23. if (option == 'MM-DD Week') return [month, day].map(formatNumber).join('-') + ' ' + getWeek(week)
    24. //获取 周一 至 周日
    25. if (option == 'Week') return getWeek(week)
    26. //获取 时分秒
    27. if (option == 'hh-mm-ss') return [hour, minute, second].map(formatNumber).join(':')
    28. //获取 时分
    29. if (option == 'hh-mm') return [hour, minute].map(formatNumber).join(':')
    30. //获取 分秒
    31. if (option == 'mm-dd') return [minute, second].map(formatNumber).join(':')
    32. //获取 时
    33. if (option == 'hh') return [hour].map(formatNumber).toString()
    34. //获取 分
    35. if (option == 'mm') return [minute].map(formatNumber).toString()
    36. //获取 秒
    37. if (option == 'ss') return [second].map(formatNumber).toString()
    38. //默认 时分秒 年月日
    39. return [year, month, day].map(formatNumber).join('-') + ' ' + [hour, minute, second].map(formatNumber).join(':')
    40. }

     效果展示

     请添加图片描述

    到这里我的分享就结束了,欢迎到评论区探讨交流!!

    💖如果觉得有用的话还请点个赞吧 💖

  • 相关阅读:
    Rust实战系列-Rust介绍
    使用 Hibernate Envers 进行实体审计
    ARM day4
    对IP协议概念以及IP地址的概念进行简单整理
    pyltp postagger 运行过程中报错Process finished with exit code -1073740791 (0xC0000409)
    动态内存管理
    如何免费获取基于公网 IP 的 SSL 证书 (无需域名)
    ElementUI浅尝辄止29:Breadcrumb 面包屑
    “智”造未来,江西同为科技(TOWE)参展第四届广州“两交会”圆满落幕
    AcWing 477:神经网络 ← 拓扑排序+链式前向星
  • 原文地址:https://blog.csdn.net/weixin_74318097/article/details/133954598