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中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Java SWT库详解与安装指南(最新推荐)

《JavaSWT库详解与安装指南(最新推荐)》:本文主要介绍JavaSWT库详解与安装指南,在本章中,我们介绍了如何下载、安装SWTJAR包,并详述了在Eclipse以及命令行环境中配置Java... 目录1. Java SWT类库概述2. SWT与AWT和Swing的区别2.1 历史背景与设计理念2.1.

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏