JavaScript,全选、全不选、反选、无刷新删除、批量删除、即点即改入库

2024-02-01 20:18

本文主要是介绍JavaScript,全选、全不选、反选、无刷新删除、批量删除、即点即改入库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

示例是在Yii框架中编辑,仅供参考



效果展示:


代码实现:


    <?php  header("content-type:text/html;charset=utf-8");  use yii\helpers\Html;  use yii\widgets\LinkPager;  //print_r($countries);die;  ?>  <h1>显示出数据</h1>  <input type="checkbox" value="全选" οnclick="check(this);">全选  <input type="checkbox" value="全不选" οnclick="check_bx(this);">全不选  <input type="checkbox" value="反选" οnclick="check_fx();">反选  <input type="checkbox" value="批量删除" οnclick="check_del();">批量删除  <script src="public/jq.js"></script>  <style media="screen">  tr{  background-color: red;  font-family: 宋体;  width: 100px;  height: 30px;  line-height: 30px;  text-align: center;  }  td{  background-color: pink;  border: 2px solid purple;  }  .aa{  border: 2px solid green;  background-color: yellow;  font-family: 隶书;  }  h1{  font-family: 华文行楷;  box-shadow: 10px 10px 5px #888888;    border:2px solid;    border-radius:25px;   width: 200px;   background-color: white;  }  th{  font-family: 隶书;  border: 2px solid green;  background-color: yellow;  }  .checkbox{  width: 25px;  height: 30px;  }  </style>  <table border="1">  <th></th>  <th>序列号</th>  <th>父级ID</th>  <th>地区名称</th>  <th>操作</th>  <?php foreach ($countries as $k => $v) {  ?>  <tr>  <td><input type="checkbox" id="<?php echo $v['r_id'] ?>" class="checkbox" name="check[]" value="<?php echo $v['r_id'] ?>"></td>  <td><?php echo $v['r_id'] ?></td>  <td><?php echo $v['pid'] ?></td>  <td><span class="num" id="<?php echo $v['r_id'] ?>"><?php echo $v['r_name']?></span></td>  <td><a href="javascript:void(0)" id="<?php echo $v['r_id'] ?>" class="aa" οnclick="del(this)">删除 </a></td>  </tr>  <?php } ?>  </table>  <?= LinkPager::widget(['pagination' => $pagination]) ?>  <script type="text/javascript">  //即点即改入库  $(function(){  $(document).on('click','.num',function(){  var id=$(this).attr('id');  var _this=$(this);  var new_val=$(this).html();  _this.parent().html("<input type='text'class='asdf' value="+new_val+" id="+id+">");  var inp=$('.asdf');  inp.focus();  inp.blur(function(){  var old_id=$(this).attr('id');  var old_val=$(this).val();  //inp.parent().html("<span class=\"num\" id="+old_id+">"+old_val+"</span>");  $.get("index.php?r=upload/updates",{measure_unit:old_val,id:old_id},function(e){  if(e==1){  inp.parent().html("<span class=\"num\" id="+old_id+">"+old_val+"</span>");  }else{  inp.parent().html("<span class=\"num\" id="+old_id+">"+new_val+"</span>");  }  })  })  })  })  </script>  <script>  //无刷新删除  function del(obj)  {  var ids=obj.id;  ajax=new XMLHttpRequest();  ajax.onreadystatechange=function()  {  if(ajax.readyState==4)  {  //alert(ajax.responseText);  if(ajax.responseText==1)  {  obj.parentNode.parentNode.parentNode.removeChild(obj.parentNode.parentNode);  }  else{  alert("删除失败");  }  }  }  ajax.open("get","index.php?r=upload/del&ids="+ids);  ajax.send(null);  }  /*全选*/  function check(obj)  {  var ids=document.getElementsByName("check[]");  if(obj.checked)  {  for(var i=0;i<ids.length;i++)  {  ids[i].checked=true;  }  }  }  /*全不选*/  function check_bx(obj)  {  var ids=document.getElementsByName("check[]");  if(obj.checked)  {  for(var i=0;i<ids.length;i++)  {  ids[i].checked=false;  }  }  }  //反选  function check_fx()  {  var ids=document.getElementsByName("check[]");  for(var i=0;i<ids.length;i++)  {  ids[i].checked=!ids[i].checked;  }  }  /*批量删除*/  function check_del()  {  var ids=document.getElementsByName("check[]");  var str='';  for(var i=0;i<ids.length;i++)  {  if(ids[i].checked)  {  str=str+','+ids[i].value;  }  }  new_str=str.substr(1);  ajax=new XMLHttpRequest();  ajax.onreadystatechange=function() {  if (ajax.readyState == 4) {  //alert(ajax.responseText);    if(ajax.responseText==1)  {  for(var j=ids.length-1;j>=0;j--)  {  if(ids[j].checked)  {  ids[j].parentNode.parentNode.parentNode.removeChild(ids[j].parentNode.parentNode);  }  }  }  else  {  alert("删除失败");  }  }  }  ajax.open("get","index.php?r=upload/del_all&new_str="+new_str);  ajax.send(null);  }  </script>  

    <?php  namespace app\controllers;  use Yii;  use yii\filters\AccessControl;  use yii\web\Controller;  use yii\filters\VerbFilter;  use app\models\LoginForm;  use app\models\ContactForm;  use yii\web\UploadedFile;  use app\models\Upload;  use yii\data\Pagination;  use app\models\Country;  use app\models\Region;  class UploadController extends Controller  {  //public $layout=false; //禁用yii自带样式  public function actionIndex(){  $model = new Upload();  if ($model->load(Yii::$app->request->post()) && $model->validate()) {  // 验证 $model 收到的数据  // 做些有意义的事 ...  return $this->render('entry-confirm', ['model' => $model]);  } else {  // 无论是初始化显示还是数据验证错误  return $this->render('entry', ['model' => $model]);  }  }  public function actionAdds()  {  $model = new Upload();  $request = Yii::$app->request;  $post=$request->post('Upload');  $u_name = $post['u_name'];  $u_pwd = $post['u_pwd'];  //在浏览器输出的值是 yii\web\UploadedFile Object ( [name] => 2.jpg [tempName] => C:\Windows\php3986.tmp  // [type] => image/jpeg [size] => 216848 [error] => 0 )  $arr =  $model->u_img = UploadedFile::getInstance($model,'u_img');  //print_r($arr);  if ($model->upload()){  $u_img = $arr->name;  //var_dump($u_img);  $connection = \Yii::$app->db;  $result=$connection->createCommand()->insert('upload', [  'u_name' => $u_name,  'u_pwd' => $u_pwd,  'u_img' =>$u_img,  ])->execute();  if($result)  {  echo "添加成功";  }  else  {  echo "添加失败";  }  }  }  /*分页*/  public function actionLists()  {  $query = Country::find();  $pagination = new Pagination([  'defaultPageSize' => 1,  'totalCount' => $query->count(),  ]);  $countries = $query->orderBy('name')  ->offset($pagination->offset)  ->limit($pagination->limit)  ->all();  return $this->render('lists', [  'countries' => $countries,  'pagination' => $pagination,  ]);  }  /*地区表进行分页*/  public function actionShow(){  $query = Region::find();  $pagination = new Pagination([  'defaultPageSize' => 6,  'totalCount' => $query->count(),  ]);  $countries = $query->orderBy('r_id')  ->offset($pagination->offset)  ->limit($pagination->limit)  ->all();  return $this->render('show', [  'countries' => $countries,  'pagination' => $pagination,  ]);  }  /*修改*/  public function actionUpdates(){  $name = $_GET['measure_unit'];  $id = $_GET['id'];  $connection = \Yii::$app->db;  $command = $connection->createCommand("UPDATE region SET r_name='$name' WHERE r_id='$id'");  $command->execute();  if(!empty($command)){  echo 1;  }else{  echo 0;  }  }  // 无刷新delete  public function actionDel(){  $id=$_GET['ids'];  $connection=\Yii::$app->db;  $arr=$connection->createCommand("delete from region where r_id='$id'")->execute();  if($arr){  echo 1;  }else{  echo 0;  }  }  /*  批量删除  @new_str  GET  */  public function actionDel_all(){  $new_str=$_GET['new_str'];  $connection=\Yii::$app->db;  $arr=$connection->createCommand("delete from region where r_id in($new_str)")->execute();  if($arr){  echo 1;  }else{  echo 0;  }  }  }  ?>  


这篇关于JavaScript,全选、全不选、反选、无刷新删除、批量删除、即点即改入库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/668347

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直