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编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("