【问题标题】:Laravel 5: directory-elements sort by name in a hasMany relationshipLaravel 5:目录元素在 hasMany 关系中按名称排序
【发布时间】:2018-04-22 08:51:20
【问题描述】:

我需要按关系 langs() 对文件夹 ($data['contents']) 进行排序,其中 lang_id == 1 我该怎么做?谢谢。

在模型文件夹中:

class Folder extends Model
{
    protected $fillable = ['active', 'date', 'path', 'slug'];

    public function langs()
    {
        return $this->hasMany('App\Models\LangFolder');
    }

}

在模型 LangFolder 中:

class LangFolder extends Model
{
    protected $fillable = ['folder_id', 'lang_id', 'name', 'description'];

    public function folder()
    {
        return $this->belongsTo('App\Models\Folder');
    }
}

在控制器中:

public function folders()
{
    // Sort folders ($data['contents']) by relationship langs() where lang_id == 1

    $data['folders'] = Folder::all();
    $data['langs'] = Lang::all();

    $directory = 'library/';
    $elements =  array_diff(scandir($directory), array('..', '.'));

    foreach($elements as $element) {
        if (is_dir($directory . '/' . $element)) {
            $content_element = Folder::where('slug', $element)->first();
            $data['contents'][] = $content_element;
        }
    }

    return view('web.library.index', compact('data'));
}

【问题讨论】:

  • Folder::langs()->where('langs.id, '=' 1)->orderBy(FIELD ON LANG)怎么样

标签: laravel sorting directory relationship


【解决方案1】:

如果要从关系中订购,则必须使用Collection 而不是Eloquent,例如:

$orderedLangs = $folder->langs->sortBy('lang_id');

【讨论】:

    【解决方案2】:

    我终于将关系的字段“名称”添加到数组中,并将数组转换为集合,然后按“名称”排序,不区分大小写。也许还有另一种更清洁的解决方案。这有效:

    控制器:

        foreach($elements as $element){
                if(is_dir($directory.'/'.$element)){
                    $content_element = Folder::where('slug', $element)->first();
                    $contenidos[] = $content_element;
                }else{
                    $data['documents'][] = Document::where('path', $directory.'/'.$element)->first();
                }
            }
    
       foreach($contenidos as $contenido){
            foreach($contenido->langs as $lang){
                if($lang->lang_id == '1'){
                    $contenido->name = $lang->name;
                }
            }
            $data['contents'][]= $contenido;
        }
    
    $data['contents']=collect($data['contents'])->sortBy('name', SORT_NATURAL|SORT_FLAG_CASE);
    

    【讨论】:

      猜你喜欢
      • 2015-04-22
      • 2022-01-10
      • 2016-02-23
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-05-14
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多