element ui 分页增删改查_推荐一个laravel极速完成增删改查的第三方包

0689cfaeab9a422ad8d1fab77229bfdd.png

php中文网最新课程

每日17点准时技术干货分享

7fca85c1bc220c59b86cb8b9c2741282.png

a16d796b0ca67bc2186541dffd4c7cc2.gif

推荐一个实用的laravel包https://github.com/osindex/LaravelControllerTrait

可以通过命令行直接生成Model、Controller和migrate文件,并且添加了很多常用的筛选过滤方法,不到一分钟就能写完简单的增删改查
特别是对查询的优化,基本不用单独加接口

laravel-controller-trait

install

composer require osi/laravel-controller-trait

useage

###artisan

php artisan trait:controllerphp artisan trait:model

###controller&&route

use Osi\LaravelControllerTrait\Traits\ControllerBaseTrait; // traituse App\Admin; //model fileclass AdminsController extends Controller{    use ControllerBaseTrait;    public function __construct(Admin $model){        $this->model = $model;        $this->resource = '\Osi\LaravelControllerTrait\Resources\Resource';        $this->collection = '\Osi\LaravelControllerTrait\Resources\Collection';        $this->functions = get_class_methods(self::class);    }}Route::resources(['admins' => 'AdminsController']);#以上完成,即提供了常规的增删改查方法#【1.10】新增批量更新post:api/admins/batchrequest()->all(): [    ['id'=>1,'field'=>'xxx','field2'=>xxx],    ['id'=>2,'field'=>'x2x','field2'=>x2x]]#【1.11】剥离基础返回类use Osi\LaravelControllerTrait\Traits\ResponseBaseTrait; // trait 附带以下方法dataSuccesscreatedacceptednoContentbadRequestunauthorizedforbiddenunprocesableEtitysuccess

filter

/message?filter={"created_at":{"from":"2016-02-20","to":"2016-02-24 23:59:59"}, "id":{"operation":"not in", "value":[2,3,4]}}/message?filter={"user_id":{"operation":"in", "value":[null,2,3,4]}}/message?filter={"id":{"from":2,"to":5}}/message?filter={"id":{"to":5}} or /message?filter={"id":{"operation":"<=","value":5}}/message?filter={"updated_at":{"isNull":true}}/message?filter={"answer":{"operation":"like","value":"Partial search string"}}/message?filter={"answer":"Full search string"}/message?filter={"user.name":"asd"} # 关联搜索 whereHas/message?filter={"id":1}# 暂时只支持单字段排序/message?sort=id/message?sort=-id/message?sort=user.name# 关联搜索/message?expand=user response: { "id": 1, "message": "some message", "user_id": 1, ... "user": { "id": 1, "name": "Some username", ... } }# 关联搜索子集,获取特定字段/message?expand=archives,user.recordable:id/status# 【1.8】新增scope搜索//User Model<?php 新增允许的filterScopes属性protected $filterScopes = ['QueryLike'];// laravel实现姓名或电话搜索public function scopeQueryLike($query, $param){    return $query->where(function ($querySec) use ($param) {        return $querySec->where('name', 'like', '%' . $param . '%')->orWhere('phone', 'like', '%' . $param . '%');    });}/user?filter={"QueryLike":2333}# 【1.9】新增JSON搜索(jsoncontains,jsonlength) ##注:目前仅有jsonlength 支持type属性/message?filter={"json->paramA":"233"}/message?filter={"json->array":{"operation":"jsonlength","type":">","value":5}}/message?filter={"json->array":{"operation":"jsoncontains","value":5}}# 【1.11】 filterExpand 用法## 一般我们使用expand对应with方法 如 `model->with('app')` === `?expand=app`因此 可以使用 filterExpand 完成 `model->with(['app'=>function($q) use($id){$q->where('id',$id)}])` 的类似方法/message?expand=app&filterExpand={'app.created_at': { 'operation': '>=', 'value': 'now()' },'app.id': 1}# 【2.0】 collection 集合增加筛选及分页方法#collect()->setFilterAndRelationsAndSort($request)->paginate((int) $request->pageSize ?? 15)集合的查询相对数据库较为简单 仅包括集合支持的相关方法 具体查阅以下函数setFilter【2.1】batch批量更新修改#原post:api/model/batchrequest()->all(): [    ['id'=>1,'field'=>'xxx','field2'=>xxx],    ['id'=>2,'field'=>'x2x','field2'=>x2x]]#新增兼容 data对象包裹request()->all(): [    'data'=>    [        ['id'=>1,'field'=>'xxx','field2'=>xxx],        ['id'=>2,'field'=>'x2x','field2'=>x2x]    ]]
添加"operation":"in"  对null的支持  "col":{"operation":"in", "value":[null,2,3,4]}

func

Don not code normal controller func.

40448a9ec963dd4a0e33bc029753b18f.png

e5a6ff4bec42e2af8069a2d997047808.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值