Displaying database columns based on current language

ⅰ亾dé卋堺 提交于 2019-11-27 19:22:21

问题


in database i have this:

name_en | name_fr 

When the user select french language - for example - i want to get name_fr field, and the same thing if he chose another language


回答1:


Assuming you set locale in your application using:

App::setLocale($lang);

if you use Eloquent, you can add to your model class accesssor:

public function getNameAttribute($value) {
    return $this->{'name_'.App::getLocale()};
}

and also mutator:

public function setNameAttribute($value) {
    $this->{'name_'.App::getLocale()} = $value;
}

Assuming you added those functions to Content model you can now use:

$content = Content::first(); // find first article
echo $content->name;  // displaying its name

$content->name = 'updated content'; // changing its name
$content->save(); // saving

This will cause displaying and changing name_{$lang} if you set lang using setLocale



来源:https://stackoverflow.com/questions/26036955/displaying-database-columns-based-on-current-language

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!