如何使用自定义方法$table->myMethod()扩展Laravel 5.5/5.6 MySQL Blueprint,类似于预构建的方法$table->timestamps();?
我已经尝试了一个SQLlite示例:Laravel 5中SQLite蓝图的扩展 ,但是我无法使其工作。我正在开发自己的软件包(使用软件包开发最佳实践),并希望从其中包括蓝图扩展。
我的开发软件包有 Laravel 扩展文件夹 "Extension": ./packages/vendorname/packagename/src/Extension/
有文件:
1) ./packages/vendorname/packagename/src/Extension/Blueprint.php
我该如何在迁移中使用标准的"use Illuminate\Database\Schema\Blueprint;",因为我不想使用"use Vendorname\Packagename\Extension\Blueprint;"。另外,在运行迁移“php artisan migrate:refresh”时,我遇到了错误。
我已经尝试了一个SQLlite示例:Laravel 5中SQLite蓝图的扩展 ,但是我无法使其工作。我正在开发自己的软件包(使用软件包开发最佳实践),并希望从其中包括蓝图扩展。
我的开发软件包有 Laravel 扩展文件夹 "Extension": ./packages/vendorname/packagename/src/Extension/
有文件:
1) ./packages/vendorname/packagename/src/Extension/Blueprint.php
<?php
namespace Vendorname\Packagename\Extension;
use Illuminate\Database\Schema\Blueprint as ParentBlueprint;
use Illuminate\Support\Facades\DB;
class Blueprint extends ParentBlueprint
{
public function myMethod()
{
$this->text('custom_column')->default('Some value');
$this->text('custom_column2')->default('Some value2');
}
}
2) ./packages/vendorname/packagename/src/Extension/MySqlConnection.php
2)./packages/vendorname/packagename/src/Extension/MySqlConnection.php<?php
namespace Vendorname\Packagename\Extension;
use Vendorname\Packagename\Extension\Blueprint;
use Illuminate\Database\MySqlConnection as ParentMySqlConnection;
use Illuminate\Database\Schema\MySqlBuilder;
class MySqlConnection extends ParentMySqlConnection
{
public function getSchemaBuilder()
{
if (is_null($this->schemaGrammar)) {
$this->useDefaultSchemaGrammar();
}
$builder = new MySqlBuilder($this);
$builder->blueprintResolver(function ($table, $callback) {
return new Blueprint($table, $callback);
});
return $builder;
}
}
我的包有服务提供者:./packages/vendorname/packagename/src/VendornamePackagenameServiceProvider.php,其中包含register()方法:
public function register()
{ if ($this->app->config->get('vendorname-packagename') === null) {
$this->app->config->set('vendorname-packagename', require __DIR__.'/../config/vendorname-packagename');
}
$this->app->bind('db.connection.mysql', Vendorname\Packagename\Extension\MySqlConnection::class);
}
此外,我的软件包还有迁移文件:./packages/vanilla/vanilla-admin/src/migrations/2018_02_07_213437_create_logs_table.php
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
//use Vendorname\Packagename\Extension\Blueprint;
use Illuminate\Database\Migrations\Migration;
class CreateLogsTable extends Migration
{
public function up()
{
Schema::create('logs', function (Blueprint $table) {
$table->increments('id');
$table->text('package');
$table->longText('log');
$table->myMethod();
$table->timestamps();
});
}
public function down()
{
Schema::dropIfExists('logs');
}
}
我该如何在迁移中使用标准的"use Illuminate\Database\Schema\Blueprint;",因为我不想使用"use Vendorname\Packagename\Extension\Blueprint;"。另外,在运行迁移“php artisan migrate:refresh”时,我遇到了错误。
Type error: Argument 1 passed to CreateLogsTable::{closure}() must be a
n instance of Vanilla\VanillaAdmin\Extension\Blueprint, instance of Ill
uminate\Database\Schema\Blueprint given, called in /Users/raido/.compos
er/vendor/bin/laravel-packages/vendor/laravel/framework/src/Illuminate/
Database/Schema/Builder.php on line 164
请帮我找到解决方案。我在互联网上搜索并测试了一整天,但仍然无法使其正常工作 :(