Maison > cadre php > Laravel > Recommander un package tiers pour Laravel afin d'effectuer rapidement des ajouts, des suppressions, des modifications et des vérifications

Recommander un package tiers pour Laravel afin d'effectuer rapidement des ajouts, des suppressions, des modifications et des vérifications

藏色散人
Libérer: 2020-08-20 13:13:14
avant
2566 Les gens l'ont consulté
Vous trouverez ci-dessous

Laravel La colonne tutoriel recommande un package tiers pour Laravel pour terminer l'ajout, la suppression et la modification, et j'espère aider les amis qui en ont besoin !

Recommander un package tiers pour Laravel afin d'effectuer rapidement des ajouts, des suppressions, des modifications et des vérifications

Recommander un package Laravel pratique https://github.com/osindex/LaravelControllerTrait

peut être généré directement via la commande Les fichiers de modèle, de contrôleur et de migration de ligne, ainsi que de nombreuses méthodes de filtrage couramment utilisées, ont été ajoutés. Des ajouts, suppressions, modifications et requêtes simples peuvent être écrits en moins d'une minute.

En particulier pour l'optimisation des requêtes, il n'est fondamentalement pas nécessaire d'en ajouter des séparés. interfaces

laravel-controller-trait

installer

composer require osi/laravel-controller-trait
Copier après la connexion

utilisation

###artisan

php artisan trait:controller
php artisan trait:model
Copier après la connexion

###controller&&route

use Osi\LaravelControllerTrait\Traits\ControllerBaseTrait; // trait
use App\Admin; //model file
class 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/batch
request()->all(): [
    ['id'=>1,'field'=>'xxx','field2'=>xxx],
    ['id'=>2,'field'=>'x2x','field2'=>x2x]
]

#【1.11】剥离基础返回类

use Osi\LaravelControllerTrait\Traits\ResponseBaseTrait; // trait 附带以下方法

dataSuccess
created
accepted
noContent
badRequest
unauthorized
forbidden
unprocesableEtity
success
Copier après la connexion

filtre

/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 = [&#39;QueryLike&#39;];
// laravel实现姓名或电话搜索
public function scopeQueryLike($query, $param)
{
    return $query->where(function ($querySec) use ($param) {
        return $querySec->where(&#39;name&#39;, &#39;like&#39;, &#39;%&#39; . $param . &#39;%&#39;)->orWhere(&#39;phone&#39;, &#39;like&#39;, &#39;%&#39; . $param . &#39;%&#39;);
    });
}
/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(&#39;app&#39;)` === `?expand=app`
因此 可以使用 filterExpand 完成 `model->with([&#39;app&#39;=>function($q) use($id){$q->where(&#39;id&#39;,$id)}])` 的类似方法
/message?expand=app&filterExpand={&#39;app.created_at&#39;: { &#39;operation&#39;: &#39;>=&#39;, &#39;value&#39;: &#39;now()&#39; },&#39;app.id&#39;: 1}

# 【2.0】 collection 集合增加筛选及分页方法
#collect()->setFilterAndRelationsAndSort($request)->paginate((int) $request->pageSize ?? 15)
集合的查询相对数据库较为简单 仅包括集合支持的相关方法 具体查阅以下函数
setFilter
Copier après la connexion

【2.1】modification de mise à jour par lots

#原
post:api/model/batch
request()->all(): [
    [&#39;id&#39;=>1,&#39;field&#39;=>&#39;xxx&#39;,&#39;field2&#39;=>xxx],
    [&#39;id&#39;=>2,&#39;field&#39;=>&#39;x2x&#39;,&#39;field2&#39;=>x2x]
]
#新增兼容 data对象包裹
request()->all(): [
    &#39;data&#39;=>
    [
        [&#39;id&#39;=>1,&#39;field&#39;=>&#39;xxx&#39;,&#39;field2&#39;=>xxx],
        [&#39;id&#39;=>2,&#39;field&#39;=>&#39;x2x&#39;,&#39;field2&#39;=>x2x]
    ]
]
Copier après la connexion
添加"operation":"in"  对null的支持  
"col":{"operation":"in", "value":[null,2,3,4]}
Copier après la connexion

func

Don not code normal controller func.
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:learnku.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal