php下拉选项的批量操作的实现代码 |
本文标签:php,下拉选项,批量操作 实现功能,操作项可以单独删除,批量项可以批量删除,批量显示,隐藏(改广告的数据库的status_is的值); 1.视图关键点: 复制代码 代码如下: <td ><input type="checkbox" name="id[]" value="<?php echo $row->id?>"> <?php echo $row->id?></td> 复制代码 代码如下: <div class="fixsel"> <input type="checkbox" name="chkall" id="chkall" onclick="checkAll(this.form, id)" /> <label for="chkall">全选</label> <select name="command"> <option>选择操作</option> <option value="adDelete">删除</option> <option value="adVerify">显示</option> <option value="adUnVerify">隐藏</option> </select> <input id="submit_maskall" class="button confirmSubmit" type="submit" value="提交" name="maskall" /> </div> 复制代码 代码如下: /*单个删除*/ <a href="<?php echo $this->createUrl(batch,array(command=>adDelete, id=>$row->id))?>" class="confirmSubmit"> 2.控制器: 复制代码 代码如下: /** * 批量操作 * */ public function actionBatch () { if (XUtils::method() == GET) { //单个删除是get方式 $command = trim($_GET[command]); $ids = intval($_GET[id]); } else if (XUtils::method() == POST) { $command = trim($_POST[command]); $ids = $_POST[id]; is_array($ids) && $ids = implode(,, $ids); } else { XUtils::message(errorBack, 只支持POST,GET数据); } empty($ids) && XUtils::message(error, 未选择记录); switch ($command) { case adDelete: parent::_acl(ad_delete); parent::_adminiLogger(array(catalog=>delete, intro=>删除广告,ID:.$ids)); parent::_delete(new Ad(), $ids, array (ad ), array (attach_file )); break; case adVerify: parent::_acl(ad_verify); parent::_adminiLogger(array(catalog=>delete, intro=>广告状态变更为显示,ID:.$ids)); parent::_verify(new Ad(), verify, $ids, array (ad )); break; case adUnVerify: parent::_acl(ad_verify); parent::_adminiLogger(array(catalog=>delete, intro=>广告状态变更为隐藏,ID:.$ids)); parent::_verify(new Ad(), unVerify, $ids, array (ad )); break; default: throw new CHttpException(404, 错误的操作类型: . $command); break; } } 父类的删除函数: 复制代码 代码如下: protected function _delete ($model = null, $id = , $redirect = index, $attach = null, $pkField = id) { if ($attach) { //如果有附件要删除广告的图片 $data = $model->findAll($pkField . IN(:id), array (:id => $id )); foreach ((array) $data as $row) { foreach ((array) $attach as $value) { if (! empty($row[$value])) { @unlink($row[$value]); } } } } $result = $model->deleteAll(array (condition => id IN( . $id . ) )); //刷新缓存 self::_refreshCache($model); $this->redirect($redirect); } 复制代码 代码如下: protected function _verify ($model = null, $type = verify, $id = , $redirect = index, $cdField = status_is, $pkField = id) { $criteria = new CDbCriteria(); $criteria->condition = $pkField . IN( . $id . ); $showStatus = $type == verify ? Y : N; $result = $model->updateAll(array ($cdField => $showStatus ), $criteria); //刷新缓存 self::_refreshCache($model); $this->redirect($redirect); } |