简体   繁体   English

排序json数组如何导致codeigniter 4

[英]How sort json array result in codeigniter 4

if mind, anyone can tell me how to sort by created_at on json array.如果介意,任何人都可以告诉我如何在 json 数组上按 created_at 排序。 I want the newest comment on top, not on the bottom.我想要最新的评论在顶部,而不是底部。 Here is my code :这是我的代码:

Model (to insert and get comment data):模型(插入和获取评论数据):

    public function add_komen($data){
            return $this->komen->insert($data);
    }

    public function get_komen($id){
            return $this->komen->where('id_user', $id)->get()->getResultArray();
        
 }

Controller (get data & get result using array for views):控制器(获取数据并使用视图数组获取结果):

public function do_add_komentar(){
        $data['nama_komentar'] = $this->request->getPost('nama');
        $data['isi_komentar'] = $this->request->getPost('komentar');
        $data['id_user'] = $_SESSION['id_user'];

        $update = $this->UndanganModel->add_komen($data);
        if($update){
            echo json_encode(array('status' => 'sukses','nama' => \esc($data['nama_komentar']),'komentar' => \esc($data['isi_komentar']) ));
        }else{
            echo json_encode(array('status' => 'gagal'));
        }
}

Views (Form & Get Result):视图(表单和获取结果):

<input id="nama" type="text" class="form-control mt-2" placeholder="Nama Anda" required>
<textarea id="komentar" class="form-control" id="exampleFormControlTextarea1" placeholder="Pesan anda.." rows="3" required></textarea>
<button id="submitKomen" class="btn btn-primary btn-block" >Kirim</button>

<div class="layout-komen">              
                <?php  foreach($komen as $key => $data) { ?>
                <div class="komen" >
                    <div class="col-12 komen-nama">
                        <?= \esc($data['nama_komentar']); ?>
                    </div>
                    <div class="col-12 komen-isi">
                        <?= \esc($data['isi_komentar']); ?>
                    </div>
                </div>
                <?php } ?> 
</div>
    

You have no need to sort json array.您无需对 json 数组进行排序。 This can be achieved simply by sorting for created_at in your model function for get result.这可以通过在模型函数中对 created_at 进行排序以获得结果来实现。 I am assuming that created_at is column name in your table.我假设 created_at 是您表中的列名。 if not then replace created_at with the column name.如果不是,则将 created_at 替换为列名。 See code here在这里查看代码

 public function get_komen($id){

   return $this->komen->where('id_user', $id)->orderBy("created_at", "desc")->get()->getResultArray();
        
 }

check and reply检查并回复

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM