0

0

WordPress 样板在插件开发中的重要性

WBOY

WBOY

发布时间:2023-08-28 09:53:01

|

1295人浏览过

|

来源于php中文网

原创

在过去的五到十年中,为网络构建网站和应用程序已经变得比人们在 90 年代构建的许多东西复杂得多。使用大写 html、基于表格的布局和丑陋的 javascript 来手动创建网站以在页面上制作某种类型的可爱动画已经一去不复返了。

现在,我们拥有各种技术、框架和语言,所有这些技术、框架和语言都可以协同工作,帮助我们构建在浏览器中运行的完整软件应用程序。

这是成为一名开发人员的美好时光。

由于我们可以使用的技术非常多,样板文件变得越来越流行。对于那些不熟悉的人来说,样板文件基本上是基础代码,可帮助开发人员快速启动项目,而无需编写所有站点和/或应用程序通用的代码或某些组件。

当然,它们可能会过度到比必要的更笨重和更复杂的程度,但所有好的都是为了奠定基础 - 即提供一种脚手架 - 帮助你专注于写作您的核心算法、代码和函数对于您的项目和需求来说是独一无二的。

一年多前,我开始研究两个项目 - WordPress 插件 Boilerplate 和 WordPress Widget Boilerplate - 每个项目都旨在为开发人员提供使用 WordPress 最佳实践构建插件的基础。值得庆幸的是,这些项目还收到了开源社区的许多其他贡献,以帮助它们变得尽可能强大。

维护这些项目的一个方面是,我经常收到这样的问题:为什么我要这样安排事情。因此,在这个由两部分组成的系列中,我们将研究样板文件、按照我的方式组织它们的原因(和优点),然后我们将使用这些样板文件之一构建一个简单的插件,以给出一个示例如何在您未来的项目中使用它们。


文件组织

构建任何软件应用程序的关键组成部分之一(无论大小)是程序的组织方式。这不仅限于类和/或函数的关联方式(这是另一篇文章的主题),还包括文件的组织方式。

理想情况下,文件不应简单地转储到目录中,然后留给其他开发人员进行筛选以维护项目。相反,它们应该在逻辑上组织在连贯的目录中,命名清晰(而不是巧妙),并且应该要求任何为项目做出贡献的开发人员花费很少的精力来了解某些文件的位置以及将他或她自己的添加内容放在哪里。

WordPress 样板在插件开发中的重要性

这就像一句古老的格言:

一个放置所有东西的地方,并且所有东西都在它的位置上。

在创建这两个样板时,我不仅尝试遵循这一特定原则,而且还尝试从 Ruby on Rails 对其布局进行建模的方式中汲取灵感。具体来说,他们更喜欢“约定优于配置”。

显然,WordPress 不是 Rails,也不是 MVC 框架,我也不想让它成为这样。我只是想从其他开发者那里借鉴好的想法,以便让我们的生活在我们的环境中变得更轻松。

核心插件文件

无论您的插件有多简单或多复杂,它都必须至少包含一个 PHP 文件。该文件用作核心插件文件,其中包含赋予您的插件生命的所有代码、逻辑和功能。

如果您查看各种插件,您会发现开发人员有不同的做法:

  • 有些将所有内容包含在一个文件中
  • 有些将相关功能分解为单独的文件,并使用核心插件文件来简单地包含每个功能
  • 有些将一些前端代码与服务器端代码分开

我并不是来证明为什么这些方法(甚至提到的方法)比其他方法更好;只是为什么样板以这种方式布局以及它如何为您工作。

WordPress 样板在插件开发中的重要性

基于 README 文件的插件主页。

除了核心插件文件之外,WordPress 插件还需要自述文件,以便为最终用户提供有关如何使用插件以及填充 WordPress 插件存储库中的页面的一些说明。

在最基本的层面上,这就是 WordPress 插件所需的全部内容:核心插件文件和自述文件。您只需使用这两个文件就可以构建一些非常复杂的插件;然而,它可能变得非常难以维护,特别是如果其他开发人员开始贡献,这最终可能会导致意外的错误。

因此,我非常喜欢逻辑上分离代码的组件。

观看次数

视图是我从 MVC 模式借用的一个词(并且受到 Rails 的启发)。

视图可以定义为前端标记,为管理员和网站访问者在屏幕上呈现元素。

仅此而已。很容易,对吧?

当然,因为我们使用 PHP 工作,所以在整个代码中肯定会放置一些较小的 PHP 标签,但视图文件的大部分应该是带有类和 ID 属性的 HTML。

在样板中,有两个视图:

  1. admin.php 是用于在管理仪表板中为用户呈现元素的视图
  2. widget.phpplugin.php 是用于为网站访问者呈现元素的视图

当然,插件可能没有仪表板或网站访问者的视图。在这种情况下,views 目录将被删除,并且负责将它们包含在核心插件文件中的代码将被删除。

Krea AI
Krea AI

多功能的一站式AI图像生成和编辑平台

下载

样式表

这是样板文件的一个微不足道的组件,因为任何进行任何类型前端开发的人都知道如何管理样式表,并且可能有自己的组织它们的方法。

但为了保持一致,值得一提的是 css 目录是保存所有样式表的位置。这些文件还遵循与其关联视图相同的命名约定。

具体:

  1. admin.css 是用于在管理仪表板中为用户设置元素样式的视图
  2. widget.cssplugin.css 是用于为网站访问者设置元素样式的视图

我曾考虑过为 LESS 或 SASS 引入目录结构,但我认为这对于开发来说过于固执己见,而且这不是我希望样板文件发展的方向。我宁愿开发者选择自己的风格并将其融入其中。

为此,我通常在自己的项目中组织样式表的方式是在 css 目录中引入一个 dev 目录,然后引入一个 admin .lessplugin.less 文件,然后编译并缩小到根 css 目录中。

这继续遵循组织样板的做法,同时还允许我包含我的 LESS 文件。

JavaScript

与样式表一样,JavaScript 文件是样板文件的一个简单组件,因为大多数使用 WordPress 并开发主题或插件的人都使用过 JavaScript。

不幸的是,作为用户和开发人员,在 WordPress 中使用 JavaScript 最令人沮丧的部分之一是开发人员通常不遵循最佳实践。

一般来说,开发人员应始终执行以下操作:

  1. 使用与 WordPress 捆绑的 jQuery 版本
  2. 通过使用匿名函数访问 jQuery '$' 函数,避免与该函数发生冲突
  3. 不要将 jQuery 取消注册为其他插件,主题可能正在使用它

话虽如此,样板文件(如样式表和视图)按以下方式组织:

  1. admin.js 是用于管理管理仪表板中用户元素行为的 JavaScript
  2. widget.jsplugin.js 是用于为访问者管理元素行为的 JavaScript

与样式表一样,开发人员也可以选择在发布插件之前检查和/或缩小其 JavaScript。为了避免对 JavaScript 文件的管理方式过于固执,样板中不包含子目录,但我经常在 js 目录中创建一个 dev 目录,以便按顺序管理我预先检查、预先缩小的 JavaScript。

语言

构建插件的一方面是确保使用其他语言的人可以访问和翻译它们。为了尽可能简单,样板文件还包含一个 lang 目录和一个框架 plugin.po 文件。

此文件旨在与 POEdit 结合使用,以便您完成开发后,可以轻松处理所有本地化字符串。

图像和其他资产怎么样?

除了样式表和 JavaScript 文件之外,样板不提供任何用于管理其他资产(例如图像)的目录或约定。

同样,这是一种平衡,既要努力避免过于固执己见,又要提供足够的脚手架,让开发人员开始专注于其核心功能。尽管并非每个插件都包含管理 CSS、JavaScript 或视图,但它们比包含图像和其他资源更为常见。

不过,所提供的约定规定您可以创建一个assets目录、一个images目录、一个icons目录,或者您将使用的任何其他类型的文件。


为什么要麻烦?

WordPress 样板在插件开发中的重要性

WordPress 小部件样板

那么这一切有什么意义呢?打开一个文件并开始编写所有代码不是很容易吗?确实。但请记住,大部分开发工作是在产品发布之后进行的,如果您认真对待插件开发,那么您就从事的是构建产品的业务。

因此,您需要以终为始。使用一致的方案来组织文件、命名文件等:

  • 从长远来看简化开发,以便您和贡献的开发人员知道如何管理文件、在哪里放置新文件以及在需要时在哪里查找依赖项
  • 通过提供可以增强插件的通用组织和模式,使维护变得更加容易
  • 提高了将项目扩展到第一个版本之后的能力,而无需在代码库变得笨重时进行大量重构

最重要的是,脚手架应该使开发人员能够轻松地开始处理其产品的核心业务逻辑,而不会妨碍他们。


结论

在本文中,我们回顾了样板文件组织的“原因”,但我们实际上并没有回顾样板文件的“方式”,因此在下一篇文章中我们将仅讨论这一点。

具体来说,我们将使用其中一个样板文件逐步构建一个插件,以便我们能够确定获取样板文件副本并开始开发所需的典型步骤。

WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

38

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

83

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

97

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

223

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

458

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

169

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

246

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

34

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号