createElement, parentNode, removeChild, appendChild

1获取父节点

var childNode = document.getElementById("child");
var parentNode = childNode.parentNode; // 获取父节点

利用dom获取元素要嵌套
引出:利用父子兄节点关系获取元素

  • 标签,元素,元素节点
  • 空格,文本节点
  • 属性节点

dom树中所有节点都能通过js访问
节点至少有nodetype,nodename,nodevalue

元素节点 nodetype=1
属性节点 nodetype=2
文本节点 nodetype=3(文字,空格,换行)
节点操作主要操作的是元素节点

如果只想获得里面元素节点:

for(var i=0;i<ul.childNodes.length;i++)
{
    if(ul.childNodes[i].nodeType==1) {
    console.log(ul.childNodes[i]);
    }
}

2 parentNode.children获取所有子元素节点

3 .children[0],.children[ol.children.length-1](ol是变量,具体见楼下代码)

<body>
  <ol>
    <li>li1</li>
    <li>li2</li>
    <li>li3</li>
    <li>li4</li>
  </ol>
  <script>
    var ol=document.querySelector('ol');
    // 1 firstchild获得第一个字节点,不管是文本还是元素
    console.log(ol.firstChild);
    // 2 firstElementChild 返回第一个子元素节点,都有兼容性问题
    console.log(ol.firsttElementChild);
    console.log(ol.children[0]);
    console.log(ol.children[ol.children.length-1]);


  </script>
</body>

新浪下拉菜单

html结构:一个大ul里包括四个li,每个li里上下栏,上栏是a标签,下栏是ul包含三个li

<ul class="nav">
    <li><a href="#">微博</a>
      <ul>
        <li><a href="#">私信</a></li>
        <li><a href="#">评论</a></li>
        <li><a href="#">@我</a></li>
      </ul>
    </li>

    <li><a href="#">微博</a>
      <ul>
        <li><a href="#">私信</a></li>
        <li><a href="#">评论</a></li>
        <li><a href="#">@我</a></li>
      </ul>
    </li>
    <li><a href="#">微博</a>
      <ul>
        <li><a href="#">私信</a></li>
        <li><a href="#">评论</a></li>
        <li><a href="#">@我</a></li>
      </ul>
    </li>
    <li><a href="#">微博</a>
      <ul>
        <li><a href="#">私信</a></li>
        <li><a href="#">评论</a></li>
        <li><a href="#">@我</a></li>
      </ul>
    </li>


  </ul>

css:

<style>
    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    li {
      list-style: none;
    }

    a {
      text-decoration: none;
      color: black;

    }

    .nav {
      margin: 100px;
    }

    .nav>li {
      position: relative;
      float: left;
      height: 41px;
      width: 80px;
      text-align: center;
    }

    .nav li a {
      display: block;
      height: 100%;
      width: 100%;
      line-height: 41px;
      color: #333;

    }

    .nav>li>a:hover {
      background-color: #eee;
    }

    .nav ul {
      display: none;
      position: absolute;
      top: 41px;
      left: 0;
      width: 100%;
      border-left: 1px solid #FECC5B;
      border-right: 1px solid #FECC5B;
    }

    .nav ul li {
      border-bottom: 1px solid #FECC5B;
    }

    .nav ul li a:hover {
      background-color: #FFF5DA;
    }
  </style>

js的思路:

1 导航栏里li都要鼠标经过效果,循环注册鼠标事件
2 鼠标里第二个孩子ul显示,鼠标离开第二个孩子ul消失

<script>
    var nav = document.querySelector('.nav');
    var lis = nav.children;//得到四个li
    for (var i = 0; i < lis.length; i++) {
      lis[i].onmouseover = function () {
        this.children[1].style.display = 'block';
      }
      lis[i].onmouseout = function () {
        this.children[1].style.display = 'none';
      }
    }
  </script>

获得兄弟节点(用的较少)

nextSibling获得下一个兄弟节点,包括元素节点,文本节点
previousSibling前一个兄弟节点,包括元素节点,文本节点
nextElementSibling 得到下一个兄弟元素节点

通过封装兼容性函数:
function getNextElementSibling(element) {
	var el = element;
	while(el = el.nextSibling) {
	 if(el.nodeType===1) {
	 return el;
	 }
	}
	return null;
}

原本ul里没有li,根据情况动态创建li放ul里
1 创建节点元素节点
var li = document.createELement('li')
2 添加节点node父级 child 子级
var ul = document.queryselector('ul')
ul.appendchild(li);//(后面新增加元素)
3 如果原来就有li元素,那么新建的元素跟在原来的后面
4 node.insertBefore(child,指定元素)
//将一个节点添加到父节点指定子节点前面
var lili = document.createelement('li');
ul.insertbefore(lili,ul.children[0]);
//在第一个元素前面插入元素

发布留言案例:

<style>
    * {
      margin: 0;
      padding: 0;
    }

    textarea {
      margin: 10px;
    }

    li {
      list-style: none;
      height: 40px;
      width: 400px;
      margin: 10px;
      background-color: pink;
    }
  </style>
<textarea name="" id="" cols="30" rows="10"></textarea>
  <button>fabu</button>
  <ul>

  </ul>
<script>
    // 1获取元素
    var btn = document.querySelector('button');
    var text = document.querySelector('textarea');
    var ul = document.querySelector('ul');
    // 2 注册事件
    btn.onclick = function () {
      if (text.value == '') {
        alert('no content');
        return false;//当文本框内没内容时,阻止事件发生
      }
      else {
        var li = document.createElement('li');
        li.innerHTML = text.value;
        // ul.appendChild(li);
        // 因为一般新发布留言都在最上面,改用insertbefore
        ul.insertBefore(li, ul.children[0]);

      }
    }

  </script>

node.removechild(child)删除子节点:

var ul = document.querySelector('ul');
var btn = document.querySelector('button');

btn.onclick=function() {
 if(ul.children.length==0)
btn.disable=true;

else
ul.removeChild(ul.children[0]);
}

留言框删除留言:

当我们把文本区域内的值赋值给li的时候,多加一个删除的链接
需要把所有链接取过来,点击当前链接时候,删除当前链接的li

1 加入删除按钮

 li.innerHTML = text.value + "<a href='javascript:'>shanchu</a>";

注意这里不是#:阻止链接跳转:添加javascript:void(0)/javascript:;

2 注意removechild只能删除他的孩子(删除a的上级li):

重点: 

ul.removeChild(this.parentNode);
<script>
    //获取元素
    var ul = document.querySelector('ul');
    var text = document.querySelector('textarea');
    var btn = document.querySelector('button');
    btn.onclick = function () {
      if (text.value == '') {
        alert('no content');
        return false;
      }
      else {
        var li = document.createElement('li');
        li.innerHTML = text.value + "<a href='javascript:'>shanchu</a>";
        ul.insertBefore(li, ul.children[0]);

        // 删除元素 删除他的父亲 
        //发现需要拿到所有链接
        var as = document.querySelectorAll('a');
        for (var i = 0; i < as.length; i++) {
          as[i].onclick = function () {
            ul.removeChild(this.parentNode);
          }
        }
      }


    }



  </script>

复制节点

var li = ul.children[0].cloneNode(true);
//这里括号为空或者为false表示浅拷贝,里面为true表示深拷贝
//只有深拷贝又拷贝元素又拷贝内容

动态生成表格:

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    table {
      width: 500px;
      margin: 100px auto;
      border-collapse: collapse;
      text-align: center;
    }

    td,
    th {
      border: 1px solid #333;
    }

    thead tr {
      height: 40px;
      background-color: #ccc;
    }
  </style>
</head>

<body>
  <table cellspacing="0">
    <thead>
      <tr>
        <th>姓名</th>
        <th>科目</th>
        <th>成绩</th>
        <th>操作</th>
      </tr>
    </thead>
    <tbody>

    </tbody>
  </table>
  <script>
    // data.length个tr
    // for k in data[i] 个td

    var data = [{
      name: 'name1',
      subject: 'sub1',
      score: 8
    }, {
      name: 'name2',
      subject: 'sub2',
      score: 8
    },
    {
      name: 'name3',
      subject: 'sub2',
      score: 2
    }
    ];
    //把对象obj放在数组里

    var tbody = document.querySelector('tbody');
    for (var i = 0; i < data.length; i++) {


      var tr = document.createElement('tr');
      tbody.appendChild(tr);
      for (var k in data[i]) {
        var kk = document.createElement('td');
        kk.innerHTML = data[i][k];
        tr.appendChild(kk);
        // 记住在obj里有:
        // (var k in obj)
        // k为属性,obj[k]是值
      }
      var td = document.createElement('td');
      td.innerHTML = '<a href = "javascript:;">shanchu</a>';
      // 注意这里单引号里面一定是双引号,javascript后面的:;
      tr.appendChild(td);
    }
    var da = document.querySelectorAll('a');
    for (var i = 0; i < da.length; i++) {
      da[i].onclick = function () {
        tbody.removeChild(this.parentNode.parentNode);
      }
    }
  </script>
</body>

</html>

document.write('<div>123</div>')
如果页面文档流加载完毕,再调用这句话会导致页面重绘,比如增加事件如onclick
window.onload = function() {
	整个页面加载完毕再调用js

}

第一种创建方式可以通过for循环达到添加多次多个元素的效果
for(var i=0;i<=100;i++)
inner.innerhtml += '<a href="javascript:;">shanchu</a>'



第一种方式转化成数组效率最高

var arr=[];
for(var i=0;i<100;i++)
{
 arr.push('<a href="#"></a>');
inner.innerHTML=arr.join('');//转化为数组
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/283150.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

32个关于FPGA的学习网站

语言类学习网站 1、HDLbits 网站地址&#xff1a;https://hdlbits.01xz.net/wiki/Main_Page 在线作答、编译的学习Verilog的网站&#xff0c;题目很多&#xff0c;内容丰富。非常适合Verilog初学者&#xff01;&#xff01;&#xff01; 2、牛客网 网站地址&#xff1a;https:…

简述Redis备份策略以及对应的实现机制

引言 Redis作为高性能的内存数据库&#xff0c;数据的安全性至关重要。一旦数据丢失&#xff0c;可能会对业务造成重大影响。因此&#xff0c;备份Redis数据是每个Redis使用者都必须考虑的问题。本文将介绍Redis的备份策略以及对应的实现机制。 一、备份策略 1.1 定期备份 …

【华为OD机试真题2023CD卷 JAVAJS】测试用例执行计划

华为OD2023(C&D卷)机试题库全覆盖,刷题指南点这里 测试用例执行计划 时间限制:1s 空间限制:256MB 限定语言:不限 题目描述: 某个产品当前迭代周期内有N个特性()需要进行覆盖测试,每个特性都被评估了对应的优先级,特性使用其ID作为下标进行标识。 设计了M个测试用…

FileZilla的使用以及主动模式跟被动模式

目录 FileZilla的安装 下载路径 安装 FileZilla的基本使用 添加组 添加用户 设置权限 测试 开始测试 FileZilla的主动模式及被动模式 主动模式&#xff08;Active Mode&#xff09; 被动模式&#xff08;Passive Mode&#xff09; 思维导图 ​编辑 FileZilla的安装 下载…

【基础】【Python网络爬虫】【3.chrome 开发者工具】(详细笔记)

Python网络爬虫基础 chrome 开发者工具元素面板&#xff08;Elements)控制台面板&#xff08;Console&#xff09;资源面板&#xff08;Source&#xff09;网络面板&#xff08;Network&#xff09;工具栏Requests Table详情 chrome 开发者工具 ​ 当我们爬取不同的网站是&…

以太网转RS485通讯类库封装

最近选用有人科技的以太网转RS485模块做项目&#xff0c;设备真漂亮&#xff0c;国货之光。调通了通讯的代码&#xff0c;发到网上供大家参考&#xff0c;多多交流。 以下分别是配套的头文件与源文件&#xff1a; /*******************************************************…

软件测试/测试开发丨Pytest测试用例生命周期管理-Fixture

1、Fixture 用法 Fixture 特点及优势 1&#xff64;命令灵活&#xff1a;对于 setup,teardown,可以不起这两个名字2&#xff64;数据共享&#xff1a;在 conftest.py 配置⾥写⽅法可以实现数据共享&#xff0c;不需要 import 导⼊。可以跨⽂件共享3&#xff64;scope 的层次及…

扫雷(c语言)

先开一个test.c文件用来游戏的逻辑测试&#xff0c;在分别开一个game.c文件和game.h头文件用来实现游戏的逻辑 主要步骤&#xff1a; 游戏规则&#xff1a; 输入1&#xff08;0&#xff09;开始&#xff08;结束&#xff09;游戏&#xff0c;输入一个坐标&#xff0c;如果该坐…

MFC消息机制详细剖析

易语言程序的破解99%的时候都需要用到FF55FC5F5E这个特征码 新建一个MFC应用程序&#xff1a; 去编辑MFC的.rc资源文件来DIY窗体 静态编译的&#xff0c;把很多静态库的代码都添加进去了 &#xff0c;所以速度很慢 消息机制针对的是GUI程序&#xff08;比如窗口程序&#xf…

有道翻译web端 爬虫, js

以下内容写于2023-12-28, 原链接为:https://fanyi.youdao.com/index.html#/ 1 在输入框内输入hello world进行翻译,通过检查发出的网络请求可以看到翻译文字的http接口应该是: 2 复制下链接最后的路径,去js文件中搜索下: 可以看到这里是定义了一个函数B来做文字的翻译接口函数…

快速部署supervisord详解

Supervisor是一个用于监控和管理进程的工具。它可以在Unix-like系统中启动、停止、重启和管理后台进程&#xff0c;确保这些进程始终保持运行状态。 yum check-update 更新yum软件包索引 yum install epel-release -y 下载eprl源 yum install supervisor -y 直接yu…

给多行文本的每行添加指定的前缀textwrap.indent()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 给多行文本的每行添加指定的前缀 textwrap.indent() [太阳]选择题 请问以下代码输出的第一行结果是&#xff1f; import textwrap text welcome to China! print("【显示】text\n&quo…

WEB 3D技术 three.js通过 GLTFLoader 导入并应用 gltf/glb 3D资源

上文 WEB 3D技术 three.js 雾 基础使用讲解我们讲了雾的基本使用方法 但是 如果我们要做一个树林 一颗一颗树去加 那真的是要累死了 我们一定是在建模软件上 建模好这样的模型 然后将模型导入到场景中 官网中搜索 GLTFLoader 在我们日常WEB开发中 用的最多的3D格式 就是 GLTF…

Linux---进程控制

一、进程创建 fork函数 在Linux中fork函数是非常重要的函数&#xff0c;它从已存在进程中创建一个新进程&#xff0c;原进程为父进程 fork函数的功能&#xff1a; 分配新的内存和内核数据结构给子进程将父进程部分数据结构内容拷贝至子进程添加子进程到系统的进程列表中fork返…

B+树的插入删除

操作 插入 case2的原理,非叶子节点永远和最右边的最左边的节点的值相等。 case3:的基本原理 非叶子节点都是索引节点 底层的数据分裂之后 相当于向上方插入一个新的索引(你可以认为非叶子节点都是索引),反正第二层插入160 都要分裂,然后也需要再插入(因为索引部分不需要重…

x-cmd pkg | openssl - 密码学开源工具集

目录 简介首次用户技术特点竞品分析进一步阅读 简介 OpenSSL 是一个开源的密码库和 SSL/TLS 协议实现&#xff0c;它提供了一组密码学工具和加密功能&#xff0c;用于保护数据通信的安全性。项目发展历史可以追溯到 1998 年&#xff0c;源自 Eric A. Young 和 Tim J. Hudson 开…

【后端】Docker学习笔记

文章目录 Docker一、Docker安装&#xff08;Linux&#xff09;二、Docker概念三、Docker常用命令四、数据卷五、自定义镜像六、网络七、DockerCompose Docker Docker是一个开源平台&#xff0c;主要基于Go语言构建&#xff0c;它使开发者能够将应用程序及其依赖项打包到一个轻…

java零拷贝zero copy MappedByteBuffer

目录 调用操作系统的 mmap 未使用 mmap 的文件通过网络传输的过程 使用 mmap 的文件通过网络传输的过程 使用例子 调用操作系统的 sendfile() 在 java 中的具体实现 mmap的优劣 mmap 的不足 mmap 的优点 mmap 的使用场景 对于零拷贝&#xff08;zero copy&#xff09…

LVGL 在framebuffer设备上的移植

LVGL 在framebuffer设备上的移植 ItemDescDate2023-12-31Authorhongxi.zhuplatformNXP I.MX6ULLLCDSPI TFTLCD NV3030B 文章目录 LVGL 在framebuffer设备上的移植一、LVGL源码获取二、源码修改适配三、编译&运行补充 一、LVGL源码获取 新建lvgl_imx6ull文件夹&#xff0c…

【基础】【Python网络爬虫】【10.验证码处理】OCR识别,Tesseract ,ddddocn识别,打码平台,滑块验证码(附大量案例代码)(建议收藏)

Python网络爬虫基础 验证码处理一. OCR识别1. Tesseract 引擎的安装windows引擎环境安装Mac系统引擎环境安装安装 tesseract查看 tesseract 版本安装过程遇到的报错解决方法下载中文包中文包存放目录查看全部语言库python 安装 pytesseract 和 pillow识别图片中文字体 Linux系统…