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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听