찾다
PHP 프레임워크LaravelLaravel에서 열거형을 사용하는 방법에 대해 이야기해 보겠습니다.

Laravel에서 열거형을 어떻게 사용하나요? 다음 글에서는 Laravel에서 열거형을 사용하는 방법을 소개하겠습니다. 도움이 되길 바랍니다.

Laravel에서 열거형을 사용하는 방법에 대해 이야기해 보겠습니다.

저는 최근에 C#을 사용하는 회사에서 enum을 광범위하게 사용하면서 enum을 찾을 수 없을 때 찾는 데 익숙해졌습니다. 그리고 그들을 그리워합니다.

요일, 주문 상태 또는 아래 예와 같이 사용자 유형과 같이 가능한 옵션이 제한된 모든 것에 사용합니다.

열거를 사용하면 여러 가지 이점이 있습니다.

- 숫자를 바꾸거나 잘못 입력하여 발생하는 오류를 줄입니다.

- 나중에 값을 쉽게 변경할 수 있습니다.

- 코드를 읽기 쉽게 만들어 버그가 침투할 가능성이 줄어듭니다.

- 향후 호환성 보장 열거형을 사용하면 나중에 누군가가 멤버 이름에 해당하는 값을 변경할 경우 코드가 실패할 가능성을 크게 줄일 수 있습니다.

PHP 자체는 열거형을 지원하지 않지만 클래스에서 상수를 사용하면 동등한 효과를 얻는 것은 매우 쉽습니다. 또한 laravel-enum이라는 Laravel 패키지를 만들었습니다. 이를 통해 키 및 값 나열, 값에 설명 추가, 열거 값이 필요한 요청 유효성 검사와 같은 도우미 기능에 액세스할 수 있습니다.

이 가이드는 사용법 예시와 모범 사례를 포함하여 Laravel 패키지를 설치하는 과정을 안내합니다.

설치 패키지

컴포저를 통해 터미널에서 다음 명령을 실행하여 패키지를 설치할 수 있습니다.

$ composer require bensampo/laravel-enum

Laravel 5.5 미만 버전을 사용하는 경우 config에 서비스 공급자를 추가해야 합니다. /app .php.config/app.php.

'BenSampo\Enum\EnumServiceProvider'

创建第一个枚举

我们将为用户类型创建一个枚举在我们的示例应用程序中,用户可以属于以下三种用户类型之一:管理员、付费成员、成员。

包中包含用于创建枚举的生成器,因此可以运行以下命令来创建名为UserType的枚举该文件将在“app/Enums/UserType.php”中创建

php artisan make:enum UserType

你将在这个文件中看到一定数量的脚手架。在文件顶部附近,可能的选项列表被定义为常量。这些常量值存储在数据库中,因此我发现最好是使用整数,但是并没有限制一定要使用整数,只要每一个值都是唯一就可以了了。

本例中的选项看起来是这样的:

const Administrator = 0;
const PaidMember = 1;
const Member = 2;

把值存储在数据库中

现在我们有了一个带有一些可能性的枚举,并且可以开始使用它。在迁移 user 表时, 可以添加以下内容。

$table->tinyInteger('type')->unsigned()->default(UserType::Member);

因为 null 不是枚举的选项,我们需要为它设置默认值。在这个例子中,有必要去假设默认情况下的用户将成为标准成员。

确保文件的顶部包含此枚举的 use 语句。

use App\Enums\UserType;

在操作中使用枚举

由于我们现在的用户模型具有类型的属性,我们可以对它进行访问,并和 enum 值进行比较。这就是枚举真正的好处,也是我为什么如此喜欢他们。看一下下面的用法示例和可能替代的方法。

if ($user->type === UserType::PaidMember) {
    // 在这里只是做一些付费会员的事情.
}

如果我们不使用枚举,可能会有类似以下的代码:

if ($user->type === 1) { // 这个1表示什么??
    // ...
}

if ($user->type === 'PaidMember') { // 这他妈咋么又是字符串 ?
    // ...
}

使用枚举的第一个例子是最容易读懂并且也是最不容易出错的例子。如果我偶然输入了 UserType::Paidember (注意拼写错误),我会得到一个很好的错误提示,告诉我代码错误了(类中不存在这个常量值),而不是像前两个示例那样默默的失败。(只是判断不符合条件,你还需要根据当前的条件语句去具体的查看相关代码?)

显示枚举

在应用的某些界面,我们可能希望向用户显示他们所属的用户类型。如果只是简单的输出从数据库所获取的整型值,显然达不到我们想要的结果。相反,可使用每个枚举类所继承基类的  getDescription 方法。

在 blade 模板上的操作如下:

<p>{{ \App\Enums\UserType::getDescription($user->type) }}</p>

输出结果Administrator(管理员),PaidMember(付费会员) 、Member(会员)中的一个。

有时候关键词名称是复合词(就像 PaidMember),我们想要展示和键名不同的东西。我们可以像下面这样覆盖掉当前枚举的描述。 在 app/Enums/UserType.php:

public static function getDescription(int $value): string
{
    switch ($value) {
        case self::PaidMember:
            return 'Paid member';
        break;
        default:
            return self::getKey($value);
    }
}

现在当我们调用  getDescription 我们将获取到 AdministratorPaid member or Member

public function store(Request $request)
{
    $this->validate($request, [
        'type' => ['required', new EnumValue(UserType::class)],
    ]);

    // 保存用户等等...
}

첫 번째 열거 만들기

사용자 유형에 대한 열거를 만듭니다. 샘플 애플리케이션에서 사용자는 관리자, 유료의 세 가지 사용자 유형 중 하나에 속할 수 있습니다. 회원, 회원.

패키지는 열거형 생성을 위한 생성기를 포함하므로 다음 명령을 실행하여 UserType이라는 열거형을 생성할 수 있습니다. 파일은 "app/Enums/UserType.php"에 생성됩니다. 🎜
use App\Enums\UserType;
use BenSampo\Enum\Rules\EnumValue;
🎜 이 파일에 열거형을 생성합니다. 어느 정도의 비계가 보였습니다. 파일 상단 근처에 가능한 옵션 목록이 상수로 정의되어 있습니다. 이러한 상수 값은 데이터베이스에 저장되므로 정수를 사용하는 것이 가장 좋다고 생각했지만, 각 값이 고유한 한 정수 사용에 제한은 없습니다. 🎜🎜이 예제의 옵션은 다음과 같습니다. 🎜rrreee🎜🎜데이터베이스에 값 저장🎜🎜🎜이제 몇 가지 가능성이 있는 열거형이 있으므로 이를 사용할 수 있습니다. 사용자 테이블을 마이그레이션할 때 다음을 추가할 수 있습니다. 🎜rrreee🎜null은 열거형의 옵션이 아니므로 기본값을 설정해야 합니다. 이 예에서는 기본 사용자가 표준 회원이 된다고 가정해야 합니다. 🎜🎜파일 상단에 이 열거형에 대한 사용 설명을 포함해야 합니다. 🎜rrreee🎜🎜작업에 열거형 사용🎜🎜🎜이제 사용자 모델에 형식화된 속성이 있으므로 이에 액세스하여 열거형 값과 비교할 수 있습니다. 이것이 열거형의 진정한 이점이며 내가 열거형을 그토록 좋아하는 이유입니다. 아래에서 사용 예와 가능한 대안을 살펴보세요. 🎜rrreee🎜열거형을 사용하지 않았다면 다음과 유사한 코드가 있을 수 있습니다. 🎜rrreee🎜열거형을 사용한 첫 번째 예는 읽기가 가장 쉽고 오류 발생 가능성이 가장 낮습니다. 실수로 UserType::Paidember를 입력하면(철자 오류 참고) 코드가 잘못되었다는 오류 메시지가 표시됩니다(이 상수 값은 클래스에 존재하지 않습니다). 처음 두 예제는 자동으로 실패합니다. (단지 조건이 충족되지 않았다고 판단하려면 현재 조건문을 기반으로 관련 코드를 구체적으로 확인해야 합니까?)🎜🎜🎜열거 표시🎜🎜🎜애플리케이션의 일부 인터페이스에서는 사용자에게 표시하고 싶을 수도 있습니다. 그들이 속한 사용자 유형. 단순히 데이터베이스에서 얻은 정수값을 출력한다면 당연히 원하는 결과를 얻을 수 없습니다. 대신 각 열거형 클래스가 상속하는 기본 클래스의 getDescription 메서드를 사용하세요. 🎜🎜블레이드 템플릿의 작업은 다음과 같습니다. 🎜rrreee🎜출력 결과는 Administrator(관리자), PaidMember(유료 회원), Member입니다. 코드>(회원). 🎜🎜때때로 키워드 이름이 복합어(예: <code>PaidMember)이고 키 이름과 다른 것을 표시하고 싶을 때가 있습니다. 다음과 같이 현재 열거형 설명을 덮어쓸 수 있습니다. app/Enums/UserType.php:🎜rrreee🎜이제 getDescription을 호출하면 Administrator, Paid member/를 얻게 됩니다. code> 또는 <code>Member.🎜🎜🎜확인 방법🎜🎜🎜사용자 입력을 통해 열거 값을 수정할 때는 유효한 값만 허용하는지 확인하는 것이 가장 좋습니다. 패키지의 유효성 검사 규칙을 사용할 수 있습니다. 🎜

当以表格展示枚举的时候,我经常把他们显示为 HTML select 元素。这样虽仍然可以被恶意修改,但是避免了将错误的值传递给服务器的情况。

继续我们的用户使用示例,让我们在用户控制器中处理修改的值:

public function store(Request $request)
{
    $this->validate($request, [
        'type' => ['required', new EnumValue(UserType::class)],
    ]);

    // 保存用户等等...
}

记住要同时包含枚举的 use 语句和 EnumValue 的规则。

use App\Enums\UserType;
use BenSampo\Enum\Rules\EnumValue;

结束

当然这并不是枚举所能完成的全部范围。但是它覆盖了90%的用例。

值得一看的列表 枚举类上的方法的完整列表 以查看您还能实现什么。

【相关推荐:laravel视频教程

위 내용은 Laravel에서 열거형을 사용하는 방법에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 learnku에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
laravel单点登录方法详解laravel单点登录方法详解Jun 15, 2022 am 11:45 AM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于单点登录的相关问题,单点登录是指在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统,下面一起来看一下,希望对大家有帮助。

一起来聊聊Laravel的生命周期一起来聊聊Laravel的生命周期Apr 25, 2022 pm 12:04 PM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于Laravel的生命周期相关问题,Laravel 的生命周期从public\index.php开始,从public\index.php结束,希望对大家有帮助。

laravel中guard是什么laravel中guard是什么Jun 02, 2022 pm 05:54 PM

在laravel中,guard是一个用于用户认证的插件;guard的作用就是处理认证判断每一个请求,从数据库中读取数据和用户输入的对比,调用是否登录过或者允许通过的,并且Guard能非常灵活的构建一套自己的认证体系。

laravel中asset()方法怎么用laravel中asset()方法怎么用Jun 02, 2022 pm 04:55 PM

laravel中asset()方法的用法:1、用于引入静态文件,语法为“src="{{asset(‘需要引入的文件路径’)}}"”;2、用于给当前请求的scheme前端资源生成一个url,语法为“$url = asset('前端资源')”。

实例详解laravel使用中间件记录用户请求日志实例详解laravel使用中间件记录用户请求日志Apr 26, 2022 am 11:53 AM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于使用中间件记录用户请求日志的相关问题,包括了创建中间件、注册中间件、记录用户访问等等内容,下面一起来看一下,希望对大家有帮助。

laravel中间件基础详解laravel中间件基础详解May 18, 2022 am 11:46 AM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于中间件的相关问题,包括了什么是中间件、自定义中间件等等,中间件为过滤进入应用的 HTTP 请求提供了一套便利的机制,下面一起来看一下,希望对大家有帮助。

laravel的fill方法怎么用laravel的fill方法怎么用Jun 06, 2022 pm 03:33 PM

在laravel中,fill方法是一个给Eloquent实例赋值属性的方法,该方法可以理解为用于过滤前端传输过来的与模型中对应的多余字段;当调用该方法时,会先去检测当前Model的状态,根据fillable数组的设置,Model会处于不同的状态。

laravel路由文件在哪个目录里laravel路由文件在哪个目录里Apr 28, 2022 pm 01:07 PM

laravel路由文件在“routes”目录里。Laravel中所有的路由文件定义在routes目录下,它里面的内容会自动被框架加载;该目录下默认有四个路由文件用于给不同的入口使用:web.php、api.php、console.php等。

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구