效果图:

建表:company

DROP TABLE IF EXISTS `company`;
CREATE TABLE `company` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`company_name` varchar(255) DEFAULT NULL,
`lxr` varchar(255) DEFAULT NULL,
`tel` varchar(255) DEFAULT NULL,
`email` varchar(255) DEFAULT NULL,
`user` varchar(255) DEFAULT NULL,
`pwd` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=12 DEFAULT CHARSET=gbk;

展示页面:show.php
代码:

<?php
// 连接数据库
$conn = mysqli_connect('127.0.0.1', 'root', '123456', '12a');
// 设置编码方式:sql语句
$result = mysqli_query($conn, "set names utf8");
$sql = "select * from company";
// 查询结果集
$result = mysqli_query($conn, $sql);
while ($row = mysqli_fetch_assoc($result)) {
$data[] = $row;
}
?>
<html>
<meta charset="utf-8">
<title>ajax即点即改</title>
<body>
<h1>人员信息</h1>
<table border="1px solid">
<tr>
  <th></th>
  <th>id</th>
  <th>用户名</th>
  <th>联系人</th>
  <th>手机号</th>
  <th>邮箱</th>
  <th>单位名称</th>
  <th>操作</th>
</tr>
<?php foreach ($data as $k => $v) {?>
<tr id="st_<?php echo $v['id'] ?>">
  <td>
    <input type="checkbox" name="usercheck" value="<?php echo $v['id'] ?>">
  </td>
  <td><?php echo $v['id'] ?></td>
  <td><?php echo $v['user'] ?></td>
  <td><?php echo $v['lxr'] ?></td>
  <td><?php echo $v['tel'] ?></td>
  <td><?php echo $v['email'] ?></td>
  <td>
    <span id="dian_<?php echo $v['id'] ?>" onclick="changeme(<?php echo $v['id'] ?>)">
      <?php echo $v['company_name'] ?>
    </span>
    <input type="hidden" id="input_<?php echo $v['id'] ?>" onblur="doit(<?php echo $v['id'] ?>)">
  </td>
  <td onclick="del(<?php echo $v['id'] ?>)">删除</td>
</tr>
<?php }?>
</table>
<input type="checkbox" id="checkall" onclick="ckAll()">全选/全不选
<button onclick="delall()">批量删除</button>
</html>
<script>
//全选
function ckAll(){
// 获取全选按钮的状态,让上面的按钮的选中状态和它的状态相同,
  var flag=document.getElementById("checkall").checked;
  var cks=document.getElementsByName("usercheck");
  for(var i=0;i<cks.length;i++){
    cks[i].checked=flag;
  }
}
function del(id){
// 实例化ajax对象
  var xhr=new XMLHttpRequest();
// 打开一个请求
  xhr.open("get","do_delete.php?id="+id);
// 发送请求
  xhr.send();
// 监听状态是否变化,状态改变事件
  xhr.onreadystatechange=function(){
// 请求成功。以及响应结束
    if(xhr.status==200&&xhr.readyState==4){
      if(xhr.responseText=='删除成功'){
        alert('删除成功')
        document.getElementById("st_"+id).innerHTML=""
      };
    }
  }
}

// 即点即改
function changeme(id){
// 获取span节点
  var span_node = document.getElementById('dian_'+id)
// 获取input节点
  var input_node = document.getElementById('input_'+id)
// 1、点击让span 隐藏,让input 显示出来
  span_node.style.display="none" // 一定是双引号,span标签隐藏
  input_node.type="text"
}

function doit(id){
// 获取span节点
  var span_node = document.getElementById('dian_'+id)
// 获取input节点
  var input_node = document.getElementById('input_'+id)
// 获取input节点中的 value值
  var input_value = input_node.value
// 如果输入值非空,input框隐藏,值显示在span标签中
  if (input_value) {
    span_node.style.display="block"
    input_node.type="hidden" //input框隐藏
// ajax发送请求,更改数据库
    var xhr = new XMLHttpRequest();
    xhr.open('get','update.php?cname='+input_value+'&id='+id)
    xhr.send()
    xhr.onreadystatechange=function(){
      if (xhr.readyState==4&&xhr.status==200) {
// 值显示在span标签中
        span_node.innerHTML=input_value
      }
    }
  }
}
// 批量删除
function delall() {
  var usercheck = document.getElementsByName("usercheck");
// 获取总共有多少个checkbox
  var len = usercheck.length;
  var flag = false;
  var str="";

  var arr=new Array();

  for (var i = 0; i < len; i++) {
    if (usercheck[i].checked) {
      // console.log(usercheck[i].value)//拼接id    

      arr.push(usercheck[i].value

      str=str+','+usercheck[i].value,

      flag = true;
    }
  }
  
if (!flag) {
    alert('至少选择一个');
    return;
  }
// 截取字符串,去除第一个逗号,
  var id = str.substr(1);
// 实例化ajax对象
  var xhr=new XMLHttpRequest();
// 打开一个请求
  xhr.open("get","do_delete.php?id="+id);
// 发送请求
  xhr.send();
// 监听状态是否变化
 
 xhr.onreadystatechange=function(){
// 请求成功。以及响应结束
    if(xhr.status==200&&xhr.readyState==4){

        for (var i = 0; i < arr.length; i++) {
          id = arr[i]
          document.getElementById("st_"+id).innerHTML=""
        }

    }
  }
}
</script>

单删文件:do_delete.php
代码:

<?php
// 连接数据库
$link = mysqli_connect('127.0.0.1', 'root', '123456', '12a');
// 接收参数id,要删除的额数据的id
$id = $_GET['id'];

$sql = "delete from company where id in ($id)";

// 执行删除

$st = mysqli_query($link, $sql);
if ($st) {
  echo "删除成功";
} else {
  echo "删除失败";
}

?>

//即点即改更新数据库,文件:update.php

<?php
// 连接数据库
$link = mysqli_connect('127.0.0.1', 'root', '123456', '12a');
$id = $_GET['id'];
$cname = $_GET['cname'];
$sql = "update company set company_name='$cname' where id=$id";
$st = mysqli_query($link, $sql);
if ($st) {
  echo "更改成功";
} else {
  echo "更改失败";
}

?>

最新文章

  1. Scala HelloWorld
  2. 批处理中的echo命令图文详解
  3. PL/pgSQL的RETURN QUERY例子
  4. HDU4545+LCS
  5. cloudera manager 及CDH卸载
  6. JS中,如何查询一个对象的所有属性
  7. BZOJ2084: [Poi2010]Antisymmetry
  8. java基础知识汇总
  9. CentOS 6.5静态IP的设置(NAT和桥接都适用)
  10. IEnumerable &amp; IEnumerator
  11. 基于zookeeper的Swarm集群搭建
  12. Scrapy 代理IP
  13. C# -- 使用XmlDocument或XDocument创建xml文件
  14. IAR map 文件报告与Flash 大小关系
  15. Go语言学习之9 网络协议TCP、Redis与聊天室
  16. spring cloud 配置文件application.yml和bootstrap.yml 的定位,区别和联系
  17. 从源码编译InfluxDB
  18. stat用法:获取文件对应权限的数字
  19. UVa 12545 Bits Equalizer (贪心)
  20. docker “no space left on device”问题定位解决

热门文章

  1. HTML+css基础 标签的起名 style标签 选择器的使用规则
  2. SQL --------------- 运算符 = 与 in
  3. Linux 监控之 IO
  4. Delphi - 10进制16进制相互转换
  5. input file 保存图片
  6. 阿里云 centos 无法执行moodle cron
  7. 立即执行函数(function(){})()与闭包
  8. jmeter+jenkins配置过程
  9. C 语言实现回调函数
  10. AI-图像基础知识-01