jeecg-boot/jeecg-boot
zhangdaihao 365810d4e6 字典排序问题合并 2020-01-13 12:03:30 +08:00
..
db Jeecg-Boot 2.1.3 大屏版本发布 2019-12-25 15:50:15 +08:00
jeecg-boot-base-common 2.1.3 大屏版本发布 2019-12-25 13:14:08 +08:00
jeecg-boot-module-system 字典排序问题合并 2020-01-13 12:03:30 +08:00
.gitattributes JeecgBoot 2.1.1 版本发布 2019-10-19 15:44:19 +08:00
.gitignore 20191227 取消系统功能的权限注解 2019-12-27 15:00:22 +08:00
Dockerfile JeecgBoot 2.1.1 代码生成器AI版本发布 2019-10-18 18:37:41 +08:00
LICENSE LICENSE 2019-04-22 19:22:31 +08:00
README.md 2.1.3 大屏版本发布 2019-12-25 13:25:10 +08:00
pom.xml 2.1.3 大屏版本发布 2019-12-25 13:14:08 +08:00

README.md

Jeecg-Boot 快速开发平台

当前最新版本: 2.1.3发布日期20191226

后端技术架构

  • 基础框架Spring Boot 2.1.3.RELEASE

  • 持久层框架Mybatis-plus_3.1.2

  • 安全框架Apache Shiro 1.4.0Jwt_3.7.0

  • 数据库连接池阿里巴巴Druid 1.1.10

  • 缓存框架redis

  • 日志打印logback

  • 其他fastjsonpoiSwagger-uiquartz, lombok简化代码等。

开发环境

  • 语言Java 8

  • IDE(JAVA) Eclipse安装lombok插件 或者 IDEA

  • 依赖管理Maven

  • 数据库MySQL5.0 & Oracle 11g

  • 缓存Redis

技术文档

专项文档

一、查询过滤器用法

QueryWrapper<?> queryWrapper = QueryGenerator.initQueryWrapper(?, req.getParameterMap());

代码示例:


	@GetMapping(value = "/list")
	public Result<IPage<JeecgDemo>> list(JeecgDemo jeecgDemo, @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, 
	                                     @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize,
			HttpServletRequest req) {
		Result<IPage<JeecgDemo>> result = new Result<IPage<JeecgDemo>>();
		
		//调用QueryGenerator的initQueryWrapper
		QueryWrapper<JeecgDemo> queryWrapper = QueryGenerator.initQueryWrapper(jeecgDemo, req.getParameterMap());
		
		Page<JeecgDemo> page = new Page<JeecgDemo>(pageNo, pageSize);
		IPage<JeecgDemo> pageList = jeecgDemoService.page(page, queryWrapper);
		result.setSuccess(true);
		result.setResult(pageList);
		return result;
	}

  • 查询规则 (本规则不适用于高级查询,高级查询有自己对应的查询类型可以选择 )
查询模式 用法 说明
模糊查询 支持左右模糊和全模糊 需要在查询输入框内前或后带*或是前后全部带*
取非查询 在查询输入框前面输入! 则查询该字段不等于输入值的数据(数值类型不支持此种查询,可以将数值字段定义为字符串类型的)
> >= < <= 同取非查询 在输入框前面输入对应特殊字符即表示走对应规则查询
in查询 若传入的数据带,(逗号) 则表示该查询为in查询
多选字段模糊查询 上述4 有一个特例,若某一查询字段前后都带逗号 则会将其视为走这种查询方式 ,该查询方式是将查询条件以逗号分割再遍历数组 将每个元素作like查询 用or拼接,例如 现在name传入值 ,a,b,c, 那么结果sql就是 name like '%a%' or name like '%b%' or name like '%c%'

二、AutoPoi(EXCEL工具类-EasyPOI衍变升级重构版本

在线文档

三、代码生成器

功能说明: 一键生成的代码包括controller、service、dao、mapper、entity、vue

四、编码排重使用示例

重复校验效果: 输入图片说明

1.引入排重接口,代码如下:

import { duplicateCheck } from '@/api/api'

2.找到编码必填校验规则的前端代码,代码如下:

<a-input placeholder="请输入编码" v-decorator="['code', validatorRules.code ]"/>

code: {
            rules: [
              { required: true, message: '请输入编码!' },
              {validator: this.validateCode}
            ]
          },

3.找到rules里validator对应的方法在哪里,然后使用第一步中引入的排重校验接口.
以用户online表单编码为示例,其中四个必传的参数有:

  {tableName:表名,fieldName:字段名,fieldVal:字段值,dataId:表的主键},

具体使用代码如下:

    validateCode(rule, value, callback){
        let pattern = /^[a-z|A-Z][a-z|A-Z|\d|_|-]{0,}$/;
        if(!pattern.test(value)){
          callback('编码必须以字母开头,可包含数字、下划线、横杠');
        } else {
          var params = {
            tableName: "onl_cgreport_head",
            fieldName: "code",
            fieldVal: value,
            dataId: this.model.id
          };
          duplicateCheck(params).then((res)=>{
            if(res.success){
             callback();
            }else{
              callback(res.message);
            }
          })
        }
      },