Working with PHP Attributes: Do’s & Don’ts

working with php attributes: do’s & don’ts

php 中的属性允许您直接使用元数据注释代码元素,从而简化了代码配置,从而可能减少 laravel 等框架中的样板文件。然而,与任何功能一样,属性可能会被过度使用或误用,从而导致控制器混乱和代码难以维护。

在这篇文章中,我们将探索以增强代码清晰度的方式使用属性的最佳实践。我还将提供一个“该做和不该做”的表格,其中包含每次比较的示例,突出显示属性工作良好的场景以及可能不工作的场景。

1. 理解php中的属性

这是定义和使用属性来提供一些上下文的快速示例:

#[attribute]class mycustomattribute {    public function __construct(public string $description) {}}#[mycustomattribute("this is a test class")]class myclass {    #[mycustomattribute("this is a test method")]    public function mymethod() {}}

2. 注意事项:快速概述

下表总结了最佳实践和常见陷阱:

do’s don’ts

use attributes for standard, repetitive configurations (e.g., http methods, caching).don’t overload attributes with complex configurations or conditional logic.leverage attributes for metadata rather than core application logic.avoid embedding business logic or intricate rules within attributes.apply attributes for simple, reusable annotations (e.g., #[throttle], #[cache]).don’t try to replace laravel’s route files entirely with attribute-based routing.cache attribute-based reflections when possible to improve performance.don’t rely solely on attributes for configurations that need flexibility or change often.document your attributes, so team members understand their purpose and usage.avoid using attributes for configurations where traditional methods work better (e.g., middleware settings).

3. 实例详细比较

让我们通过具体示例深入了解每个比较。

立即学习“PHP免费学习笔记(深入)”;

1. 使用属性进行标准、重复的配置(执行)

属性非常适合不需要复杂逻辑的标准配置。以下是三个很好的例子:

定义路由:使用属性通过 http 方法和路径定义简单的路由。

  #[attribute]  class route {      public function __construct(public string $method, public string $path) {}  }  class productcontroller {      #[route('get', '/products')]      public function index() {}  }

缓存控制:使用属性指定方法的缓存持续时间。

  #[attribute]  class cache {      public function __construct(public int $duration) {}  }  class productcontroller {      #[cache(3600)]      public function show($id) {}  }

速率限制:throttle 属性可用于限制每个用户的请求数量。

  #[attribute]  class throttle {      public function __construct(public int $maxattempts) {}  }  class usercontroller {      #[throttle(5)]      public function store() {}  }

不要使用复杂的配置来重载属性(不要)

避免对需要多个参数或条件的配置使用属性。以下是不应该做的事情:

使用多个配置重载:避免向属性添加多个参数。

  #[attribute]  class route {      public function __construct(          public string $method,          public string $path,          public ?string $middleware = null,          public ?string $prefix = null      ) {}  }  #[route('post', '/users', middleware: 'auth', prefix: '/admin')]

属性中的条件逻辑:避免属性内的条件设置。

  #[attribute]  class condition {      public function __construct(public string $condition) {}  }  class controller {      #[condition("isadmin() ? 'adminroute' : 'userroute'")]      public function index() {}  }

单个属性中的链接配置:避免在一个属性中链接多个配置行为。

  #[attribute]  class combined {      public function __construct(          public int $cacheduration,          public int $ratelimit      ) {}  }  #[combined(cacheduration: 300, ratelimit: 5)]

2. 利用元数据的属性(执行)

使用属性作为标记或元数据,而不是在其中嵌入应用程序逻辑。方法如下:

验证注释:使用属性将字段标记为必填。

  #[attribute]  class required {}  class user {      #[required]      public string $name;  }

指定 http 方法作为元数据:使用属性来标记 http 方法类型。

  #[attribute]  class get {}  class blogcontroller {      #[get]      public function list() {}  }

指示访问级别:使用属性来指示访问级别要求。

  #[attribute]  class requiresadmin {}  class settingscontroller {      #[requiresadmin]      public function update() {}  }

不要在属性中嵌入业务逻辑(不要)

避免使用属性直接确定应用程序行为。以下是不应该做的事情:

避免在属性中使用直接条件:不要在属性中放置条件检查。

  #[attribute]  class accesscontrol {      public function __construct(public string $role) {}  }  #[accesscontrol(role: isadmin() ? 'admin' : 'user')]

避免在属性中调用方法:不要在属性中放置函数调用或业务逻辑。

  #[attribute]  class conditionalcache {      public function __construct(public int $duration) {}  }  #[conditionalcache(duration: userhaspremium() ? 3600 : 300)]

避免在属性中使用计算值:属性应该是静态元数据,而不是计算值。

  #[attribute]  class cache {      public function __construct(public int $duration) {}  }  #[cache(duration: (int)env('cache_duration'))]

3. 将属性应用于简单、可重用的注释(执行)

属性非常适合可重用的轻量级注释。以下是一些可重用的注释示例:

simple throttle:用于限制请求速率的简单节流属性。

  #[attribute]  class throttle {      public function __construct(public int $limit) {}  }  #[throttle(5)]

缓存控制:使用单个持续时间参数添加缓存控制属性。

  #[attribute]  class cache {      public function __construct(public int $duration) {}  }  #[cache(120)]

弃用警告:将方法标记为弃用以提醒开发人员。

  #[attribute]  class deprecated {      public function __construct(public string $message) {}  }  #[deprecated("this method will be removed in v2.0")]

不要过度使用其他格式更容易的配置属性(不要)

某些配置在属性之外可以得到更好的管理。以下是不应该做的事情:

中间件配置:避免直接在属性中配置中间件。

  #[attribute]  class middleware {      public function __construct(public string $name) {}  }  #[middleware('auth')]

授权规则:复杂的授权配置最好放在策略文件中。

  #[attribute]  class permission {      public function __construct(public string $requiredpermission) {}  }  #[permission("edit_post")]

复杂的验证规则:将验证逻辑排除在属性之外。

  #[Attribute]  class Validate {      public function __construct(public array $rules) {}  }  #[Validate(['name' => 'required|min:3'])]

结论

属性提供了一种优雅的方式来处理重复配置,特别是在 laravel 这样的 php 框架中。

但是,它们作为简单的元数据效果最好,并且必须避免使用复杂的配置或逻辑使它们过载。

通过遵循最佳实践并将属性用作轻量级、可重用的注释,您可以充分利用它们的潜力,而不会给代码库增加不必要的复杂性。

赞助

通过在 github 赞助商上赞助我来支持我的开源工作!您的赞助帮助我不断创建有用的 laravel 软件包、工具和教育内容,让开发者社区受益。感谢您帮助让开源变得更好!

照片由 milad fakurian 在 unsplash 上拍摄

以上就是Working with PHP Attributes: Do’s & Don’ts的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1249651.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月9日 21:33:37
下一篇 2025年12月9日 21:33:49

相关推荐

  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • HTMLrev 上的免费 HTML 网站模板

    HTMLrev 是唯一的人工策划的库专门专注于免费 HTML 模板,适用于由来自世界各地慷慨的模板创建者制作的网站、登陆页面、投资组合、博客、电子商务和管理仪表板世界。 这个人就是我自己 Devluc,我已经工作了 1 年多来构建、改进和更新这个很棒的免费资源。我自己就是一名模板制作者,所以我知道如…

    2025年12月24日
    300
  • 如何使用 Laravel 框架轻松整合微信支付与支付宝支付?

    如何通过 laravel 框架整合微信支付与支付宝支付 在 laravel 开发中,为电商网站或应用程序整合支付网关至关重要。其中,微信支付和支付宝是中国最流行的支付平台。本文将介绍如何使用 laravel 框架封装这两大支付平台。 一个简单有效的方法是使用业内认可的 easywechat lara…

    2025年12月24日
    000
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • Laravel 框架中如何无缝集成微信支付和支付宝支付?

    laravel 框架中微信支付和支付宝支付的封装 如何将微信支付和支付宝支付无缝集成到 laravel 框架中? 建议解决方案 考虑使用 easywechat 的 laravel 版本。easywechat 是一个成熟、维护良好的库,由腾讯官方人员开发,专为处理微信相关功能而设计。其 laravel…

    2025年12月24日
    500
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 使用Laravel框架如何整合微信支付和支付宝支付?

    使用 Laravel 框架整合微信支付和支付宝支付 在使用 Laravel 框架开发项目时,整合支付网关是常见的需求。对于微信支付和支付宝支付,推荐采用以下方法: 使用第三方库:EasyWeChat 的 Laravel 版本 建议直接使用现有的 EasyWeChat 的 Laravel 版本。该库由…

    2025年12月24日
    000
  • 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中?

    如何简洁集成微信和支付宝支付到 Laravel 问题: 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中? 答案: 强烈推荐使用流行的 Laravel 包 EasyWeChat,它由腾讯开发者维护。多年来,它一直保持更新,提供了一个稳定可靠的解决方案。 集成步骤: 安装 Laravel …

    2025年12月24日
    100
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000
  • 有哪些美观的开源数字大屏驾驶舱框架?

    开源数字大屏驾驶舱框架推荐 问题:有哪些美观的开源数字大屏驾驶舱框架? 答案: 资源包 [弗若恩智能大屏驾驶舱开发资源包](https://www.fanruan.com/resource/152) 软件 [弗若恩报表 – 数字大屏可视化组件](https://www.fanruan.c…

    2025年12月24日
    000
  • 网站底部如何实现飘彩带效果?

    网站底部飘彩带效果的 js 库实现 许多网站都会在特殊节日或活动中添加一些趣味性的视觉效果,例如点击按钮后散发的五彩缤纷的彩带。对于一个特定的网站来说,其飘彩带效果的实现方式可能有以下几个方面: 以 https://dub.sh/ 网站为例,它底部按钮点击后的彩带效果是由 javascript 库实…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信