# 模型
使用模型可以拆分控制器里方法的业务逻辑,减少代码的冗余度,提高代码的可读性。
通常我们把复杂的数据查询逻辑写到模型中,控制器只负责将模型得到的数据返回出去,不做过多的业务逻辑。
<br>
```
// 这是一个控制器,两个方法可调用同一个模型
// 其中M内传入的参数为model文件夹下的文件名
const Controller = require('think-js-lib').Controller
class HelloController extends Controller{
// 打印hello
sayHello(){
const result = this.M('screen').show('hello')
return this.showSuccess(result)
}
// 打印world
sayWorld(){
const result = this.M('screen').show('world')
return this.showSuccess(result)
}
}
module.exports = HelloController
```
<br>
```
// 这是一个模型,继承了Model
const Model = require('think-js-lib').Model
class ScreenModel extends Model{
// 打印
show(str){
return str
}
}
module.exports = ScreenModel
```
- 序言
- 新手指南
- 安装
- 开发规范
- 目录结构
- 配置
- 路由
- 路由定义
- 路由中间件
- 控制器
- 控制器定义
- 内置showSuccess方法
- 内置ApiException方法
- 参数获取器getParams
- 网络请求器Fetch
- 内置工具函数
- JWT的使用
- 验证
- 验证器
- 验证规则
- 自定义验证规则
- 混合验证规则
- 分场景验证
- 数据库
- 连接数据库
- 查询数据
- 链式操作
- where
- whereOr
- whereBetweenTime
- limit
- page
- count
- order
- field
- alias
- group
- distinct
- 添加数据
- 更新数据
- 删除数据
- 联表查询
- SQL调试
- 模型
- 视图
- 模板渲染(废弃)
- 模板变量(废弃)
- 错误和日志
- 异常处理
- 日志处理
- 命令行
- 扩展库
- 使用Redis
- get
- set
- del
- hget
- hset
- hdel
- decrby
- incrby
- rpush
- rpop
- 使用MongoDB
- 模型
- 新增
- 删除
- 修改
- 查询
- 使用ElasticSearch
- 使用阿里云OSS
- 阿里短信服务
- 微信支付
- 支付宝支付
- 部署
- 更新日志