zoukankan      html  css  js  c++  java
  • php批量POST修改

    这是一个thinkphp中的批量修改的案例:

     如需要删除多项,或者同时修改多项记录

    要点:

    前端表单中name要加[],如:<input type="hidden" name="id[]" value="{$vo.id}">

    后端接受如:$id = $_POST [id] [$i];     $i为for中的循环变量,当$i相同时可以使得$_POST [id] [$i]和$_POST [name] [$i]为一一对应;

    前端表单:

    <form name="form1" method="post" action="__GROUP__/Repair/updateList">
      对所选操作:<input type="submit" value="保 存" class="btn btn-primary"> <br>
                <table id="checkList" class="list table table-hover">
                    <tr>
                        <th scope="col"><input id="check" type="checkbox"
                            onclick="checkAll()" /> 全选</th>
                        <th scope="col">主题</th>
                        <th scope="col">校区</th>
                        <th scope="col">房间</th>
                        <th scope="col">报修人</th>
                        <th scope="col">联系电话</th>
                        <th scope="col">报修时间</th>
                        <th scope="col">审核</th>
                        <th scope="col">报修状态</th>
                    </tr>
                    <volist name="list" id="vo">
                    <tr>
                        <td><input type="checkbox" name="key" value="{$vo.id}">{$vo.id}<input type="hidden" name="id[]" value="{$vo.id}"></td>
                        <td>{$vo.topic}</td>
                        <td>{$vo.xiaoqu}</td>
                        <td>{$vo.room}</td>
                        <td>{$vo.pname}</td>
                        <td>{$vo.phone}</td>
                        <td>{$vo.create_time|date='Y-m-d H:i:s',###}</td>
                        <td><select name="check[]"><switch name="vo.check">
                                <case value="0">
                                <option value="0" selected="selected">未审核</option>
                                <option value="1">审核</option>
                                </case> <default />
                                <option value="0">未审核</option>
                                <option value="1" selected="selected">审核</option>
                                </switch></select></td>
                        <td><select name="status[]"><switch name="vo.status">
                                <case value="已修">
                                <option value="未修">未修</option>
                                <option value="任务已下">任务已下</option>
                                <option value="已修" selected="selected">已修</option>
                                </case> <case value="任务已下">
                                <option value="未修">未修</option>
                                <option value="任务已下" selected="selected">任务已下</option>
                                <option value="已修">已修</option>
                                </case> <default />
                                <option value="未修" selected="selected">未修</option>
                                <option value="任务已下">任务已下</option>
                                <option value="已修">已修</option>
                                </switch></select></td>
                    </tr>
                    </volist>
                </table>
            </form>

    服务端处理:

        /**
         * 批量修改状态
         */
        public function updateList() {
            $result = false;
            for($i = 0; $i < count ( $_POST [id] ); $i ++) {
                
                $id = $_POST [id] [$i];
                $check = $_POST [check] [$i];
                $status = $_POST [status] [$i];
                
                // 保存登录信息
                $Repair = M ( 'Repair' );
                $data ['id'] = $id;
                $data ['check'] = $check;
                $data ['status'] = $status;
                $result = $Repair->save ( $data );
            }
            
            if (false !== $result) {
                $this->success ( '修改成功!' );
            } else {
                $this->error ( '修改失败!' );
            }
        }        
  • 相关阅读:
    .Net中集合排序还可以这么玩
    C# 6.0中你不知道的新特性
    EF Core利用Transaction对数据进行回滚保护
    dot watch+vs code提升asp.net core开发效率
    .Net小白的大学四年,内含面经
    EF Core利用Scaffold从根据数据库生成代码
    利用EF Core的Join进行多表查询
    EF Core下利用Mysql进行数据存储在并发访问下的数据同步问题
    新建.Net Core应用程序后引用项一直黄色感叹号怎么办?
    用户密码传输和存储的保护
  • 原文地址:https://www.cnblogs.com/nobcool/p/3339954.html
Copyright © 2011-2022 走看看