【完结15章】深入学习小程序框架底层原理,培养双线程思维
给大家分享一套课程——《深入学习小程序框架底层原理,培养双线程思维》,课程共15章,附源码下载。
微信小程序在产品功能设计上给用户更多控制力。在微信小程序的设置页,为用户提供了数据权限开关,一旦用户授权之后又关闭,微信小程序再次使用该用户数据时需要重新获得授权,为用户提供更方便的数据控制权。用户在微信小程序的资料页还可以看到隐私数据保护的提示以及投诉入口。 微信小程序在收集、获取用户数据上,微信小程序坚持“必要+合理”原则。必要是指只有在微信小程序的具体业务中,确实有场景需要获取用户数据的情况下,开发者才能去获取用户的同意授权;合理是指开发者获取数据的范围不应该超出具体场景所需要的数据范围。例如一个提供外卖服务的微信小程序,可能需要获得电话、地址等数据,但没有必要获取性别、年龄等数据,否则平台会认为微信小程序收集用户数据的行为违反了“必要并且合理”的原则,会对这类微信小程序进行处理。
微信小程序的框架分为两层,分别是视图层和逻辑层,框架的视图层由WXML与WXSS编写,由组件来进行展示,负责小程序的外貌;逻辑层又称为AppService,由js编写,负责小程序的行为动作
除了微信小程序自带的视图层和逻辑层,市场上也出现了一些第三方的主流框架,以下是其中几种比较常见的:
- mpvue:一个使用 Vue.js 开发小程序的框架,支持 Vue.js 的大部分特性和语法,具有更好的组件化和模块化能力。
- Taro:一个使用 React.js 开发小程序的框架,支持多端开发,即可以同时开发小程序、H5、React Native 等多个平台。
- uni-app:一个使用 Vue.js 开发跨平台应用的框架,支持多端开发,即可以同时开发小程序、H5、App 等多个平台。
- WePY:一个类似于 Vue.js 的组件化开发框架,但是使用的是类似于微信小程序的语法和 API,具有更好的性能和更快的开发速度。
- Nest.js:一个使用 TypeScript 开发 Node.js 应用的框架,支持微信小程序后端的开发,具有更好的可维护性和扩展性。
这些主流框架各有优缺点,可以根据具体项目需求和开发者技术背景选择合适的框架进行开发。
引入GraceJSONResult,结合枚举对接口返回数据进行优雅的封装(请参考源码) package com.imooc.grace.result;
import java.util.Map;
/**
- 自定义响应数据类型枚举升级版本 *
- @Title: IMOOCJSONResult.java
- @Package com.imooc.utils
- @Description: 自定义响应数据结构
- 本类可提供给 H5/ios/安卓/公众号/小程序 使用
- 前端接受此类数据(json object)后,可自行根据业务去实现相关功能 *
- @Copyright: Copyright (c) 2020
- @Company: www.imooc.com
- @author 慕课网 - 风间影月
@version V2.0 */ public class GraceJSONResult {
// 响应业务状态码 private Integer status;
// 响应消息 private String msg;
// 是否成功 private Boolean success;
// 响应数据,可以是Object,也可以是List或Map等 private Object data;
/**
- 成功返回,带有数据的,直接往OK方法丢data数据即可
- @param data
- @return / public static GraceJSONResult ok(Object data) { return new GraceJSONResult(data); } /*
- 成功返回,不带有数据的,直接调用ok方法,data无须传入(其实就是null)
- @return */ public static GraceJSONResult ok() { return new GraceJSONResult(ResponseStatusEnum.SUCCESS); } public GraceJSONResult(Object data) { this.status = ResponseStatusEnum.SUCCESS.status(); this.msg = ResponseStatusEnum.SUCCESS.msg(); this.success = ResponseStatusEnum.SUCCESS.success(); this.data = data; }
/**
* 错误返回,直接调用error方法即可,当然也可以在ResponseStatusEnum中自定义错误后再返回也都可以
* <a href="/user/return" title="@return">@return</a>
*/
public static GraceJSONResult error() {
return new GraceJSONResult(ResponseStatusEnum.FAILED);
}
/**
* 错误返回,map中包含了多条错误信息,可以用于表单验证,把错误统一的全部返回出去
* @param map
* <a href="/user/return" title="@return">@return</a>
*/
public static GraceJSONResult errorMap(Map map) {
return new GraceJSONResult(ResponseStatusEnum.FAILED, map);
}
/**
* 错误返回,直接返回错误的消息
* @param msg
* <a href="/user/return" title="@return">@return</a>
*/
public static GraceJSONResult errorMsg(String msg) {
return new GraceJSONResult(ResponseStatusEnum.FAILED, msg);
}
/**
* 错误返回,token异常,一些通用的可以在这里统一定义
* <a href="/user/return" title="@return">@return</a>
*/
public static GraceJSONResult errorTicket() {
return new GraceJSONResult(ResponseStatusEnum.TICKET_INVALID);
}
/**
* 自定义错误范围,需要传入一个自定义的枚举,可以到[ResponseStatusEnum.java[中自定义后再传入
* @param responseStatus
* <a href="/user/return" title="@return">@return</a>
*/
public static GraceJSONResult errorCustom(ResponseStatusEnum responseStatus) {
return new GraceJSONResult(responseStatus);
}
public static GraceJSONResult exception(ResponseStatusEnum responseStatus) {
return new GraceJSONResult(responseStatus);
}
public GraceJSONResult(ResponseStatusEnum responseStatus) {
this.status = responseStatus.status();
this.msg = responseStatus.msg();
this.success = responseStatus.success();
}
public GraceJSONResult(ResponseStatusEnum responseStatus, Object data) {
this.status = responseStatus.status();
this.msg = responseStatus.msg();
this.success = responseStatus.success();
this.data = data;
}
public GraceJSONResult(ResponseStatusEnum responseStatus, String msg) {
this.status = responseStatus.status();
this.msg = msg;
this.success = responseStatus.success();
}
public GraceJSONResult() {
}
public Integer getStatus() {
return status;
}
public void setStatus(Integer status) {
this.status = status;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public Object getData() {
return data;
}
public void setData(Object data) {
this.data = data;
}
public Boolean getSuccess() {
return success;
}
public void setSuccess(Boolean success) {
this.success = success;
}
}
在common工程中引入坐标:
日志级别 logging: level: root: info
多环境配置 spring: profiles: active: dev
在model工程中引入数据层坐标:
yml中引入数据库配置: spring: datasource: # 数据源的相关配置 type: com.zaxxer.hikari.HikariDataSource # 数据源的类型,可以更改为其他的数据源配置,比如druid driver-class-name: com.mysql.jdbc.Driver # mysql/MariaDB 的数据库驱动类名称 url: jdbc:mysql://192.168.1.6:3306/imooc-red-book?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true username: root password: root hikari: connection-timeout: 30000 # 等待连接池分配连接的最大时间(毫秒),超过这个时长还没有可用的连接,则会抛出SQLException minimum-idle: 5 # 最小连接数 maximum-pool-size: 20 # 最大连接数 auto-commit: true # 自动提交 idle-timeout: 600000 # 连接超时的最大时长(毫秒),超时则会被释放(retired) pool-name: DataSourceHikariCP # 连接池的名字 max-lifetime: 18000000 # 连接池的最大生命时长(毫秒),超时则会被释放(retired) connection-test-query: SELECT 1
整合mybatis
mybatis: type-aliases-package: com.imooc.pojo # 所有pojo类所在的包路径 mapper-locations: classpath:mapper/*.xml # mapper映射文件
通用mapper工具的配置
mapper: mappers: com.imooc.my.mapper.MyMapper # 配置MyMapper,包含了一些封装好的CRUD方法 not-empty: false # 在进行数据库操作的时候,username != null 是否会追加 username != '' identity: MYSQL
分页插件助手的配置
pagehelper: helper-dialect: MYSQL support-methods-arguments: true
有疑问加站长微信联系(非本文作者)
