0

0

自定义 Blade 指令实现静态资源路径配置

花韻仙語

花韻仙語

发布时间:2025-10-16 13:12:02

|

926人浏览过

|

来源于php中文网

原创

自定义 blade 指令实现静态资源路径配置

本文介绍了如何在 duncan3dc/blade 模板引擎中静态添加自定义指令,以实现对 CSS 和 JavaScript 资源路径的预定义和便捷引用。通过示例代码,详细讲解了利用 `Blade::directive` 方法以及 `assetify` 函数自定义指令的多种实现方式,旨在帮助开发者更灵活地管理和使用静态资源。

在使用 duncan3dc/blade 模板引擎时,有时需要自定义指令来简化模板编写,特别是对于静态资源(如 CSS 和 JavaScript)的引用。 默认情况下,模板引擎可能没有提供直接修改资源路径的配置项,因此需要手动添加指令来实现。以下介绍几种静态添加指令的方法,以便在 Blade 模板中方便地使用预定义的资源路径。

方法一:使用 Blade::directive 自定义指令

Blade::directive 方法允许你定义新的 Blade 指令。 这种方法简单直接,但需要手动处理资源路径的拼接。

use duncan3dc\Laravel\Blade;

Blade::directive('css', function($parameter){
    return "";
});

// 使用示例:
// 在 Blade 模板中使用 @css('style.css')
// 将会输出: 

注意事项:

Facet
Facet

Facet.ai是一款AI图像生成和编辑工具,具备实时图像生成和编辑功能

下载
  • 这种方法需要硬编码资源路径,不够灵活。
  • 无法利用 assetify 函数的优势,例如处理外部资源链接。

方法二:复制 assetify 函数并自定义指令

assetify 函数负责处理资源路径的拼接和转换,但它是 Directives 类的私有方法。 为了利用其功能,可以将 assetify 函数的代码复制出来,并自定义指令。

use duncan3dc\Laravel\Blade;

function assetify(string $file, string $type, string $path): string
{
    // 复制 Directives->assetify 的代码
    $file = trim($file, "\"'");

    if (preg_match("#^(https?:)?//#i", $file)) {
        return $file;
    }

    if (substr($file, 0, 1) !== "/") {
        $file = "/" . $path . "/" . $file;
    }

    $file = str_replace(" ", "%20", $file);

    return $file . "?" . filemtime(getcwd() . $file);
}

Blade::directive('css', function($parameter){
    $file = assetify($parameter, "css", 'assets/css');
    return "";
});

Blade::directive('js', function($parameter){
    $file = assetify($parameter, "js", 'assets/js');
    return "";
});

// 使用示例:
// 在 Blade 模板中使用 @css('style.css')
// 将会输出:  (时间戳会根据文件修改时间变化)

注意事项:

  • 需要手动维护 assetify 函数的代码,当 Directives 类中的 assetify 函数发生变化时,需要同步更新。

方法三:使用反射绕过访问权限

可以使用 PHP 的反射机制来访问 Directives 类的私有方法 assetify。 这种方法可以确保使用最新版本的 assetify 函数,避免手动维护代码。

use duncan3dc\Laravel\Directives;
use duncan3dc\Laravel\Blade;

function assetify(string $file, string $type, string $path): string
{
    static $assetify;
    if(!$assetify){
        $assetify = new \ReflectionMethod(Directives::class, 'assetify');
        $assetify->setAccessible(true);
    }
    return $assetify->invoke(new Directives, $file, $type, $path);
}

Blade::directive('css', function($parameter){
    $file = assetify($parameter, "css", 'assets/css');
    return "";
});

Blade::directive('js', function($parameter){
    $file = assetify($parameter, "js", 'assets/js');
    return "";
});

// 使用示例:
// 在 Blade 模板中使用 @css('style.css')
// 将会输出:  (时间戳会根据文件修改时间变化)

注意事项:

  • 使用反射可能会带来性能损耗。
  • 依赖于 Directives 类的内部实现,如果 assetify 方法被移除或重命名,代码将会失效。

总结

以上三种方法都可以实现静态添加 Blade 指令,以便在模板中方便地引用静态资源。选择哪种方法取决于具体的需求和偏好。

  • 如果对资源路径的处理要求不高,可以选择第一种方法,简单直接。
  • 如果需要利用 assetify 函数的优势,可以选择第二种或第三种方法。 第二种方法需要手动维护代码,第三种方法使用反射,可以确保使用最新版本的 assetify 函数。

无论选择哪种方法,都需要仔细测试,确保指令能够正确地工作。

相关专题

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

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

2788

2023.09.01

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

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

1686

2023.10.11

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

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

1548

2023.10.11

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

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

1016

2023.10.23

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

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

1485

2023.10.23

html怎么上传
html怎么上传

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

1256

2023.11.03

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

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

1569

2023.11.09

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

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

1307

2023.11.13

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 22.2万人学习

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

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