承接 dwnload/wp-settings-api 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

dwnload/wp-settings-api

最新稳定版本:v3.12.1

Composer 安装命令:

composer require dwnload/wp-settings-api

包简介

A PHP class abstraction that removes all the headaches of the WordPress settings API under the hood and builds a nice options panel on the fly.

README 文档

README

PHP from Packagist Latest Stable Version Total Downloads License Build Status codecov

It's a PHP class wrapper for handling WordPress Settings API.

Package Installation (via Composer)

To install this package, edit your composer.json file:

{ "require": { "dwnload/wp-settings-api": "^3.8" } }

Now run:

$ composer install dwnload/wp-settings-api

Usage Example

@see examples/Example.php

Suggested package

⭐️ frontpack/composer-assets-plugin

As of v3.2.1, this shouldn't be needed any more (unless you are filtering local assets only). Assets will now be loaded via the jsdelivr CDN.

Otherwise, since this is a PHP package and not a WordPress plugin the assets included can't be loaded properly. In order to have the settings page inherit the styles and use the proper JS, you've got to copy the /assets directory to your plugin or theme. Then add the following to filter the asset src to your directory:

<?php declare(strict_types=1); namespace Vendor\Package; use Dwnload\WpSettingsApi\Api\Script; use Dwnload\WpSettingsApi\Api\Style; use Dwnload\WpSettingsApi\WpSettingsApi; use TheFrosty\WpUtilities\Plugin\AbstractHookProvider; use TheFrosty\WpUtilities\Plugin\HooksTrait; /**  * Class WpSettingsApi  *  * @package Dwnload\WpSettingsApi  */ class WpSettingsApiScripts extends AbstractHookProvider { public function addHooks(array $scripts): void { \add_filter(WpSettingsApi::FILTER_PREFIX . 'admin_scripts', [$this, 'adminScripts']); \add_filter(WpSettingsApi::FILTER_PREFIX . 'admin_styles', [$this, 'adminStyles']); } /**  * The default script needs to be moved from the vendor directory somewhere into our app since the  * vendor directory is outside of the doc root.  * @param Script[] $scripts  * @return array  */ public function adminScripts(array $scripts): array { \array_walk($scripts, function (Script $script, int $key) use (&$scripts) { switch ($script->getHandle()) { case WpSettingsApi::ADMIN_SCRIPT_HANDLE: /**  * If you're not using the `TheFrosty\WpUtilities\Plugin\AbstractHookProvider`  * use `plugins_url()` in place of the `$this->getPlugin()->getUrl` or any other WP  * function that will point to the asset.  * (Should match `frontpack/composer-assets-plugin configs`)  */ $scripts[$key]->setSrc($this->getPlugin()->getUrl('assets/js/admin.js')); break; case WpSettingsApi::ADMIN_MEDIA_HANDLE: /**  * If you're not using the `TheFrosty\WpUtilities\Plugin\AbstractHookProvider`  * use `plugins_url()` in place of the `$this->getPlugin()->getUrl` or any other WP  * function that will point to the asset.  * (Should match `frontpack/composer-assets-plugin configs`)  */ $scripts[$key]->setSrc($this->getPlugin()->getUrl('assets/js/wp-media-uploader.js')); break; } $this->registerScript($script); }); return $scripts; } /**  * The default style needs to be moved from the vendor directory somewhere into our app since the  * vendor directory is outside of the doc root.  * @param Style[] $styles  * @return array  */ public function adminStyles(array $styles): array { \array_walk($styles, function (Style $style, int $key) use (&$styles) { if ($style->getHandle() === WpSettingsApi::ADMIN_STYLE_HANDLE) { /**  * If you're not using the `TheFrosty\WpUtilities\Plugin\AbstractHookProvider`  * use `plugins_url()` in place of the `$this->getPlugin()->getUrl` or any other WP  * function that will point to the asset.  */ $styles[$key]->setSrc($this->getPlugin()->getUrl('assets/css/admin.css')); $this->registerStyle($style); } }); return $styles; } /**  * If the script is not registered before being returned back to the filter the src still uses  * the vendor directory file path.  * @param Script $script  */ private function registerScript(Script $script): void { \wp_register_script( $script->getHandle(), $script->getSrc(), $script->getDependencies(), $script->getVersion(), $script->getInFooter() ); } /**  * If the style is not registered before being returned back to the filter the src still uses  * the vendor directory file path.  * @param Style $style  */ private function registerStyle(Style $style): void { \wp_register_style( $style->getHandle(), $style->getSrc(), $style->getDependencies(), $style->getVersion(), $style->getMedia() ); } }

统计信息

  • 总下载量: 12.04k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 11
  • 点击次数: 0
  • 依赖项目数: 6
  • 推荐数: 0

GitHub 信息

  • Stars: 11
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固