JavaScript高级进阶(三)

DOM-改变HTML

语法与说明

        document.write() //改变HTML输出流,整个页面进行重绘。

        操作对象.innerHTML=新的HTML //改变HTML内容

        操作对象.attribute=新属性值 //改变HTML属性

        对象.style.property=新样式 //改变操作样式的属性

 

       注意: document.write(),优先级太高,修改的是整个的document文档,所以添加会覆盖整个的页面。

实操一下:

document.write() :

<body>

    <button οnclick="rewrite()">点击页面进行改写</button>

    <!-- 为了检测是否改写整个页面 -->

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <script>

        function rewrite(){

            document.write('document.write来了,别的都起开!')

        }

    </script>

</body>

a10098fe10ae4e85a184d589f55261e0.png

给他绑定到了这个按钮上,一点就会执行我们的write:

bbf2d407e254499eb660958e3dc70a7f.png

可以看到,确实是改变了整个页面,坐实了前面那个注意。

操作对象.innerHTML=新的HTML:

<body>

    <button οnclick="rewrite()">点击页面进行改写</button>

    <!-- 为了检测是否改写整个页面 -->

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <script>

        //innerHtml 添加新东西,覆盖旧东西

        //getElements先找到要添加的地方,像数组一样用下标找到要更改的是第几个标签

        var h1_=document.getElementsByTagName('p')[0];

        h1_.innerHTML='改变后的内容';

    </script>

</body>

0f2fbfe3b22843aeb94d708a3b9e9af2.png

 //还可以在inner中添加标签

        h1_.innerHTML='<h1>hello</h1>';

137335a21ea843baa22ad4d351268e9f.png

 操作对象.attribute=新属性值:

<body>

    <button οnclick="rewrite()">点击页面进行改写</button>

    <!-- 为了检测是否改写整个页面 -->

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <p>hello</p >

    <script>

        //innerText只是向标签内添加新的文本,覆盖掉原来的内容

        var h2_=document.getElementsByTagName('p')[1];

        h2_.innerText='text值';

    </script>

107940ea520144a28511d3fd7bab1ecc.png

 //如果带有标签(<h1>)识别不了,会把内容当成文本

        h2_.innerText='<h2>text值</h2>';

ba550217dcda4c09ae7278fb48ecf8f0.png

 至于对象.style.property=新样式,更简单,找到对应标签在style后带上想更改或添加的属性就行,下面练习中会有涉及

终于可以做这个小广告练习了,不要觉得low,前端就是要雅俗共赏,要求打开页面3秒后弹出画面,点击关闭可以去掉广告:

先做准备工作:一个写好的页面(我偷了个懒,直接截了一张图),一个广告素材和关闭素材

19d9ecfdea734b05bc72e69d6ee6eeaf.png

<title>定时弹出小广告</title>

    <style>

        *{

            margin: 0;

            padding: 0;

            box-sizing: border-box;

        }

        .bg{

            width: 100%;

            /* 最好是页面高度 */

            height: 100vh;

            background-color:rgb(255, 255, 255);

            position: relative;

        }

        .xbg{

            width: 100%;

            height: 100%;

            position: absolute;

            object-fit: cover; /* 保持图片的宽高比例,防止拉伸或压扁 */

            z-index: 1; /*背景图在最底层 */

        }

         /* 页面弹出广告后添加此标签,并设置透明度 */

        .blackbg {

            width: 100%;

            height: 100%;

            background-color: rgba(0, 0, 0, 0.5); /* 半透明黑色背景 */

            position: absolute;

            z-index: 2; /* 位于背景图之上,广告之下 */

            display: none; /* 默认不显示,广告弹出时显示 */

        }

        .ym{

            position: relative;

            height: 100%;

        }

        .gz{

            width: 618px;

            height: 238px;

            position: absolute;

            /* margin: auto;在绝对定位的情况下不生效,使用 left: 50%; top: 50%; transform: translate(-50%, -50%); 来实现水平和垂直居中。 */

            left: 50%; 

            top: 50%;

            transform: translate(-50%, -50%);

            z-index: 3;

            display: none; /* 默认不显示,几秒后显示 */

        }

        .close_{

            width: 25px;

            height: 25px;

            position: absolute;

            left: 1048px;

            top: 250px;

            z-index: 999;/*直接设在最外层,一点击把blackbg和gz,还有自己close_清掉*/

            display: none;

        }

    </style>

</head>

<body>

    <div class="bg">

        <div class="ym">

            <div class="blackbg"></div>(这玩意是,广告弹出后出现在在广告下,页面上的半透明黑色背景)

            < img src="./images/e57ee45083e1d225b186513f4c80267.png" class="xbg">(这是背景图)

            < img src="./images/26-新客优惠-弹窗@2x.png" class="gz">(广告素材)

            < img src="./images/关闭按钮@2x.png" class="close_" οnclick="clear_()">(关闭素材)

        </div>

    </div>

    <script>

        // 等待3秒后显示广告和半透明黑色背景

        var timer;

        timer = setTimeout(function() {

//这里就是通过style改变元素的属性控制其显示的。     

document.querySelector('.blackbg').style.display = 'block';

            document.querySelector('.gz').style.display = 'block';

            document.querySelector('.close_').style.display = 'block';

        }, 3000); // 3秒后显示

        // 绑定clear_()点击即可删除blackbg,gz和close_

        function clear_() {

            clearTimeout(timer); // 停止定时器

            document.querySelector('.blackbg').style.display = 'none'; // 隐藏背景

            document.querySelector('.gz').style.display = 'none'; // 隐藏广告

            document.querySelector('.close_').style.display = 'none'; // 隐藏关闭按钮

        }

    </script>

</body>

135004c54be6419c904b8167a5792de9.png

 效果就是三秒后弹出广告,点击关闭可以清掉广告和半透明黑色背景。

4e78cf53dfa541bc8b17e78b2530e1a2.png

都带着注释因该大致能看明白,定时器发生后通过document.querySelector找到类名,通过style进行样式的修改,(这里用querySelector算是偷懒了,用前面的getElements一样的效果)

至于那个display的用法,还没有学过移动端写法的同学可能还不太明白,在流式布局,弹性布局中用的多,讲移动端的时候都会说。

DOM节点之间的关系

我们想改变某块区域的样式,通过id虽然准确但太耗时费力。

在整个html文档中,每一个元素都被视为一个节点,HTMLDOM将HTML文档视作树结构,这种结构被称为节点树。

如:

870b27df4049424fb899924ba98fe06b.png

方便js通过dom操作找到每一个节点,节点和节点之间的父子关系,上下级关系,我们称之为节点直接的关系。

节点的好处:页面中任意一个节点,都可以通过节点关系来找到页面的任意另外元素。

        节点属性

        parentNode       返回节点的父节点

        childNodes        返回所有节点,包含元素节点和文本节点,换行等。

        children           返回子节点集合,只返回元素节点【标签】。

        firstChild         返回节点的第一个子节点,最普通的用法是访问该元素的文本节点。

        lastChild         返回节点的最后一个子节点。

        nextSibling      下一个节点。

        previousSibling  上一个节点。

        getAttributeNode 获取属性节点。

下面来演示一下:

以找到ul的父节点与子节点为例

<body>

    <div class="box">

        <ul class="name">

            <li>赵</li>

            <li>钱</li>

            <li>孙</li>

            <li>李</li>

        </ul>

    </div>

    <script>

        //找到ul节点

        var ul_=document.getElementsByClassName('name');

        console.log(ul_);

    </script>

不要忘了这样拿到的不是ul

d8eb2a31b5d743a9a2216fa04520729f.png

 要拿的是第0项

var ul_=document.getElementsByClassName('name')[0];

 //找到父节点

        var box =ul_.parentNode;

        console.log(box);

a24373a3a14f40c1b166c83ef31891e8.png

 //找到所有子节点

        var lis =ul_.childNodes;

        console.log(lis);

70068ed40cac452caee3fca83c72b0c5.png

所有的子节点包括元素,换行,注释。

只想返回元素节点:

        var lis_ = ul_.children;

        console.log(lis_);

dc9537723b0946fab0efaf1b1e90167f.png

 //fristChild当前元素的第一个元素节点

        console.log(ul_.firstChild);

42f9ed4d94174437a87a8ff38af77342.png

 这个节点所有的信息都在这了,那看到的为什么是#text这个玩意呢,且听后面分析。

 //lastChild最后的节点

 console.log(ul_.lastChild);

找找具体的列,不然赵钱孙李不是白写了:

        //找到赵的li

        console.log(ul_.children[0]);

1d5b117fcbb54fd697ec0fa0aee109c2.png

      //找到赵的li下第一个文本,可以搭配使用

        console.log(ul_.children[0].firstChild);

77c9d72a2b0e424f8ec90017f1670250.png

// 使用一下nextSibling,找到赵li的下一个子节点看看好不好使

        console.log(ul_.children[0].nextSibling);

a17cd259a23045d0b36af30551a634b1.png

这里为什么不轻易用那个firstChild来代替children[0],那不是更方便吗,这就涉及到前面留的坑了:

当浏览器解析 HTML 时,它不仅会解析元素节点(如 <li>),还会解析其中的 空白 换行符 作为 文本节点。因此,当你查看 firstChild 时,它可能并不是第一个 <li> 元素,而是一个代表空白的 文本节点。

HTML 结构如下:

<ul class="name">

    <li>赵</li> <!-- 第一个元素节点 -->

    <li>钱</li> <!-- 第二个元素节点 -->

    <li>孙</li>

    <li>李</li>

</ul>

在这个 <ul> 内部,浏览器在 <li> 标签之间可能插入 文本节点 来表示空格或换行符。假设浏览器解析了换行和缩进,DOM 树可能是这样:

<ul>

    #text (表示 <li>赵</li> 之前的换行或空白)

    <li>赵</li> (第一个 <li> 元素)

    #text (表示 <li>赵</li> 和 <li>钱</li> 之间的换行或空白)

    <li>钱</li> (第二个 <li> 元素)

    ...

</ul>

在这种情况下:

ul_.firstChild 实际上返回的并不是 <li>赵</li>,而是那个代表空白或换行的 文本节点。

当你调用 ul_.firstChild.nextSibling 时,返回的会是下一个 文本节点,而不是你期望的第二个 <li> 元素(<li>钱</li>)。

你可以在代码中输出 firstChild 来查看实际返回的节点类型:

console.log(ul_.firstChild); // 可能输出的是一个文本节点 (#text)

console.log(ul_.firstChild.nextSibling); // 可能输出的还是另一个文本节点 (#text)

如何解决

如果你只想获取 <li> 元素,应该使用 children 属性,它只返回 元素节点,不会包含文本节点。例如:

console.log(ul_.children[1]); // 这样可以直接获取第二个 <li>,即“钱”

children 返回的是一个 HTMLCollection,只包含元素节点,因此可以避免空白或换行符造成的干扰。

这里是为了实验nextSibling才这样写的,nextSibling也可以连续使用:

        console.log(ul_.children[0].nextSibling.nextSibling.nextSibling);

70ae827662564525bf5e4cd6b3cf91d1.png

 

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Th:1.1 建立连接

基础讲解 1.TCP通信流程 基于TCP通信的Socket基本流程: 1.1 Socket 函数返回值&#xff1a;一个文件描述符&#xff1a; 特别的两个队列。 #include <sys/types.h> #include <sys/socket.h> //create an endpoint for communication int socket(int …

vue循环渲染动态展示内容案例(“更多”按钮功能)

当我们在网页浏览时&#xff0c;常常会有以下情况&#xff1a;要展示的内容太多&#xff0c;但展示空间有限&#xff0c;比如我们要在页面的一部分空间中展示较多的内容放不下&#xff0c;通常会有两种解决方式&#xff1a;分页&#xff0c;“更多”按钮。 今天我们的案例用于…

MyBatis-config.xml核心配置

MyBatis-config.xml 包含了会深深影响MyBatis行为的设置和属性信息&#xff0c;配置文档的顶层结构如下 environments&#xff08;环境配置&#xff09; environments用于配置数据库的URL信息&#xff0c;MyBatis-config可以动态配置多个数据源&#xff0c;用于连生产、预发、…

python:编写一个函数查找字符串中的最长公共前缀

最近在csdn网站上刷到一个题目&#xff0c;题目要求编写一个函数查找字符串中的最长公共前缀&#xff0c;题目如下&#xff1a; 给出的答案如下&#xff1a; from typing import List def longestCommonPrefix(strs:List[str]) -> str:if len(strs) 0:return i 0 #代…

矩阵系统源码搭建抖音矩阵批量剪辑矩阵分发,矩阵系统可开源或oem

揭秘抖音矩阵系统源码搭建秘籍 在短视频平台迅猛增长的背景下&#xff0c;抖音矩阵系统已变成扩大创作者及企业影响力的有效工具。构建这样一个系统需要精通多种编程技术&#xff0c;本文将探讨这些关键技术点。 矩阵营销系统通过集成多项功能如跨平台的账户管理、自动化任务生…

AI周报(9.15-9.21)

AI应用-宇宙建筑师&#xff1a;AI探索宇宙结构 近日&#xff0c;来自马克斯普朗克研究所等机构&#xff0c;利用宇宙学和红移依赖性对宇宙结构形成进行了场级仿真。 AI版“宇宙闪电侠”&#xff1a;若以传统宇宙模拟的缓慢行进比作悠然自得的蜗牛&#xff0c;那么AI便宛如宇宙…

Observability:构建下一代托管接入服务

作者&#xff1a;来自 Elastic Vishal Raj, Marc Lopez Rubio 随着无服务器&#xff08;serverless&#xff09;的引入&#xff0c;向 Elastic Cloud 发送可观察性数据变得越来越容易。你可以在 Elastic Cloud Serverless 中创建一个可观察性无服务器项目&#xff0c;并将可观察…

LeetCode 每周算法 7(二分查找)

LeetCode 每周算法 7&#xff08;二分查找&#xff09; 二分查找算法&#xff1a; class Solution { public: // 定义一个函数&#xff0c;接收一个整数向量nums和一个整数target&#xff0c;返回目标值在数组中的插入位置 int searchInsert(vector<int>& nums,…

golang学习笔记4-基本数据类型

声明&#xff1a;本人已有C&#xff0c;C,Python基础&#xff0c;只写本人认为的重点&#xff0c;方便自己回顾。 go的数据类型如下 由于bool和c类似&#xff0c;和go的区别是&#xff0c;bool的值只能取true和false&#xff0c;不能取整数&#xff0c;而且有默认值false。 一…

让C#程序在linux环境运行

今晚花一些时间&#xff0c;总结net程序如何在linux环境运行的一些技术路线。 1、采用.Net Core框架 NET Core 使用了 .NET Core Runtime&#xff0c;它可以在 Windows、Linux 和 macOS 等多个操作系统上运行。可以采用Visual Studio生成Linux版本的dll。 在Linux系统中&…

系统架构笔记-2-计算机系统基础知识

知识要点-2.6计算机语言 UML 对系统架构的定义是系统的组织结构&#xff0c;包括系统分解的组成部分以及它们的关联性、交互机制和指导原则等&#xff0c;提供系统设计的信息。 具体有以下 5 个系统视图&#xff1a; 1. 逻辑视图&#xff1a;也称为设计视图&#xff0c;表示…

【WEB】EZ_Host

1、 2、解答 http://8762a9b0-5aa3-49f8-b8d2-54e4cb0746cc.www.polarctf.com:8090/?hostlocalhost;lshttp://8762a9b0-5aa3-49f8-b8d2-54e4cb0746cc.www.polarctf.com:8090/?hostlocalhost;cat flag即可看到答案

【亿美软通-注册/登录安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…

14.面试算法-字符串常见算法题(三)

1. 字符串回文问题 1.1 LeetCode.125. 验证回文串 回文问题在链表中是重点&#xff0c;在字符串中同样是个重点。当初我去美团面试第一轮技术面的第一个算法题就是让写判断字符串回文的问题。 这个本身还是比较简单的&#xff0c;只要先转换成字符数组&#xff0c;然后使用双…

OctoSQL 查询大量数据库和文件格式

OctoSQL 主要是一款 CLI 工具&#xff0c;可让你通过统一界面使用 SQL 查询大量数据库和文件格式&#xff0c;甚至在它们之间进行连接。同时&#xff0c;它还是一个易于扩展的完整数据流引擎&#xff0c;你可以用它为自己的应用程序添加 SQL 接口 OctoSQL是一款功能强大的SQL查…

Git从了解到操作

Git常用命令 基本的linux命令 ls / ll 查看当前目录( ls 是查看目录有哪些文件夹&#xff0c;ll 是查看隐藏文件)cat 查看文件内容touch 创建文件vi vi编辑器 (使用 vi 编辑器是为了方便展示效果&#xff0c;也可以记事本、editPlus、notPad等其它编辑器) 备注 Git GUl: Gi…

docker基本(仅供自己参考)

一、大型项目部署的问题&#xff1a; 1、大型项目的组件比较多&#xff0c;运行环境很复杂&#xff0c;部署通常会遇到各种问题&#xff1a; &#xff08;1&#xff09;&#xff1a;依赖关系复杂&#xff0c;容易出现兼容性问题 &#xff08;2&#xff09;&#xff1a;开发、…

雪花算法Snowflake

雪花算法常用于分布式的项目中&#xff0c;是为了解决大数据产生的多表分表中&#xff0c;保证id的唯一性。 1.分布式的特点 全局唯一性&#xff1a;不能出现有重复ID的标识&#xff1b;地增性&#xff1a;确保生成的ID对用于用户或业务是递增的&#xff1b;高可用性&#xf…

施耐德EcoStruxure Machine SCADA Expert(EMSE)与SQL数据库连接(十五)

我习惯使用SQL Server 数据库与EMSE进行连接。 用的是sql 2017 关于数据库软件的安装教程 网上一大把。 1.新建数据库 打开数据库管理工具&#xff0c;新建数据库 2.新建表单 &#xff08;ps:这里先做一个小测试-----目的是验证与EMSE软件的链接是否顺畅。) 添加两个元素进去…

flask的学习记录

结构如下&#xff1a; app.py from App import create_appapp create_app()if __name__ __main__:app.run(debugTrue,host0.0.0.0,port5000) App/__init__.py from flask import Flask, render_template, request, redirect, url_for from .views import blue from .exts …