Magento 2:在订单详情页添加自定义按钮并实现功能

magento 2:在订单详情页添加自定义按钮并实现功能

本文档详细介绍了如何在 Magento 2 后台的订单详情页面添加一个自定义按钮,并配置其点击后的功能。通过创建自定义模块、配置路由、控制器和插件,可以实现自定义按钮的添加和功能的实现,并提供了完整的代码示例和配置步骤。

创建自定义模块

首先,创建一个自定义模块来实现所需的功能。按照 Magento 2 的模块结构,创建以下文件:

注册文件 (registration.php)

<?phpMagentoFrameworkComponentComponentRegistrar::register(    MagentoFrameworkComponentComponentRegistrar::MODULE,    'MG_Dropship',    __DIR__);

该文件用于注册模块。

模块配置文件 (etc/module.xml)

    

该文件定义了模块的基本信息,例如模块名称和版本。

配置依赖注入 (di.xml)

使用 di.xml 文件配置依赖注入,以便在订单详情页面添加自定义按钮。

             

这个配置将 MGDropshipPluginSalesBlockAdminhtmlOrderButton 插件应用到 MagentoSalesBlockAdminhtmlOrderView 块,允许我们修改订单详情页面的行为。

配置路由 (routes.xml)

为了处理自定义按钮的点击事件,需要配置路由。

                                    

该文件定义了一个名为 mg_dropship 的路由,其 frontName 为 mg_dropship。

创建控制器 (Controller/Adminhtml/Order/Index.php)

创建一个控制器来处理按钮点击后的逻辑。

orderRepository = $orderRepository;        $this->logger = $logger;        parent::__construct($context);    }    /**     * Execute action     *     * @throws MagentoFrameworkExceptionLocalizedException|Exception     */    public function execute()    {        $orderId = $this->getRequest()->getParam('order_id');        $resultRedirect = $this->resultFactory->create(ResultFactory::TYPE_REDIRECT);        try {            $order = $this->orderRepository->get($orderId);            // TODO: Do something with the order            $this->messageManager->addSuccessMessage(__('We did something!'));        } catch (MagentoFrameworkExceptionLocalizedException $e) {            $this->messageManager->addErrorMessage($e->getMessage());        } catch (Exception $e) {            $this->messageManager->addErrorMessage(__('We can't process your request' . $e->getMessage()));            $this->logger->critical($e);        }        return $resultRedirect->setPath(            'sales/order/view',            [                'order_id' => $orderId            ]        );    }    /**     * @return bool     */    protected function _isAllowed()    {        return $this->_authorization->isAllowed('MG_Dropship::order_dosomething');    }}

这个控制器获取订单ID,执行一些操作(TODO部分),并重定向回订单详情页面。

创建插件 (Plugin/Adminhtml/Order/Button.php)

创建一个插件来向订单详情页面添加自定义按钮。

getOrder()) {            $message = __('Are you sure you want to Do Something?');            $subject->addButton(                'do_something',                [                    'label' => __('Do Something'),                    'class' => 'do_something',                    'onclick' => "confirmSetLocation('{$message}', '{$subject->getUrl('mg_dropship/order/index', ['order_id' => $subject->getOrder()->getId()])}')"                ]            );        }    }}

这个插件使用 beforeSetLayout 方法在订单详情页面添加一个名为 “Do Something” 的按钮。点击该按钮会弹出一个确认对话框,然后重定向到 mg_dropship/order/index 路由,并传递订单ID。

清理缓存和重新部署

完成以上步骤后,需要清理 Magento 2 的缓存并重新部署静态内容。

php bin/magento cache:cleanphp bin/magento setup:upgradephp bin/magento setup:di:compilephp bin/magento setup:static-content:deploy -f

注意事项

确保模块已启用。检查文件路径和命名空间是否正确。根据实际需求修改控制器中的逻辑。如果开启了 “Add Secret Key to URLs”,请确保URL包含正确的 Form Key。

总结

通过以上步骤,你可以在 Magento 2 后台的订单详情页面成功添加一个自定义按钮,并配置其点击后的功能。这个方法可以扩展到其他页面和功能,实现更复杂的自定义需求。

以上就是Magento 2:在订单详情页添加自定义按钮并实现功能的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月11日 07:15:35
下一篇 2025年12月11日 07:15:50

相关推荐

  • PHP集成Sign in with Apple:重定向URL处理详解

    本文详细探讨了在PHP后端实现Sign in with Apple时,如何正确处理授权重定向以获取code参数。核心问题通常源于redirect_uri配置不精确,特别是在子域名(如www)的使用上。教程将指导开发者理解response_mode=form_post的工作原理,并强调确保redire…

    好文分享 2025年12月11日
    000
  • CodeIgniter 4 重定向函数传递参数的技巧与扩展

    本文旨在解决在 CodeIgniter 4 中使用命名路由进行重定向时,如何传递参数的问题。通过分析 redirect() 函数的源码和 route() 方法的特性,提供了一种扩展 redirect() 函数,使其能够传递参数的解决方案,从而满足更灵活的路由需求。 在 CodeIgniter 4 中…

    2025年12月11日
    000
  • Laravel 控制器方法参数传递:正确获取 URL 查询字符串

    本教程详细阐述了在 Laravel 应用中,如何正确地从 URL 查询字符串中获取动态参数并传递给控制器方法。通过使用 Laravel 的 Request 对象,开发者可以安全、高效地访问请求数据,从而实现如文章点赞类型(心形或手指)等动态功能的处理。文章将提供清晰的代码示例和最佳实践,帮助您优化参…

    2025年12月11日
    000
  • Laravel WebSockets 安装问题解决指南

    本文旨在帮助开发者解决在 Laravel 项目中安装 beyondcode/laravel-websockets 包时遇到的依赖冲突问题。通过移除 composer.lock 文件并重新安装依赖,可以有效解决版本不兼容导致的安装失败,确保 WebSocket 功能的顺利集成。 在 Laravel 项…

    2025年12月11日
    000
  • 在 WooCommerce 产品页面显示特色产品标签

    本文介绍了如何在 WooCommerce 产品页面上,使用 WooCommerce 内置的特色产品功能,显示 “Featured” 标签。通过 wc_get_featured_product_ids() 函数获取特色产品 ID 数组,并判断当前产品是否在其中,从而动态显示标签…

    2025年12月11日
    000
  • 如何在 WooCommerce 产品页面显示特色产品标签

    本文将介绍如何在 WooCommerce 产品页面上,根据产品是否被设置为特色产品,动态显示 “Featured” 标签。我们将利用 WooCommerce 内置的特色产品功能,避免使用自定义字段,并通过代码示例演示如何在产品摘要之前添加该标签,只需在子主题的 functio…

    2025年12月11日
    000
  • 使用 WooCommerce 内置功能显示特色商品标签

    本文将介绍如何在 WooCommerce 单品页面中,利用 WooCommerce 内置的特色商品功能,显示一个“特色”标签。我们将使用 wc_get_featured_product_ids() 函数来判断当前商品是否为特色商品,并根据判断结果显示相应的标签。避免使用自定义字段,简化操作流程。 利…

    2025年12月11日
    000
  • 在 WooCommerce 产品页面显示精选产品标签

    本文将介绍如何在 WooCommerce 产品页面上,根据产品是否被设置为精选产品,动态显示一个“Featured”标签。我们将使用 wc_get_featured_product_ids() 函数来判断产品是否为精选产品,并在产品摘要之前显示相应的标签。本文提供了详细的代码示例和步骤,帮助你轻松实…

    2025年12月11日
    000
  • CodeIgniter 4:优化视图层数据处理,避免直接数据库操作

    本教程旨在解决CodeIgniter 4应用中视图层直接执行数据库查询的问题,这种做法违反了MVC设计模式的核心原则。我们将探讨为何应避免在视图中进行数据请求,并提供一套专业的解决方案,通过在控制器或服务层预处理数据,确保视图仅负责渲染已准备好的数据,从而提升代码的可维护性、可测试性和整体架构的清晰…

    2025年12月11日
    000
  • 在Apache2中基于主机和请求URI设置环境变量并处理重定向影响

    本文探讨了在Apache2环境下,使用SetEnvIfExpr基于主机和请求URI设置环境变量时遇到的常见问题,特别是当mod_rewrite进行内部重定向时,PHP端无法直接获取变量的现象。核心内容是揭示Apache在内部重定向后会将环境变量名称自动添加REDIRECT_前缀,并提供了正确的访问方…

    2025年12月11日
    000
  • 如何在PHP中实现文件锁?通过flock防止并发冲突

    flock()函数用于实现文件锁,通过共享锁(LOCK_SH)和独占锁(LOCK_EX)协调多进程对文件的并发访问,防止竞态条件导致的数据损坏或不一致;其基于建议性锁定机制,需所有访问方共同遵守锁规则,且在NFS等网络文件系统中可能存在兼容性问题,同时应防范阻塞、死锁及异常未释放锁等风险,确保在操作…

    2025年12月11日
    000
  • 在PHP中获取需要认证的远程文件内容

    本文旨在解决PHP中无法使用file_get_contents访问带认证的远程文件的问题。我们将详细介绍如何利用cURL库来安全地发起HTTP请求,并处理基本的HTTP认证机制(如用户名/密码),从而成功获取并处理远程服务器上的XML或其他类型文件。教程将包含示例代码、关键参数解释以及错误处理方法,…

    2025年12月11日
    000
  • PHP连接Amazon PA-API:深入理解fopen错误与API调用调试

    本教程旨在解决PHP集成Amazon Product Advertising API (PA-API)时遇到的Fatal Error。通过分析fopen函数失败的根本原因,特别是@错误抑制符的陷阱,本文将指导开发者如何正确调试API连接问题,并推荐使用更健壮的HTTP客户端如cURL进行API交互,…

    2025年12月11日
    000
  • PHP 8.1+ 枚举(Enum)值获取与高级管理实践

    本教程详细介绍了在 php 8.1 及更高版本中如何高效地获取枚举(enum)的所有成员名称和支持值(backed values)。文章首先阐述了通过 cases() 方法结合 array_column 获取基本名称和支持值的方法,随后深入探讨了如何利用 trait 模式构建可复用的功能,以实现枚举…

    2025年12月11日
    000
  • PHP 8.1+ 枚举:高效获取所有成员名称与值的实践指南

    本教程深入探讨PHP 8.1及更高版本中枚举类型(Enum)的成员获取方法。我们将详细介绍如何利用cases()方法结合array_column函数,高效地提取枚举的所有成员名称和值,并提供一个可复用的EnumToArray Trait,以封装这些常用操作,从而提升代码的简洁性和可维护性。 PHP …

    2025年12月11日
    000
  • PayPal Express Checkout 交易ID获取与退款操作指南

    本教程详细阐述了在PayPal Express Checkout流程中,如何正确获取并管理交易ID以进行退款操作。核心在于交易ID并非由getExpressCheckoutDetails返回,而是通过doExpressCheckoutPayment成功完成支付后获得。文章强调了存储交易ID的重要性,…

    2025年12月11日
    000
  • 使用纯JavaScript实现基于多条件输入的PHP生成表格筛选

    本教程详细介绍了如何使用纯JavaScript实现对PHP动态生成的HTML表格进行多条件(AND逻辑)筛选。针对现有单条件筛选代码的局限性,文章提供了一种通过绑定多个输入框到特定列、并实时应用所有非空筛选条件来精确匹配表格行的解决方案,旨在提升用户体验和数据检索效率。 理解现有代码的局限性 在we…

    2025年12月11日
    000
  • PayPal Express Checkout 交易ID获取与退款策略

    本文详细阐述了PayPal Express Checkout流程中交易ID的正确获取方法与管理策略。核心指出交易ID并非通过getExpressCheckoutDetails获取,而是在doExpressCheckoutPayment调用成功后返回。为确保后续退款操作的顺畅,强烈建议开发者在交易完成…

    2025年12月11日
    000
  • 将HTML代码转换为包含JavaScript的PHP变量的正确方法

    将HTML代码转换为包含JavaScript的PHP变量,是Web开发中常见的需求。然而,由于HTML属性、JavaScript代码以及PHP变量都可能包含引号,因此很容易出现语法错误。关键在于正确处理字符串的引号和转义,避免字符串提前结束。 第一段:本文旨在解决将包含JavaScript的HTML…

    2025年12月11日
    000
  • 使用 Amp 并发处理循环中的 Promise

    正如摘要所说,本文旨在解决在使用 Amp 进行异步编程时,在循环中处理 Promise 时遇到的阻塞问题。在异步编程中,我们经常需要在循环中发起多个异步操作,并等待它们全部完成。然而,如果直接在循环中使用 yield 等待 Promise,会导致循环阻塞,无法充分利用异步的优势。 下面我们通过一个示…

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信