使用JS批量选中功能实现更改数据库中的status状态值(批量展示)


Posted in Javascript onNovember 22, 2016

我们在开发项目的时候经常会在后台管理时用到批量展示功能来动态的修改数据库的值。下面以修改数据库的status状态值来实现批量展示功能。批量选中功能引用js来实现。

前端html代码:

<table class="mlt" style="border:1px solid red;">
<thead>
<tr>
<if condition="$type eq 'pg'">
<th colspan="9" style="text-align:left;padding-left:20px;background-color:#e5e4e4;color:#c10e23;">实物商品</th>
<else/>
<th colspan="8" style="text-align:left;padding-left:20px;background-color:#e5e4e4;color:#c10e23;">虚拟商品</th>
</if>
<th style="background-color:#e5e4e4;">
<a href="{:U('Mall/AddMall',array('type'=>$type))}" style="color:#c10e23;text-decoration:none;">+新增商品</a></th> 
</tr>
<tr>
<th style="background-color:#f7f7f7;width:8%;text-align:center;" class="lf">
<input name='chkAll' type='checkbox' id='chkAll' onClick="checkAll(this, 'id[]')" value='checkbox' /> 全选
</th>
<th style="background-color:#f7f7f7;width:8%;" class="lf">商品编号</th>
<th style="background-color:#f7f7f7;width:13%;" class="lf">名称</th>
<th style="background-color:#f7f7f7;width:18%;" class="lf">标题</th>
<if condition="$type eq 'pg'">
<th style="background-color:#f7f7f7;width:8%;" class="lf">品牌</th>
</if>
<th style="background-color:#f7f7f7;width:8%;" class="lf">组别</th>
<th style="background-color:#f7f7f7;width:5%;" class="lf">排序</th>
<th style="background-color:#f7f7f7;width:5%;" class="lf">状态</th>
<th style="background-color:#f7f7f7;width:10%;">图标</th>
<th style="background-color:#f7f7f7;text-align:center;" class="lf">操作</th>
</tr>
</thead>
<tbody>
<volist name="list" id="vo">
<tr>
<td class="lf" style="text-align:center;">
<input name='id[]' type='checkbox' value='{$vo.id}' onClick="checkItem(this, 'chkAll')">
</td>
<td class="lf">{$vo['code']}</td>
<td class="lf">{$vo['name']}</td>
<td class="lf">{$vo['title']}</td>
<if condition="$type eq 'pg'">
<td class="lf">{$vo['brand']}</td>
</if>
<td class="lf">{$vo['ggroup']}</td>
<td class="lf">{$vo['sortno']}</td>
<td class="lf"><if condition="$vo['status'] eq 1">展示<else/>不展示</if></td>
<td><img src="{$vo['base_img']}" style="width:40px;" /></td>
<td class="lf" style="text-align:center;">
<a href="{:U('Mall/NextLevel',array('pid'=>$vo['id']))}" class='cz' style="text-decoration:none;">编辑子信息</a>
<a href="{:U('Mall/UpdateMall',array('id'=>$vo['id']))}" class='cz' style="text-decoration:none;margin:0 7px;">编辑</a>
<a href="{$Think.config.WEB_URL}/Shop/GoodsDetails.html?pid={$vo['id']}&type={$vo['type']}" class='cz' style="text-decoration:none;" target="_Blank">查看</a>
</td>
</tr>
</volist>
<tr height="45">
<td colspan="10" style="text-align:left;padding-left:40px;">
<input type="button" id="btn_show" value="批量展示" class="btn_normal" style="width:100px;margin-left:20px;">
</td> 
</tr>
</tbody>
</table>
<div>{$page}</div>

js代码使用ajax提交代码到后台GoodsShow()方法:

<script type="text/javascript">
var ids = []; //把得到的is转化为数组形式
$('#btn_show').click(function(){
btnCheck('展示');
data = {
"ids":ids
};
$.ajax({
type:"POST",
url:"{:U('Mall/GoodsShow')}",
data:data,
//dataType:"json",
success:function(msg){
if(msg == 00){ //如果msg=00则修改成功
alert("批量展示成功");
window.location.href='/index.php/Admin/Mall/MallList'; //修改完成后自动刷新
}else{
alert("批量展示失败,请重新编辑");
}
},
error:function(){
alert("批量编辑失败,请重新编辑"); //错误提示
}
}); 
});function btnCheck(info){ 
var obj = $("input[name='id[]']:checked").each(function(){ //得到选中的id的每一个值并且这个值为一个数组
ids.push($(this).val()); 
});
if (ids == false) { 
alert("请选定要"+info+"的商品");
return false;
}else {
return ids; 
}
}
</script>

后台GoodsShow()方法:

public function GoodsShow(){
$goods=M('shop_goods_info'); //实例化要使用的数据表
$data = I(); //获取前台页面获取的id值(这个值为一个一位数组)
//var_dump(I('ids'));die(); //打印
$id=implode(',',I('ids')); //把得到的这个数组用implode方法拆分 
//var_dump(I('id'));die(); //打印查看
$order=$goods->where("id in ($id)")->setField('status','1'); //用得到的$id的值匹配数据库中的id值,并设置id下的status字段值为1.
if($order>=1){ // 如果...else... 
$remark="00";
}else{
$remark="01";
}
echo $remark;
}

以上所述是小编给大家介绍的使用JS批量选中功能实现更改数据库中的status状态值(批量展示),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript innerHTML、outerHTML、innerText、outerText的区别
Nov 24 Javascript
JavaScript经典效果集锦
Jul 06 Javascript
jquery下为Event handler传递动态参数的代码
Jan 06 Javascript
jQuery实现的一个自定义Placeholder属性插件
Aug 11 Javascript
用JavaScript实现使用鼠标画线的示例代码
Aug 19 Javascript
JavaScript中的对象的extensible属性介绍
Dec 30 Javascript
javascript验证手机号和实现星号(*)代替实例
Aug 16 Javascript
详解各版本React路由的跳转的方法
May 10 Javascript
uni-app之APP和小程序微信授权方法
May 09 Javascript
JS原形与原型链深入详解
May 09 Javascript
javascript实现数字时钟效果
Feb 06 Javascript
vue如何批量引入组件、注册和使用详解
May 12 Vue.js
AngularJS中指令的四种基本形式实例分析
Nov 22 #Javascript
AngularJS中directive指令使用之事件绑定与指令交互用法示例
Nov 22 #Javascript
微信小程序-图片、录音、音频播放、音乐播放、视频、文件代码实例
Nov 22 #Javascript
详解js中Json的语法与格式
Nov 22 #Javascript
AngularJS中一般函数参数传递用法分析
Nov 22 #Javascript
javascript入门之string对象【新手必看】
Nov 22 #Javascript
模板视图和AngularJS之间冲突的解决方法
Nov 22 #Javascript
You might like
在PHP中养成7个面向对象的好习惯
2010/01/28 PHP
php中将html中的br换行符转换为文本输入中的换行符
2013/03/26 PHP
PHP5中Cookie与 Session使用详解
2013/04/30 PHP
非常有用的9个PHP代码片段
2016/04/06 PHP
PHP使用递归算法无限遍历数组示例
2017/01/13 PHP
利用php操作memcache缓存的基础方法示例
2017/08/02 PHP
Mac下关于PHP环境和扩展的安装详解
2019/10/17 PHP
jquery easyui的tabs使用时的问题
2010/03/23 Javascript
window.event.keyCode兼容IE和Firefox实现js代码
2013/05/30 Javascript
浅析ajax请求json数据并用js解析(示例分析)
2013/07/13 Javascript
JQuery表格拖动调整列宽效果(自己动手写的)
2014/09/01 Javascript
jquery delay()介绍及使用指南
2014/09/02 Javascript
javascript每日必学之封装
2016/02/23 Javascript
jQuery中iframe的操作(点击按钮新增窗口)
2016/04/20 Javascript
JS高仿抛物线加入购物车特效实现代码
2017/02/20 Javascript
微信小程序 动态传参实例详解
2017/04/27 Javascript
vue多种弹框的弹出形式的示例代码
2017/09/18 Javascript
详解ES6 系列之异步处理实战
2018/10/26 Javascript
浅谈对于react-thunk中间件的简单理解
2019/05/01 Javascript
深入了解Vue动态组件和异步组件
2021/01/26 Vue.js
[04:19]完美世界携手游戏风云打造 卡尔工作室模型介绍篇
2013/04/24 DOTA
新手该如何学python怎么学好python?
2008/10/07 Python
Python的string模块中的Template类字符串模板用法
2016/06/27 Python
Python利用Beautiful Soup模块搜索内容详解
2017/03/29 Python
python爬虫实战之爬取京东商城实例教程
2017/04/24 Python
python人民币小写转大写辅助工具
2018/06/20 Python
利用Python对文件夹下图片数据进行批量改名的代码实例
2019/02/21 Python
python如何使用Redis构建分布式锁
2020/01/16 Python
python使用OpenCV模块实现图像的融合示例代码
2020/04/10 Python
戴森香港官方网站:Dyson香港
2021/02/11 全球购物
行政经理岗位职责
2013/11/09 职场文书
4S店销售内勤岗位职责
2015/04/13 职场文书
董事长年会致辞
2015/07/29 职场文书
阿里云服务器部署mongodb的详细过程
2021/09/04 MongoDB
JS 4个超级实用的小技巧 提升开发效率
2021/10/05 Javascript
mysql中varchar类型的日期进行比较、排序等操作的实现
2021/11/17 MySQL