laravel如何优雅的用LaravelLaravel框架相关

Laravel研究之增加引擎解析模板的扩展名

2018-05-22  本文已影响171人  env107

猫猫应该放在最前


Cat

学前教育

学过laravel的人都知道,在laravel中使用的视图模板引擎blade,来看看官方对blade的简介

Blade 是 Laravel 提供的一个简单而又强大的模板引擎。和其他流行的 PHP 模板引擎不同,Blade 并不限制你在视图中使用原生 PHP 代码。所有 Blade 视图文件都将被编译成原生的 PHP 代码并缓存起来,除非它被修改,否则不会重新编译,这就意味着 Blade 基本上不会给你的应用增加任何负担。Blade 视图文件使用 .blade.php 作为文件扩展名,被存放在 resources/views 目录。

正因为blade的强大之处,因此在laravel环境开发中,我们经常会使用到blade。

今天的重点并不是blade,而是视图模板的扩展名,有的开发者在拿到来自前端的静态页面之后会懒得更改模板的扩展名,而又不想新建文件做着复制粘贴的工作(就像我),因此尝试往框架中新增加扩展名解析是有必要的。

由于laravel的开发人员也考虑到模板扩展名的问题,因此在构建框架当中为我们提供了一个方便维护的数组,只需要在该数组中指明解析扩展名文件的引擎,我们就可以让blade解析我们的扩展文件了,以下是数组示例:

protected $extensions = [
        'blade.php' => 'blade',
        'php' => 'php',
        'css' => 'file',
    ];

从数组中我们可以猜到,该数组以键名作为文件的扩展名,以键值作为文件扩展名的解析引擎的形式声明。

了解思路

修改一个框架的源代码需要你有强大的阅读框架代码的能力,通过这样一个修改扩展名解析的小需求,该从那里入手呢?

我们知道,laravel中,如果指定渲染一个视图模板,可以使用helpers.php当中提供的View方法,该方法干了什么事情,我们看代码

function view($view = null, $data = [], $mergeData = [])
    {
        $factory = app(ViewFactory::class); //通过服务提供者获取视图工厂对象

        if (func_num_args() === 0) {
            return $factory;
        }
        return $factory->make($view, $data, $mergeData);
    }

从代码中我们可以知道,其实就是通过视图工厂去生成一个视图对象,并返回。
如果你尝试打印$factory对象,你就可以很清楚的看到对象所在的位置。

"Illuminate\View\Factory"

通过打印对象我们可得知该对象的文件位置,该文件在

[网站根目录]/vendor/laravel/framework/src/Illuminate/View/Factory.php

打开该文件,浏览对象的相关属性,我们可以找到一个类似跟文件扩展名有关的数组,这个数组就是我们上面展示的示例数组

/**
     * The extension to engine bindings.
     *
     * @var array
     */
    protected $extensions = [
        'blade.php' => 'blade',
        'php' => 'php',
        'css' => 'file',
    ];

从官方的注释中我们可以了解到,该数组的作用就是绑定扩展名的解析引擎。
但是该数组只是声明了扩展名的解析引擎,并没有明确的指明模板文件解析的扩展名有哪些。
我们试着增加一个模板解析

    protected $extensions = [
        'blade.php' => 'blade',
        'php' => 'php',
        'css' => 'file',
        //增加blade.html的扩展名
        'blade.html'=>'blade',
    ];

然后保存文件,然后将项目中的一个模板文件扩展名更改为.blade.html,我在项目中将我的主布局文件扩展名改成.blade.html

更改扩展名

接着引入布局文件


引入布局文件

现在我们开始运行程序
哎呀~~报错了!!


错误

程序不是我们预期得到的效果,不过这并不影响,laravel提供了强大的调试工具,我们可以很清晰的知道代码那里出问题了,从打印的错误中我们可以知道

View [layout] not found. (View: /home/vagrant/Code/demo1/resources/views/create.blade.php)

提示视图layout不存在。我们再从右边代码提示信息中可以看到,抛出异常的是在findInPaths()该方法中,其所在的文件是

/laravel/framework/src/Illuminate/View/FileViewFinder.php

我们找到该文件中对应的代码行


FileViewFinder.php
$this->getPossibleViewFiles()
getPossibleViewFiles()

看吧,我们很清晰的找到了拼接扩展名文件的地方,我们仿佛已经看到胜利的曙光了~
我们再追索$this->extensions属性,呵!找到了


extensions

从官方的注释中也可以很清晰的了解到,该数组就是注册视图扩展名的数组,现在总算没找错对象了 XD

现在我们为数组增加新的扩展项

protected $extensions = ['blade.php', 'php', 'css','blade.html'];

保存文件之后刷新浏览器,哇哦~终于达到预期的效果了,该扩展名的模板很顺利的被blade解析出来了


success.jpg

总结

其实小编也是刚开始学习laravel框架,正好在练习的项目中想到该需求,其实这只是简单的一次修改,通过这次的研究和学习,我这个新人也对laravel有着进一步的了解,也开始尝试阅读更多核心主体的代码。
第一次写的技术类文章,不太清楚写作套路,反正按着我自己的思路来写吧,如果有技术大牛路过也请多多包容。

上一篇下一篇

猜你喜欢

热点阅读