javascript(dom查询,增删改练习)

目录

dom的其他查询方法

dom增删改

添加删除记录


dom的其他查询方法

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <script>
      window.onload = function () {
        // 获取body标签
        var body = document.getElementsByTagName("body")[0];
        // 在document中有一个属性body,它保存的是body的引用
        alert(body); //[object HTMLBodyElement]
        var body = document.body;
        alert(body); //[object HTMLBodyElement]

        var html = document.documentElement;
        alert(html);
        // document.all代表页面中的所有元素
        var all = document.all;
        console.log(all.length);
        for (var i = 0; i < all.length; i++) {
          console.log(all[i]);
        }
        all = document.getElementsByTagName("*");

        console.log(all.length);
        // 根据元素的class属性查询一些元素节点对象
        // getElementsByClassName()可以根据class属性获取一组元素节点对象
        // 但是该方法不支持IE8及以下的浏览器

        // 根据元素的class属性值查询一组元素节点对象
        // getElementsByClassName()可以根据class属性值获取一组元素节点对象
        // 但是这种方法不知=支持IE8以下的浏览器
        var box1 = document.getElementsByClassName("box1");

        console.log(box1.length);
        // 获取页面中的所有的div
        var divs = document.getElementsByTagName("div");
        console.log(divs.length);
        // 获取box1中的div

        // document.querySelector()
        // 需要一个选择器的字符串作为参数,
        // 可以根据一个css选择器来查询一个元素节点对象
        // 使用该方法总会返回唯一的元素,如果满足条件的元素有多个,
        // 则它只会返回第一个
        var div = document.querySelector(".box1 div");

        var box1 = document.querySelector(".box1");

        console.log(box1.innerHTML);
        console.log(div.innerHTML);

        // document.querySelectorAll()
        // 该方法和querySelector()语法类似,
        // 不同的是它会将符合条件的元素封装到一个数组中返回
        // 即使符合条件的元素只有一个,他也会返回数组

        box1 = document.querySelectorAll(".box1");
        box1 = document.querySelectorAll("#box2");
        console.log(box1);
        console.log(box1.length);
      };
    </script>
  </head>
  <body>
    <div id="box2">box2</div>
    <div class="box1">
      我是第一个box1
      <div>我是box1中的div</div>
    </div>
    <div class="box1">
      <div>我是box1中的div</div>
    </div>
    <div class="box1">
      <div>我是box1中的div</div>
    </div>
    <div></div>
  </body>
</html>

dom增删改

修改:

  • confirm()用于弹出一个带有确认和取消按钮的提示框,需要一个字符串作为参数,该字符串将会作为提示文字显示出来。
  • 如果用户点击确认会返回true,如果点击取消返回false
  • 点击超链接以后,超链接会跳转页面,是超链接的默认行为,但是不希望出现默认行为时,可以通过在响应函数的最后return false来取消默认行为。
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <script>
      window.onload = function () {
        // 创建一个“广州”节点,添加到#city<
        myClick("btn01", function () {
        //   alert("helo");
          // 创建li元素节点
          /*document.createElement()
            可以创建一个标签名作为参数,将会根据该标签名创建元素节点对象
            他需要一个标签名作为参数,将会根据该标签名创建元素节点对象,
            并将创建好的对象作为返回值返回
            */
          var li = document.createElement("li");
          // 创建广州文本节点
          // document.=document.createTextNode()
          // 可以用来创建一个文本节点对象
          // 需要一个文本内容作为参数,将会根据该内容创建文本节点,
          // 并将新的节点返回
          var gzText = document.createTextNode("广州");
          /* 将geText设置li的子节点
            appendChild()
            向一个父节点中添加新的子节点
            用法:父节点.appendChild(子节点)
            */
          li.appendChild(gzText);
          // 添加到#city<
          // 获取id为city的节点
          var city = document.getElementById("city");
          city.appendChild(li);
        });

        // 将“广州”节点插入到#bj前面
        myClick("btn02", function () {
          var li = document.createElement("li");
          var gzText = document.createTextNode("广州");
          li.appendChild(gzText);
          // 获取id为bj的节点
          var bj = document.getElementById("bj");
          // 获取city
          var city = document.getElementById("city");
          /* 
                insertBefore
                可以在指定的子节点前插入新的子节点
                语法:
                父节点.insertBefore(新节点,旧节点)
                 */
          city.insertBefore(li, bj);
        });

        myClick("btn03", function () {
          var li = document.createElement("li");
          var gzText = document.createTextNode("广州");
          li.appendChild(gzText);
          // 获取id为bj的节点
          var bj = document.getElementById("bj");
          // 获取city
          var city = document.getElementById("city");
          /* replaceChild()
          可以用来使用指定的子节点替换已有的子节点
          语法:
          父节点.replaceChild(新节点,子节点)
           */
          city.replaceChild(li, bj);
        });

        // 删除#bj节点
        myClick("btn04",function(){
            // var bj=document.getElementById("bj");
            // var city=document.getElementById("city");

            // /* removeChild()
            // 可以删除一个子节点
            // 语法:父节点.removeChild(子节点);

            //  */
            // city.removeChild(bj);
            // 另一种方法
            bj.parentNode.removeChild("bj");

        })
        myClick("btn05",function(){
            // 获取city
            var city=document.getElementById("city");
            alert(city.innerHTML);
        });

        myClick("btn06",function(){
            var bj=document.getElementById("bj");
            bj.innerHTML="赣州";

        })
        myClick("btn07",function(){
            var city=document.getElementById("city");
            city.innerHTML+="<li>广州</li>";
        });
      };


      function myClick(idStr, fun) {
        var btn = document.getElementById(idStr);
        btn.onclick = fun;
      }
    </script>
  </head>
  <body>
    <div id="total">
      <div class="inner">
        <p>你喜欢哪个城市?</p>

        <ul id="city">
          <li id="bj">北京</li>
          <li>上海</li>
          <li>东京</li>
          <li>首尔</li>
        </ul>

      </div>
    </div>
    <div id="btnList">
      <div><button id="btn01">创建一个“广州”节点,添加到#city</button></div>
      <div><button id="btn02">将“广州”节点插入到#bj前面</button></div>
      <div><button id="btn03">使用“广州”节点替换#bj节点</button></div>
      <div><button id="btn04">删除#bj节点</button></div>
      <div><button id="btn05">读取#city内的Html代码</button></div>
      <div><button id="btn06">设置#bj内的HTML代码</button></div>
      <div><button id="btn07">创建一个“广州”节点,添加到#city</button></div>
    </div>
  </body>
</html>

添加删除记录

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>添加删除记录练习</title>
    <script>
      /* 
      删除tr的响应函数
       */
      function delA(){
            //点击a删除tr
            // 获取当前tr
            var tr=this.parentNode.parentNode;
            // 删除之前弹出一个提示框
            
            // 获取要删除的员工的名字
            var name=tr.getElementsByTagName("td")[0].innerHTML;
            // var name=tr.children[0].innerHTML;

            /* 
            confirm()
            用于弹出一个带有确认和取消按钮的提示框
            需要一个字符串作为参数,该字符串作为提示文字显示出来
            如果用户确认,则返回true
            如果用户取消,则返回false
             */
            var flag=confirm("确认删除"+name+"吗?");
            // 如果用户点击确定
            if(flag){
           // 删除tr
            tr.parentNode.removeChild(tr);

            }
            return false;
            
            
            // 点击链接后,超链接回跳转页面,
            // 这个是超链接的默认行为
            // 不希望出现默认行为,可以通过在响应函数的最后
            // return false
            // 来取消默认行为
            // 也可以在用javascript:;
          };
      window.onload = function () {

        /* 
        点击超链接,删除员工的信息 
        */
        // 获取超链接以后,删除一个员工的信息
        var allA=document.getElementsByTagName("a");
        // 为每个超链接都绑定一个单击响应函数
        for(var i=0;i<allA.length;i++){
          allA[i].onclick=delA;
        };
       
      
    
          // 是赋值给对象,函数值

        


/* 
添加员工
点击按钮,将员工的信息添加到表格中
 */
// 为按钮绑定一个单击响应函数
var addEmpButton=document.getElementById("addEmpButton");
addEmpButton.onclick=function(){
  // 获取员工的名字
  var name=document.getElementById("empName").value;
  // 获取员工的email和salary
  var email=document.getElementById("email").value;
  var salary=document.getElementById("salary").value;

  // alert(name+email+salary);
  // 创建tr
  var tr=document.createElement("tr");
  // 该创建方法笨拙,需要采取新方法
//   // 创建四个td
//   var nameTd=document.createElement("td");
//   var emailTd=document.createElement("td");
//   var salaryTd=document.createElement("td");
//   var aTd=document.createElement("td");
  
//   // 创建a元素
//   var a=document.createElement("a");
//   // 创建文本节点
//   var nameText=document.createTextNode(name);
//   var emailText=document.createTextNode(email);
//   var salaryText=document.createTextNode(salary);
//   var delText=document.createTextNode("Delete");

//   // 将文本条件到td中
//   nameTd.appendChild(nameText);
//   emailTd.appendChild(emailText);
//   salaryTd.appendChild(salaryText);

//   // 向a节点添加文本
//   a.appendChild(delText);
  
//   // 将a添加到td中
//   aTd.appendChild(a);

//   // 将td添加到tr中
//   tr.appendChild(nameTd);
//   tr.appendChild(emailTd);
//   tr.appendChild(salaryTd);
//   tr.appendChild(aTd);

//   // 向a中添加到href属性
//   a.href="javascript:;";
//   // 为新添加的a再绑定一次单击响应函数
//  a.onclick=delA;
  // 设置tr中的内容
  tr.innerHTML="<td>"+name+"</td>"+
  "<td>"+email+"</td>"+
  "<td>"+salary+"</td>"+
  "<td><a href='javascript:;'>Delete</td>";
    // 获取tr中的a节点,标并且跟他单击响应函数
  var a=tr.getElementsByTagName("a")[0];
  a.onclick=delA;


  // 获取table
  var employeeTable=document.getElementById("employeeTable");
  // 获取employeeTable中的tbody
  var tbody=employeeTable.getElementsByTagName("tbody")[0];
  // 将tr添加到table中
  tbody.appendChild(tr);

 
}

      }
    
    </script>
  </head>
  <body>
    <table id="employeeTable">
      <tr>
        <th>Name</th>
        <th>Email</th>
        <th>Salary</th>
        <th>&nbsp;</th>
      </tr>
      <tr>
        <td>Tom</td>
        <td>tom@tom.com</td>
        <td>5000</td>
        <td><a href="javascript:;">Delete</a></td>
      </tr>
      <tr>
        <td>Jerry</td>
        <td>Terry@sohu.com</td>
        <td>8000</td>
        <td><a href="javascript:;">Delete</a></td>
      </tr>
      <tr>
        <td>Bob</td>
        <td>Bob@tom.com</td>
        <td>10000</td>
        <td><a href="javascript:;">Delete</a></td>
      </tr>
    </table>
    <div id="formDiv">
      <h4>添加新员工</h4>
      <table>
        <tr>
            <td class="word">name:</td>
            <td class="inp">
                <input type="text" name="empName" id="empName" />

            </td>

        </tr>
        <tr>
            <td class="word">email:</td>
            <td class="inp">
                <input type="text" id="email" name="email"></input>
            </td>
        </tr>
        <tr>
            <td class="word">salary:</td>
            <td class="inp">
                <input  type="text" id="salary" name="salary"></input>
            </td>
        </tr>
        <tr>
            <td colspan="2" align="center">
                <button id="addEmpButton">
                    Submit
                </button>

            </td>
        </tr>
      </table>
    </div>
  </body>
</html>

 for循环在页面加载完成之后立即执行

响应函数会在超链接被点击时才执行 当响应函数执行时,for循环早已执行完毕

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值