手机
当前位置:查字典教程网 >编程开发 >php教程 >php下拉选项的批量操作的实现代码
php下拉选项的批量操作的实现代码
摘要:实现功能,操作项可以单独删除,批量项可以批量删除,批量显示,隐藏(改广告的数据库的status_is的值);1.视图关键点:复制代码代码如下...

php下拉选项的批量操作的实现代码1

实现功能,操作项可以单独删除,批量项可以批量删除,批量显示,隐藏(改广告的数据库的status_is的值);

1.视图关键点:

复制代码 代码如下:

<td ><input type="checkbox" name="id[]" value="<?php echo $row->id?>">

<?php echo $row->id?></td>

复制代码 代码如下:

<div>

<input type="checkbox" name="chkall" id="chkall" />

<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" type="submit" value="提交" name="maskall" />

</div>

复制代码 代码如下:

/*单个删除*/

<a href="<?php echo $this->createUrl('batch',array('command'=>'adDelete', 'id'=>$row->id))?>">

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);

}

【php下拉选项的批量操作的实现代码】相关文章:

php实现ping

php分别做为cgi和module来运行的配置

php数组随机排序实现方法

PHP中的事务使用实例

PHP自动生成月历代码

PHP CURL 多线程操作代码实例

php操作MongoDB类实例

php 批量查询搜狗sogou代码分享

php使用curl打开https网站的方法

php简单实现多字节字符串翻转的方法

精品推荐
分类导航