laraeast / laravel-settings
Laravel 持久性键值存储
v1.3.0
2023-03-03 21:32 UTC
Requires
- laravel/framework: >=5.2
Requires (Dev)
- mockery/mockery: ^1.4
- orchestra/testbench: >=3.0
This package is auto-updated.
Last update: 2024-08-30 01:34:15 UTC
README
Laravel 持久性设置管理器
- 简单的键值存储
- 支持本地化。
- 使用 Astrotomic/laravel-translatable 结构进行本地化
安装
-
安装包
composer require laraeast/laravel-settings
-
编辑 config/app.php (如果你使用 Laravel 5.5+,则跳过此步骤)
服务提供者
Laraeast\LaravelSettings\Providers\SettingsServiceProvider::class,
类别名
'Settings' => Laraeast\LaravelSettings\Facades\Settings::class,
-
为
database
驱动创建设置表php artisan settings:table php artisan migrate
使用方法
Settings::get('name', 'Computer'); // get setting value with key 'name' // return 'Computer' if the key does not exists Settings::locale('en')->get('name', 'Computer'); // get setting value with key and language Settings::get('name:en', 'Computer'); // get setting value with key and language Settings::set('name', 'Computer'); // set setting value by key Settings::locale('en')->set('name', 'Computer'); // set setting value by key and language Settings::set('name:en', 'Computer'); // set setting value by key and language Settings::has('name'); // check the key exists, return boolean Settings::locale('en')->has('name'); // check the key exists by language, return boolean Settings::has('name:en'); // check the key exists by language, return boolean Settings::delete('name'); // delete the setting by key Settings::locale('en')->delete('name'); // delete the setting by key and language Settings::delete('name:en'); // delete the setting by key and language
处理数组
Settings::get('item'); // return null; Settings::set('item', ['USB' => '8G', 'RAM' => '4G']); Settings::get('item'); // return array( // 'USB' => '8G', // 'RAM' => '4G', // );
使用方法
Settings::locale('en')->set('title', 'Example Website'); Settings::locale('en')->get('title'); // return return 'Example Website'; Settings::set('title:ar', 'عنوان الموقع'); Settings::locale('ar')->get('title'); // return return 'عنوان الموقع'; Settings::locale('ar')->has('title') // bool Settings::locale('ar')->delete('title') App::setLocale('en'); Settings::locale()->get('title'); // return return 'Example Website';
扩展驱动
你可以通过在你的
AppServiceProvider
的register()
方法中添加以下代码来扩展你的自定义驱动
示例
$this->app['settings.manager']->extend('file', function () { return new SettingsFileDriverHandler(); });
注意:你的自定义驱动
SettingsFileDriverHandler
应实现Laraeast\LaravelSettings\Contracts\SettingsStore
接口
<?php
namespace App\LaravelSettings;
use Laraeast\LaravelSettings\Contracts\SettingsStore;
class SettingsFileDriverHandler implements SettingsStore
{
...
}