看了 Taylor Otwell 发表的 Package Auto-Discovery In Laravel 5.5 第一反应是
为啥。。。
也怪我,在开发之前忘记看 5.5 的开发代码动态,之前的文章中也提到过,在 ThinkSNS+开发场景中,我们不可能让用户去 config/app.php 修改配置,所以为了解决加载包的问题,我们开发了 Laravel 服务提供者的增强版可以看 plus/doc/pakcage
是的,增强版的服务提供者,增加功能如下:
可以友好的加载其他「服务提供者」(这在开发包的时候需要依赖其他 laravel 拓展包很有用)
服务提供者转到 composer.json 配置(无需修改配置了)
针对包更友好的 publish ( Laravel 的 vendor:publish 要求输入服务提供者类,我们的只要求输入包名称)
处理器,简化版的命令行,可以用一个函数写一个简单的处理方法。
看到第二个就知道了,和 laravel 5.5 的自动发现类似,我们是在 bootstrap/cache/providers.php 中记录服务提供者信息,而 Laravel 5.5 是在 vendor 目录中查找后写入到 bootstrap/cache/package.php。
是的,我们的实现思路差不多,但我们支持更多功能。从这里读取服务提供者列表,然后在 Illuminate\Foundation\Application::registerConfiguredProviders 函数中合并服务提供者,然后加载,从服务提供者中还可以继续加载服务提供者。
说下我的心情,大概是这样:
开心,高兴,Laravel 更易用了,另一个心情;
惆怅,因为我在 ThinkSNS+中开发了这一特性后,公司包几乎都是以这种方式实现的。
你会说,把这些包配置字段设置下不就好了嘛?可是,在这种方式没定型之前,已经修改过一次,难道一个多月后又要修改一次?惨不忍睹呀!!!我怕我会被揍,想想就有点痛。
今天在群里说这个话题,某开发者:“哈哈,我终于开发了画中画功能”,然后谷歌:“ Android 8 原生支持”。其实道理一样的,并不是因为官方原生支持了不好,而是在纠结,用官方的?还是继续维护自己的?自己的不一定有官方好,官方支持更稳定。
总结,我们觉得废弃掉现在的安装器( bootstrap/cache/providers.php 是由 Composer 安装器插件写入的),然后增加一份代码,从 vendor 目录匹配出来,写入到 bootstrap/cache/package.php 中去,只为 5.5 做准备。来吧!!!
开源代码仓库
GitHub:https://github.com/zhiyicx/thinksns-plus(点击 star,每日关注开发动态。)
咨询 QQ:3298713109
内测申请方式
提供个人/企业联系方式及认证信息(实名 ID /企业营业执照照片或扫描件)及申请说明,发送邮件至 lihecong@zhishisoft.com 即可获得内测资格,申请从速。
欢迎各位关注者通过邮件,以图+文的形式发送至官方邮箱 lihecong@zhishisoft.com 反馈发现的问题,备注机型及系统版本。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.