(Yii2)如何将表格中的值传递给HTML按钮

时间:2018-11-14 08:00:49

标签: yii2

我是Yii2的新手,目前我在admin部分工作,在该部分中admin可以更新典型的网页,在本例中为“关于我们”页面。应用程序将检查“关于”表中是否已经存在一行。如果是这样,则“更新”按钮将显示在视图的索引页面中,因为“关于我们”部分仅允许一个内容。否则,将显示“创建”按钮。 gridview中的更新工作正常,但我想知道如何将表中的“ id”值传递到更新按钮,因为我不断收到错误消息“缺少必需的参数id”。我花了整整一整天,但仍然坚持。预先感谢您的帮助。

这是我的索引的样子:

<?php
 if(!$dataProvider)
        {
            echo Html::a('Create', ['create'], ['class' => 'btn btn-success']) ;
        }
        else
        {   

            echo Html::a('Update-about', ['update'], ['class' => 'btn btn-success']);
        }
        ?>
    </p>
    <?= GridView::widget([
        'dataProvider' => $dataProvider,
        'filterModel' => $searchModel,
        'columns' => [
            ['class' => 'yii\grid\SerialColumn'],


            'Tite',
            'Content:ntext',
            'Date',
            'ImageID',

            ['class' => 'yii\grid\ActionColumn'],
        ],
    ]); ?>

这是控制器:

 public function actionIndex()
    {
        $searchModel = new aboutSearch();
        $dataProvider = $searchModel->search(Yii::$app->request->queryParams);

        return $this->render('index', [
            'searchModel' => $searchModel,
            'dataProvider' => $dataProvider,
        ]);
    }

public function actionUpdate($id)
    {   


        $model = $this->findModel($id);

        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            return $this->redirect(['view', 'id' => $model->ID]);
        } else {
            return $this->render('update', [
                'model' => $model,

            ]);
        }
    }

1 个答案:

答案 0 :(得分:0)

链接应为

bytes

您应该将行的ID传递到Html::a('Update-about', ['update', 'id' => $id], ['class' => 'btn btn-success']); 视图:

index

主要问题是-您要通过更新操作来更改表return $this->render('index', [ 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, 'id' => $id, ]); 的哪一行?如果这是第一个可用记录,则:

About

或通过将某些条件传递给public function actionIndex() { $searchModel = new aboutSearch(); $dataProvider = $searchModel->search(Yii::$app->request->queryParams); $about = About::find()->one(); // get first record found return $this->render('index', [ 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, 'id' => $about->id, // pass record id to view ]); } 方法来找到所需的行:where;