php下拉选项的批量操作的实现代码
来源:互联网 发布:本地漫画阅读软件 编辑:程序博客网 时间:2024/06/05 04:31
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')
{
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);
}
实现功能,操作项可以单独删除,批量项可以批量删除,批量显示,隐藏(改广告的数据库的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) {
//如果有附件要删除广告的图片 www.jbxue.com
$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下拉选项的批量操作的实现代码
- php 批量替换程序的具体实现代码
- PHP多线程批量采集下载美女图片的实现代码
- PHP mysqli 增强 批量执行sql 语句的实现代码
- 一行代码实现RecyclerView的多选批量操作
- 在IE中实现窗口间操作下拉选框的选项
- 在IE中实现窗口间操作下拉选框的选项
- odoo8中在“更多”下拉菜单下实现简单的批量操作
- 利用chosen.js插件实现下拉可搜索多选,控制选择个数,选项框复位,修改下拉选项的功能(附代码)
- ibatis批量操作的实现
- //JQ操作文本域和下拉选项的值
- 关于用户批量操作checkbox选项的若干实际问题解决
- phpCodeBeautifier的批量美化php代码
- php批量去除bom的代码
- jsp实现下拉框选项下有选择的显示
- jQuery实现两个下拉菜单的选项互相移动效果
- 单击下拉菜单里面的选项实现跳转
- 携着往事的深沉,
- 远。时间;可
- my.cnf优化
- 新的一天
- jquery实现兼容浏览器的图片上传本地预览功能
- php下拉选项的批量操作的实现代码
- 数据库设计的理论步骤
- eclipse launching workspace太慢的解决方法
- C/C++学习笔记(十一)string和string.h文件的区别
- 2dx学习笔记-----常用宏
- 1、Map-Reduce的逻辑过程
- VC++实现自动关机
- day3
- qt中oci库的编译