【源码分析】laravel getXXXAttribute 修改器无效

有时前端问我,为什么你们php 的参数都是下划线的,感觉很不规范啊,你看(Java)其他人的都是驼峰命名。

我说我不管,php 是世界上最好的语言,我就是下划线的。

其实这个问题好像,入行以来都是用下划线的,但是说出一个原因我也说不出来, 今天我遇到了一个比较好解释这种命名的一种,如果有更清楚的小伙伴欢迎留言。

laravel getXXXAttribute 修改器无效

场景是我爬取亚马逊接口,亚马逊的命名都是驼峰命名,比如:ProductDetail

然后我想用修改器对这个字段进行修改,在相应的model设置:

    public function getProductDetailAttribute($extra)
    {
        return json_decode($extra, true);
    }

但是我无论怎么试,就是不行。于是我好好看了一下源码的修改器

laravel getXXXAttribute 对于数据库字段全驼峰命名无效

HasAttributes.php
是修改器的核心,通过正则筛选,当前模型中有多少个符合修改器的条件。

    protected static function getMutatorMethods($class)
    {

        preg_match_all('/(?<=^|;)get([^;]+?)Attribute(;|$)/', implode(';', get_class_methods($class)), $matches);

        return $matches[1];
    }

匹配出了ProductDetai字段,符合修改器条件的。

接着,看到一个操作,至关重要

    public static function cacheMutatedAttributes($class)
    {
        static::$mutatorCache[$class] = collect(static::getMutatorMethods($class))->map(function ($match) {
            return lcfirst(static::$snake```php
    public static function cacheMutatedAttributes($class)
    {
        static::$mutatorCache[$class] = collect(static::getMutatorMethods($class))->map(function ($match) {
            return lcfirst(static::$snakeAttributes ? Str::snake($match) : $match);
        })->all();
    }

```? Str::snake($match) : $match);
        })->all();
    }

也就是把 ProductDetai 转化成了 product_detail

然后再从attributes 去匹配相应的字段,结果没有找到,故不会走上面定义的方法。

就这样被屈服了,然后我把数据库的字段,转为product_detail解决问题。

这个算一个原因:php 为什么用下划线命名吗?

和我做朋友?

已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 酷酷鲨 设计师:CSDN官方博客 返回首页