JScript实现表格的简单操作


Posted in Javascript onAugust 15, 2017

本文实例为大家分享了JScript实现表格的简单操作,供大家参考,具体内容如下

实现思路:

1、添加时:获取当前列表的行数,在当前一行添加下一行;
2、用insertCell()方法添加一行,下标从0开始,
3、若要给新一行添加类型、响应事件,就用setAttribute()方法,类似于键值对,并用appendChild()方法将数据保存到新一行
4、删除时:获取需要删除行的当前行数this,然后获取父节点,把整一行删掉remove(),而不是单单删除某一行的单个数据
5、修改时:获取当前修改行的行数索引,点击修改时,把表格状态转换为文本格式,并把“修改”改为“确定”

实现代码:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title></title>
    <style>
      table{
        border-top: 1px solid #ccc;
        border-left: 1px solid #ccc;
        width: 400px;
      }
      td,th{
        border-right:1px solid #ccc ;
        border-bottom: 1px solid #ccc;
      }
    </style>
    <script>
      function add(){
        var table = document.getElementById("order");
        var index = table.rows.length;//表格行数
        var row = table.insertRow(index);//插入一个行并返回新一行


        var c0 = row.insertCell(0);
        var b0 = document.createElement("input");
        b0.setAttribute("type","checkbox");
        b0.setAttribute("onclick","seclect("+index+")");
        b0.setAttribute("name","sel");
        c0.appendChild(b0);

        var c1 = row.insertCell(1);//在新一行插入一列,并返回新一列
        c1.innerHTML = prompt("请输入商品名称","");

        var c2 = row.insertCell(2);//在新一行插入一列,并返回新一列
        c2.innerHTML = prompt("输入数量","");

        var c3 = row.insertCell(3);//在新一行插入一列,并返回新一列
        c3.innerHTML = prompt("输入价格","");

        var c4 = row.insertCell(4);
        var b1 = document.createElement("input");
        b1.setAttribute("type","button");
        b1.setAttribute("value","删除");
        b1.setAttribute("onclick","del(this)");

        var b2 = document.createElement("input");//创建按钮
        b2.setAttribute("type","button");
        b2.setAttribute("value","修改");
        b2.setAttribute("style","margin-left: 5px");
        b2.setAttribute("onclick","update("+index+")");

        c4.appendChild(b1);//把按钮添加到操作的单元格中
        c4.appendChild(b2);
      }

      function del(but){
        //var table = document.getElementById("order");
        but.parentNode.parentNode.remove();//根据节点的层级关系删除行
      }

      function update(index){
        var table = document.getElementById("order");
        //获得修改按钮
        var cell=table.rows[index].cells[4];

        cell.lastChild.setAttribute("value","确定");
        //为按钮重新绑定事件
        cell.lastChild.setAttribute("onclick","edit("+index+")");

        //修改数量
        var cellNumer = table.rows[index].cells[2];
        var txt = document.createElement("input"); //创建一个文本框
        txt.setAttribute("value",cellNumer.innerHTML);//设置文本框的值
        txt.setAttribute("size",5);//文本框长度
        cellNumer.innerHTML = "";//把单元格的数据清除
        cellNumer.appendChild(txt); //把文本框加入到单元格
      }

      function edit(index){
        var table = document.getElementById("order");

        var cell = table.rows[index].cells[4];

        cell.lastChild.setAttribute("value","修改");
        cell.lastChild.setAttribute("onclick","update("+index+")");

        //把单元格中的文本框删除
        var cellNumer = table.rows[index].cells[2];
        var num = cellNumer.firstChild.value;//取文本框的值
        cellNumer.removeChild(cellNumer.firstChild);//删除文本框
        cellNumer.innerHTML = num;
      }

      function allSelect(ch){
        var item = document.getElementsByTagName("input"); //取所有的input标签
        for(var i=0;i<item.length;i++){ //循环每一个
          if(item[i].type==ch.type){ //判断每一个标签的类型是否为CheckBox
            item[i].checked = ch.checked; //复选框的选中与全选的复选框选中相同
          }
        }

      }
      function seclect(sh){
        var item = document.getElementsByName("sel"); 
        var all = document.getElementById("all");
        var tag = true;
        for(var i=0;i<item.length;i++){//判断是否全部选中
          if(item[i].checked == false){
            tag = false;
            break;
          }
        }
        all.checked = tag;
      }
    </script>
  </head>
  <body>
    <center>
      <table id="order" >
        <tr>
          <th>
            <input type="checkbox" onclick="allSelect(this)" id="all"/>全选
          </th>
            <th>商品名称</th>
            <th>数量</th>
            <th>单价</th>
            <th>操作</th>
          </tr>
        <tr>
          <td><input type="checkbox" onclick="seclect(this)" name="sel"/></td>
          <td>娃哈哈</td>
          <td>10</td>
          <td>2</td>
          <td><input value="删除" type="button" onclick="del(this)"style="margin-right:5px ;"/><input value="修改" type="button" onclick="update(1)"/></td>
        </tr>

      </table>
      <button onclick="add()">添加商品</button>
    </center>
  </body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript URL锚点取值方法
Feb 25 Javascript
js动态在form上插入enctype=multipart/form-data的问题
May 24 Javascript
增强用户体验友好性之jquery easyui window 窗口关闭时的提示
Jun 22 Javascript
jquery选择器之基本过滤选择器详解
Jan 27 Javascript
使用GruntJS构建Web程序之合并压缩篇
Jun 06 Javascript
node-http-proxy修改响应结果实例代码
Jun 06 Javascript
AngularJS基础 ng-open 指令简单实例
Aug 02 Javascript
Angular ng-repeat 对象和数组遍历实例
Sep 14 Javascript
Vue实现PopupWindow组件详解
Apr 28 Javascript
详解在不使用ssr的情况下解决Vue单页面SEO问题
Nov 08 Javascript
JavaScript setInterval()与setTimeout()计时器
Dec 27 Javascript
TS 类型收窄教程示例详解
Sep 23 Javascript
AngularJS日程表案例详解
Aug 15 #Javascript
jQuery实现菜单栏导航效果
Aug 15 #jQuery
js实现网页的两个input标签内的数值加减(示例代码)
Aug 15 #Javascript
JScript实现地址选择功能
Aug 15 #Javascript
jQuery实现腾讯信用界面(自制刻度尺)样式
Aug 15 #jQuery
关于vue.js发布后路径引用的问题解决
Aug 15 #Javascript
JavaScript中使用Async实现异步控制
Aug 15 #Javascript
You might like
php miniBB中文乱码问题解决方法
2008/11/25 PHP
php实现的遍历文件夹下所有文件,编辑删除
2010/01/05 PHP
PHP常用特殊运算符号和函数总结(php新手入门必看)
2013/02/02 PHP
php获取从百度搜索进入网站的关键词的详细代码
2014/01/08 PHP
php递归函数中使用return的注意事项
2014/01/17 PHP
PHP创建单例后台进程的方法示例
2017/05/23 PHP
一个加载js文件的小脚本
2007/06/28 Javascript
js图片自动轮播代码分享(js图片轮播)
2014/05/06 Javascript
我的NodeJs学习小结(一)
2014/07/06 NodeJs
高效利用Angular中内置服务$http、$location等
2016/03/22 Javascript
简单实现Bootstrap标签页
2020/08/09 Javascript
微信小程序page的生命周期和音频播放及监听实例详解
2017/04/07 Javascript
Node.js利用断言模块assert进行单元测试的方法
2017/09/28 Javascript
详解Angular2学习笔记之Html属性绑定
2018/01/03 Javascript
微信小程序中button去除默认的边框实例代码
2019/08/01 Javascript
layui字体图标 loading图标静止不旋转的解决方法
2019/09/23 Javascript
vue.config.js中配置Vue的路径别名的方法
2020/02/11 Javascript
[17:45]DOTA2 HEROES教学视频教你分分钟做大人-军团指挥官
2014/06/11 DOTA
[01:42]TI4西雅图DOTA2前线报道 第一顿早饭哦
2014/07/08 DOTA
python的绘图工具matplotlib使用实例
2014/07/03 Python
python实现从wind导入数据
2019/12/03 Python
opencv resize图片为正方形尺寸的实现方法
2019/12/26 Python
django使用F方法更新一个对象多个对象字段的实现
2020/03/28 Python
关于keras中keras.layers.merge的用法说明
2020/05/23 Python
全网最详细的PyCharm+Anaconda的安装过程图解
2021/01/25 Python
python多线程爬取西刺代理的示例代码
2021/01/30 Python
解决PDF 转图片时丢文字的一种可能方式
2021/03/04 Python
HTML5之SVG 2D入门2—图形绘制(基本形状)介绍及使用
2013/01/30 HTML / CSS
联想香港官方网站及网店:Lenovo香港
2018/04/13 全球购物
《中国梦我的梦》小学生演讲稿
2014/08/20 职场文书
学习优秀共产党员先进事迹思想报告
2014/09/17 职场文书
党员批评与自我批评总结
2014/10/15 职场文书
委托函范文
2015/01/29 职场文书
2015年材料员工作总结
2015/04/30 职场文书
会议室管理制度范本
2015/08/06 职场文书
2019年幼儿园管理条例范本!
2019/07/17 职场文书