js에 대한 기본 지식을 갖추고 jquery, thinkphp를 이해하는 것이 좋습니다. 더 이상 고민하지 말고 코드부터 시작해 보겠습니다.
《————HTML————》
//thinkphp循环显示把data里fid赋予多选框 <volist name="data" id="vo"> <tr> <td><input type="checkbox" value="{$vo.fid}"/></td>//可在后面加td输入参数 </tr> </volist> <tr> <th width="80"><input type="checkbox" id="all"/>全选</th> <th width="80"><input type="button" value="全选" class="btn" id="selectAll" /></th> <th width="80"><input type="button" value="全不选" class="btn" id="unSelect" /></th> <th><input type="button" value="反选" class="btn" id="reverse" /></th> <th width="180"> <a href="javascript:void(0);" rel="external nofollow" onclick="del()" title="删除选定数据">删除</a> </th> </tr>
《————jsvascript————》
<script> //多选 $("#all").click(function(){ if(this.checked){ $("#list :checkbox").attr("checked", true); }else{ $("#list :checkbox").attr("checked", false); } }); //当点到全选按钮 $("#selectAll").click(function () { $("#list :checkbox,#all").attr("checked", true); }); //全不选 $("#unSelect").click(function () { $("#list :checkbox,#all").attr("checked", false); }); //反选 $("#reverse").click(function () { $("#list :checkbox").each(function () { $(this).attr("checked", !$(this).attr("checked")); }); allCheck(); }); //删除 function del(){ var valArr = new Array; $("#list :checkbox[checked]").each(function(i){ valArr[i] = $(this).val(); }); var vals = valArr.join(',');//数组转换以逗号隔开的字符串 if (valArr.length == 0) { alert('请选择要删除的选项'); }else{ if (confirm("确定删除?删除后将无法恢复。")){ var data={name:vals}; $.ajax({ type: "post", url: "{:U('College/School/faculty_del')}",//url为tp方法(控制器/方法) data:data, success: function(json) { var obj = eval('(' + json + ')');//返回回来的json转化为js对象 if (parseInt(obj.counts) > 0) { alert(obj.des); location.reload(); } else { alert(obj.des); } }, error: function(XMLHttpRequest, textStatus) { alert("页面请求错误,请检查重试或联系管理员!\n" + textStatus); } }); } } } </script>
《—— ——PHP———— 》
public function faculty_del(){ $fid = trim($_POST['name']); //以下为查询条件 $bname['deletemark'] = 0; $res = $this->faculty_model ->where(array('fid'=>array('in',$fid))) ->save($bname); //查询条件为你的查询条件,我这边为逻辑删除,修改字段值就好 // echo $this->faculty_model->getLastSql(); // var_dump($res); // exit; if ($res) { $counts = "1"; $des = "成功"; } else { $counts = "0"; $des = "失败"; } $json_data = "{"; $json_data.= "\"counts\":".json_encode($counts).","; $json_data.= "\"des\":".json_encode($des).""; $json_data.= "}"; echo $json_data; exit; }
비동기적이기 때문에 보내는 데이터가 현재 콘솔에 출력되지 않습니다. 페이지를 찾으려면 페이지로 이동하지 마세요.
위는 Ajax 다중 선택, 반전, 삭제 기능을 구현하기 위해 php(Thinkphp) + jquery를 기반으로 에디터가 소개한 내용입니다. 질문이 있으시면 메시지를 남겨주세요. 편집자가 제 시간에 모든 사람에게 답변해 드릴 것입니다. 또한 PHP 중국어 웹사이트를 지원해 주신 모든 분들께 감사드립니다!
Ajax 다중 선택, 역선택, 데이터 삭제 기능을 구현하기 위한 더 많은 php(Thinkphp) + jquery를 보려면 PHP 중국어 웹사이트에서 관련 기사를 주목하세요!