0

0

解决 WordPress 自定义区块不显示问题

花韻仙語

花韻仙語

发布时间:2025-11-02 11:03:24

|

783人浏览过

|

来源于php中文网

原创

解决 wordpress 自定义区块不显示问题

本文旨在帮助开发者解决 WordPress 自定义区块在区块插入器中不显示的问题。通过分析常见原因和提供实际案例,我们将重点讲解路径配置错误这一关键因素,并提供相应的解决方案,确保你的自定义区块能够成功加载并使用。

问题诊断与排查

当你在 WordPress 中创建自定义区块后,却发现它并没有出现在区块插入器中,这通常让人感到困惑。在深入研究代码之前,我们需要先进行一些基础的排查,确保问题不在于一些常见的疏忽:

  1. 插件激活状态: 确认你的插件已经正确激活。这是最基本,但也最容易被忽略的一点。
  2. 主题兼容性: 尝试切换到 WordPress 默认主题(如 Twenty Twenty-Three)来排除主题冲突的可能性。
  3. JavaScript 错误: 打开浏览器的开发者工具(通常按 F12 键),查看控制台是否有 JavaScript 错误。这些错误可能会阻止区块的注册。
  4. 缓存问题: 清除浏览器缓存和 WordPress 缓存(如果使用了缓存插件),然后重新加载页面。
  5. 代码检查: 仔细检查你的 JavaScript 和 PHP 代码,确保没有拼写错误或语法错误。

如果经过以上排查,问题依然存在,那么很可能问题出在区块注册的代码上。

关键:正确的路径配置

在自定义区块的注册过程中,一个常见的错误来源是 JavaScript 文件的路径配置不正确。WordPress 需要知道如何找到你的区块 JavaScript 文件,以便在编辑器中加载它。

在问题描述中,开发者使用了 WP_PLUGIN_DIR 来构建 JavaScript 文件的路径:

WP_PLUGIN_DIR . '/ghs-custom-blocks/assets/js/landing-page-block.js'

虽然 WP_PLUGIN_DIR 提供了插件目录的绝对路径,但它并不总是适用于引用插件目录中的资源。更可靠的方法是使用 plugin_dir_url(__FILE__) 函数。plugin_dir_url(__FILE__) 返回当前插件文件的 URL,这通常是构建相对于插件目录的资源 URL 的最佳方式。

解决方案:

芒果商城系统GSHOP
芒果商城系统GSHOP

芒果系统GSHOP 纯静态商城系统,你还在为商城的优化而苦恼?GSHOP是全站纯静态商城系统,一键seo优化功能解决seo问题,自定义URL链接解决商城同质化问题;多页面显示:动态页、伪静态页面、纯静态页面增加收录,提升网站权重,提升流量等。安全稳定、功能强大的商城系统。1、芒果商城系统基于 php5.0开发,企业级应用。2、产品功能Ajax设计,响应速度更快,购物体验更好。3、全新密钥存放机制,

下载

将代码修改为:

plugin_dir_url(__FILE__) . 'assets/js/landing-page-block.js'

完整示例代码:

add_action('init', function() {
    $asset_file = include( plugin_dir_path(__FILE__) . 'assets/js/landing-page-block.asset.php');

    wp_register_script('ghs-landing-page',
        plugin_dir_url(__FILE__) . 'assets/js/landing-page-block.js',
        $asset_file['dependencies'],
        $asset_file['version']);

    register_block_type('ghs/landing-page-block', [
        'api_version' => 2,
        'editor_script' => 'ghs-landing-page',
    ]);
});

解释:

  • plugin_dir_path(__FILE__):获取当前文件(通常是你的插件主文件)所在的目录的绝对路径。
  • plugin_dir_url(__FILE__):获取当前文件所在的目录的 URL。
  • 'assets/js/landing-page-block.js':相对于插件目录的 JavaScript 文件路径。

通过使用 plugin_dir_url(__FILE__),你可以确保 WordPress 能够正确地找到你的 JavaScript 文件,从而使你的自定义区块能够成功加载到区块插入器中。

其他注意事项

  • block.json 文件: 从 WordPress 5.8 开始,推荐使用 block.json 文件来定义你的区块。这是一种更现代、更简洁的方式来注册区块,并且可以避免一些常见的错误。
  • wp-scripts 构建工具: 使用 @wordpress/scripts 包提供的 wp-scripts 构建工具可以简化 JavaScript 代码的编译和打包过程。
  • 调试技巧: 在开发过程中,可以使用 console.log() 在 JavaScript 代码中输出调试信息,或者使用 WordPress 的 WP_DEBUG 模式来查看更详细的错误信息。

总结

自定义区块不显示的问题往往是由于路径配置错误引起的。通过使用 plugin_dir_url(__FILE__) 函数,可以确保 WordPress 能够正确地找到你的 JavaScript 文件。同时,注意其他常见的错误,例如插件激活状态、主题兼容性、JavaScript 错误和缓存问题。通过仔细排查和调试,你一定能够成功解决这个问题,并创建出令人满意的 WordPress 自定义区块。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2676

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1658

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1515

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1419

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1468

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

2

2026.01.19

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 8.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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