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

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

Java中的.close()举例详解

《Java中的.close()举例详解》.close()方法只适用于通过window.open()打开的弹出窗口,对于浏览器的主窗口,如果没有得到用户允许是不能关闭的,:本文主要介绍Java中的.... 目录当你遇到以下三种情况时,一定要记得使用 .close():用法作用举例如何判断代码中的 input

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S