Voyager Relationships 的多语言翻译实现

聖光之護
发布: 2025-09-25 15:44:16
原创
660人浏览过

voyager relationships 的多语言翻译实现

在使用 Laravel Voyager 管理后台时,实现 relationships 的多语言翻译是一个常见的需求。本文将介绍如何在 Voyager 中正确配置和使用 Translatable trait,以确保在处理 belongsToMany 和 hasMany 等关系时,能够根据当前应用语言环境显示翻译后的数据。通过示例代码和详细步骤,帮助开发者解决关系数据无法翻译的问题,并提供一种在 Blade 模板中正确访问翻译后关系数据的方法。

模型配置:使用 Translatable trait

首先,确保你的模型使用了 TCG\Voyager\Traits\Translatable trait,并且正确定义了 $translatable 属性。这个属性是一个数组,包含了需要进行翻译的字段。

例如,对于 Process、WorkMachine 和 Product 模型,你的配置应该如下:

Process Model:

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use TCG\Voyager\Traits\Translatable;

class Process extends Model
{
    use Translatable;

    protected $translatable = ['name', 'meta_description', 'description'];

    public function get_workmachine() {
        return $this->belongsToMany(WorkMachine::class, 'process_workmachine');
    }

    public function get_products() {
        return $this->hasMany(Product::class, 'process_product');
    }
}
登录后复制

WorkMachine Model:

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use TCG\Voyager\Traits\Translatable;

class WorkMachine extends Model
{
    use Translatable;

    protected $translatable = ['name', 'meta_description', 'description'];
}
登录后复制

Product Model:

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use TCG\Voyager\Traits\Translatable;

class Product extends Model
{
    use Translatable;

    protected $translatable = ['name'];
}
登录后复制

控制器中的数据获取

在控制器中,你需要确保获取到的数据已经进行了翻译。可以直接在查询结果上调用 translate() 方法,并传入当前应用的 locale。

$process = App\Models\Process::where('slug', $processSlug)
                    ->with('get_workmachine')
                    ->with('get_products')
                    ->firstOrFail()->translate(app()->getLocale());
登录后复制

尝试使用 -youjiankuohaophpcnwith(['get_workmachine' => function ($query) { $query->withTranslation('de'); }]) 预加载翻译可能不会直接生效,因为关系本身可能没有被正确翻译。

ViiTor实时翻译
ViiTor实时翻译

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。

ViiTor实时翻译 116
查看详情 ViiTor实时翻译

Blade 模板中的正确用法

在 Blade 模板中,访问 relationship 时,需要对 relationship 的结果进行翻译。如果直接访问 relationship 返回的是一个集合或对象,你需要对集合中的每个元素或对象调用 translate() 方法。

错误示例:

@foreach(json_decode($process->get_workmachine) as $workmachine)
    ...
    ...
@endforeach
登录后复制

正确示例:

@foreach($process->get_workmachine as $workmachine)
    {{ $workmachine->translate(app()->getLocale())->name }}
@endforeach
登录后复制

或者,如果需要将整个集合转换为 JSON,再在前端解析,也需要先对集合进行翻译:

@foreach(json_decode($process->get_workmachine->translate(app()->getLocale())) as $workmachine)
    ...
    ...
@endforeach
登录后复制

解释:

  • $process->get_workmachine 返回的是 WorkMachine 模型的集合。
  • $workmachine->translate(app()->getLocale()) 对单个 WorkMachine 模型实例进行翻译,返回翻译后的实例。
  • ->name 访问翻译后的 WorkMachine 模型的 name 属性。

注意事项

  • 确保你的数据库中已经存在相应语言的翻译数据。
  • 检查 config/voyager.php 中的 multilingual.enabled 是否设置为 true,以及 multilingual.default 是否设置为你的默认语言。
  • 如果仍然无法正常显示翻译,尝试清除缓存:php artisan cache:clear 和 php artisan config:cache。
  • 如果使用了自定义的 relationship 方法(如 get_workmachine()),请确保这些方法返回的是 Eloquent relationship 对象,而不是直接返回数据。

总结

通过正确配置模型中的 Translatable trait,并在控制器和 Blade 模板中合理使用 translate() 方法,可以有效地实现 Voyager 中 relationships 的多语言翻译。关键在于理解何时以及如何对关系数据进行翻译,并确保你的代码能够正确访问翻译后的属性。

以上就是Voyager Relationships 的多语言翻译实现的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号