JavaScript - Api学习 Day03 (日期对象、节点操作、两种定时器、本地存储)

news2024/11/15 23:50:51

文章目录

  • 一、日期对象
    • 1.1 实例化
    • 1.2 日期对象方法
  • 二、节点操作
    • 2.1 父子兄弟节点
      • 1. 父节点查找
      • 2. 子节点查找
      • 3. 兄弟关系查找
    • 2.2 增删节点
      • 1. 创建节点 - `createElement`
      • 2. 添加节点
        • 2.1 `appendChild()` 方法
        • 2.2 `insertBefore()` 方法
        • 2.3. 克隆节点 - `cloneNode`
      • 3. 删除节点
        • 3.1 `removeChild()` 方法
        • 3.2 `remove()` 方法
      • 4. 替换节点
        • `replaceChild()` 方法
  • 三、其他
    • 3.1 定时器 的对比
      • 延时函数(setTimeout)
      • 间歇函数(setInterval)
    • 3.2 Js执行机制
  • 四、本地存储
    • 4.1 localStorage
    • 4.2 存储分类sessionStorage
    • 4.3 区别:
    • 4.4 存储复杂数据类型到localStorage
      • 字符串拼接

一、日期对象

1.1 实例化

// 创建一个全局的日期格式化器
const globalFormatter = new Intl.DateTimeFormat('zh-CN', {
    // locale: 指定语言环境,这里是中文(中国)
    // 用于确定日期和时间的显示格式以及使用的日历系统。

    // options: 配置选项对象,用于指定日期和时间的格式化细节

        // timeZone: 指定时区,这里是东八区(上海)
        // 用于确定日期和时间的时区。
        timeZone: 'Asia/Shanghai',

        // year: 年份的显示方式
        // 'numeric': 显示完整的年份数字,例如 2023
        // '2-digit': 显示两位数的年份,例如 23
        year: 'numeric',

        // month: 月份的显示方式
        // 'numeric': 显示数字,例如 5
        // '2-digit': 显示两位数的数字,例如 05
        // 'long': 显示完整月份名称,例如 五月
        // 'short': 显示缩写的月份名称,例如 五月
        // 'narrow': 显示最短的月份名称,例如 5月
        month: '2-digit',

        // day: 日的显示方式
        // 'numeric': 显示数字,例如 20
        // '2-digit': 显示两位数的数字,例如 20
        day: '2-digit',

        // hour: 小时的显示方式
        // 'numeric': 显示数字,例如 14
        // '2-digit': 显示两位数的数字,例如 14
        hour: '2-digit',

        // minute: 分钟的显示方式
        // 'numeric': 显示数字,例如 30
        // '2-digit': 显示两位数的数字,例如 30
        minute: '2-digit',

        // second: 秒的显示方式
        // 'numeric': 显示数字,例如 45
        // '2-digit': 显示两位数的数字,例如 45
        second: '2-digit'
    
});

// 使用全局日期格式化器
function formatDateTime(date) {
    // 使用 globalFormatter 格式化传入的 date 参数
    // 返回格式化后的日期和时间字符串
    return globalFormatter.format(date);
}

在这里插入图片描述

1.2 日期对象方法

在这里插入图片描述
时间戳是一个特定的时间,通常以数字表示,用于标记事件发生的确切时间。在计算机科学中,时间戳通常是一个数字,表示从某个特定时间点(如1970年1月1日)到当前时间的毫秒数或秒数。时间戳在记录事件顺序、计算时间间隔和跟踪时间相关数据时非常有用。

在这里插入图片描述

二、节点操作

2.1 父子兄弟节点

node.parentNode: 获取当前节点的父节点。
node.childNodes: 获取当前节点的所有子节点。
node.firstChild: 获取当前节点的第一个子节点。
node.lastChild: 获取当前节点的最后一个子节点。
node.previousSibling: 获取当前节点的前一个兄弟节点。
node.nextSibling: 获取当前节点的下一个兄弟节点。

你描述了如何在DOM中通过父节点、子节点以及兄弟节点来查找和操作节点。下面我将详细解释这些属性和它们的用法。

1. 父节点查找

  • parentNode 属性

    • 用于获取当前节点的父节点。
    • 如果当前节点没有父节点(比如根节点),则返回null
    const child = document.getElementById('child');
    const parent = child.parentNode; // 获取父节点
    

2. 子节点查找

  • childNodes 属性

    • 返回一个包含所有子节点的NodeList,包括元素节点、文本节点(如空格、换行)和注释节点。
    • NodeList是一个类数组对象,可以通过索引访问,但它不是一个真正的数组。
    const parent = document.getElementById('parent');
    const allChildren = parent.childNodes; // 获取所有子节点,包括文本和注释节点
    
  • children 属性(重点)

    • 返回一个包含所有子元素节点的HTMLCollection,不包括文本节点、注释节点等。
    • HTMLCollection是一个类数组对象,可以通过索引访问。
    const parent = document.getElementById('parent');
    const elementChildren = parent.children; // 获取所有元素节点
    

3. 兄弟关系查找

  • 下一个兄弟节点

    • nextElementSibling 属性
      • 用于获取当前节点的下一个兄弟元素节点(即下一个同级元素节点),如果没有则返回null
    const current = document.getElementById('current');
    const nextSibling = current.nextElementSibling; // 获取下一个兄弟元素节点
    
  • 上一个兄弟节点

    • previousElementSibling 属性
      • 用于获取当前节点的上一个兄弟元素节点(即上一个同级元素节点),如果没有则返回null
    const current = document.getElementById('current');
    const previousSibling = current.previousElementSibling; // 获取上一个兄弟元素节点
    

2.2 增删节点

当然,下面是按照从创建开始到增删的顺序,重新整理的内容:

1. 创建节点 - createElement

  • 功能: createElement 用于创建指定标签名称的 HTML 元素节点。
  • const newElement = document.createElement(tagName);
    
  • 参数:
    • tagName: 字符串,表示要创建的元素的标签名称(例如 div, span, p 等)。

2. 添加节点

2.1 appendChild() 方法
  • 功能: 将一个节点添加为指定父节点的最后一个子节点。
  • parentNode.appendChild(newNode);
    
2.2 insertBefore() 方法
  • 功能: 在指定的参考节点之前插入一个新的节点。
  • parentNode.insertBefore(newNode, referenceNode);
    
2.3. 克隆节点 - cloneNode
  • 功能: cloneNode 用于克隆一个节点,可以选择是否深度克隆(包括其子节点)。
  • const clonedNode = originalNode.cloneNode(deep);
    
  • 参数:
    • deep: 布尔值,表示是否进行深度克隆。如果为 true,则克隆节点及其所有子节点;如果为 false,则只克隆节点本身,不包括子节点。默认false

3. 删除节点

3.1 removeChild() 方法
  • 功能: 从父节点中移除一个子节点,并返回被移除的节点。
  • parentNode.removeChild(childNode);
    
3.2 remove() 方法
  • 功能: 直接删除节点本身。
  • element.remove();
    

4. 替换节点

replaceChild() 方法
  • 功能: 用一个新的节点替换一个子节点,并返回被替换的节点。
  • parentNode.replaceChild(newNode, oldNode);
    

三、其他

3.1 定时器 的对比

延时函数(setTimeout)用于在指定的时间后执行一次函数,而间歇函数(setInterval)用于每隔一定时间重复执行函数。

延时函数(setTimeout)

  • 函数语法setTimeout(function, delay)
  • 介绍setTimeout 函数会在指定的延迟时间后执行一次指定的函数。
  • 例子
setTimeout(function() {
    console.log('延时函数执行了!');
}, 2000);

请添加图片描述

间歇函数(setInterval)

  • 函数语法setInterval(function, delay)
  • 介绍setInterval 函数会每隔指定的时间重复执行指定的函数。
  • 例子
setInterval(function() {
    console.log('间歇函数执行了!');
}, 1000);

请添加图片描述

3.2 Js执行机制

JavaScript的执行机制是单线程的,采用的是事件循环模型。

代码执行时,会被分为同步任务和异步任务,同步任务会按顺序执行,而异步任务会被放入任务队列中,在主线程空闲时才会被执行。事件循环会不断地从任务队列中取出任务执行,这样就实现了异步操作。

同步任务是按照代码顺序依次执行,执行完一个才能执行下一个,会阻塞后续代码的执行;

// 同步任务示例
console.log("Start");
for (let i = 0; i < 3; i++) {
    console.log(i);
}
console.log("End");

异步任务不会等待,会先继续执行后续代码,当异步任务完成后会通过回调函数或者Promise来通知执行结果。这样可以提高程序的性能和响应速度。

// 异步任务示例
console.log("Start");
setTimeout(() => {
    console.log("Async task completed");
}, 2000);
console.log("End");

执行栈(call stack)是用来存储代码执行过程中的上下文和调用关系的数据结构,遵循先进后出的原则。任务队列(task queue)则用来存储异步任务的回调函数。事件循环会不断地将任务队列中的任务取出,放入执行栈中执行,这样实现了异步任务的执行。

四、本地存储

4.1 localStorage

// 存储数据到localStorage
localStorage.setItem('key', 'value');

// 从localStorage获取数据
const data = localStorage.getItem('key');

// 删除localStorage中的数据
localStorage.removeItem('key');

// 清空localStorage
localStorage.clear();

4.2 存储分类sessionStorage

// 存储数据到sessionStorage
sessionStorage.setItem('key', 'value');

// 从sessionStorage获取数据
const data = sessionStorage.getItem('key');

// 删除sessionStorage中的数据
sessionStorage.removeItem('key');

// 清空sessionStorage
sessionStorage.clear();

在这里插入图片描述

4.3 区别:

  • 作用域:localStorage的数据在浏览器关闭后仍然存在,而sessionStorage的数据在当前会话结束(关闭标签页或浏览器)时会被清除。
  • 存储大小:localStorage的存储容量较大,一般为5MB,而sessionStorage的容量较小,一般为5MB。
  • 共享性:localStorage的数据在同一域名下的不同窗口、标签页之间共享,而sessionStorage的数据只在同一标签页下共享。
  • 生命周期:localStorage的数据不会过期,除非手动删除,而sessionStorage的数据在会话结束时自动删除。
  • 用途:localStorage适合长期存储,sessionStorage适合临时存储会话数据。

4.4 存储复杂数据类型到localStorage

  1. 将复杂数据类型(如对象)转换为JSON字符串:使用JSON.stringify()方法将对象转换为字符串库存储在本地。
  2. 将JSON字符串存储到localStorage中:使用localStorage.setItem()方法将JSON字符串存储在localStorage中,以指定的键名作为标识。
  3. 从localStorage获取数据:使用localStorage.getItem()方法获取存储在localStorage中的JSON字符串。
  4. 解析JSON字符串为复杂数据类型:使用JSON.parse()方法将获取的JSON字符串解析为原始的复杂数据类型,如对象或数组。
// 存储复杂数据类型到localStorage(需要先将对象转换为JSON字符串)
const complexObject = { name: 'Alice', age: 30 };
localStorage.setItem('complexData', JSON.stringify(complexObject));

// 从localStorage获取并解析复杂数据类型
const storedData = localStorage.getItem('complexData');
const parsedData = JSON.parse(storedData);
console.log(parsedData);

字符串拼接

通过map方法,我们将数组中的每个数字转换为字符串形式,得到一个新的字符串数组stringArray。然后,我们使用join方法将这个字符串数组中的元素用指定的分隔符(这里是-)连接起来,得到最终的拼接字符串result


// 使用map和join方法实现字符串拼接
const array = [1, 2, 3, 4, 5];

// 使用map方法将数组元素转换为字符串
const stringArray = array.map(num => num.toString());

// 使用join方法将字符串数组连接成一个字符串
const result = stringArray.join('-');

console.log(result); // 输出: "1-2-3-4-5"

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

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

相关文章

开放式运动耳机评测怎么样?真人实测总结分享

其实对于很多人来说&#xff0c;为了保持身体的健康&#xff0c;还是蛮喜欢适当运动的。不过&#xff0c;跑步有时候还是有点枯燥的&#xff0c;所以能提升运动兴趣的装备必须提前安排。除了舒服的衣服&#xff0c;耳机也是必不可少的&#xff0c;跟着节奏踩点跑步也很容易分泌…

【数据库】MySQL-基础篇-SQL

专栏文章索引&#xff1a;数据库 有问题可私聊&#xff1a;QQ&#xff1a;3375119339 目录 一、SQL通用语法 二、SQL分类 三、DDL 1.数据库操作 1.1 查询所有数据库 1.2 查询当前数据库 1.3 创建数据库 1&#xff09;案例&#xff1a; 1.4 删除数据库 1.5 切换数据库…

Hadoop运行jps没有datanode节点【已解决】

1 原因&#xff1a; 格式化NameNode后&#xff0c;如果DataNode的clusterID与新的NameNode的clusterID不匹配&#xff0c;DataNode将无法加入集群&#xff0c;导致HDFS无法正常提供服务。 2 解决方式&#xff1a; 将新的NameNode的clusterID与DataNode的clusterID保持一致 &…

C#使用MQTT(二):MQTT客户端

上一篇我们初步设计了MQTT服务端 C#使用MQTT(一):MQTT服务端-CSDN博客 这里我们设计客户端MQTT Client,接上一篇 新建Windows窗体FormMqttClient 窗体FormMqttClient设计如图&#xff1a; 窗体FormMqttClient设计器相关代码如下 文件FormMqttClient.Designer.cs namespace…

【软件测试】软件测试-----什么是Bug?Bug是如何分级的?Bug的生命周期是怎样的?如何描述一个Bug?

博客目录 一.软件测试的生命周期二.BUG的定义和级别2.1 bug的概念.2.2 如何描述一个bug.2.3bug的级别2.3.1 bug分级的意义.2.3.2 bug的四种级别. 三.BUG的生命周期.四.当与开发人员发生冲突该如何处理(高频面试)五.总结 一.软件测试的生命周期 软件测试贯穿于软件的整个生命周…

Day-02-QPushButton设置信号与槽一在UI界面直接设置槽函数

1.点击UI界面 2.选择Push Button按键 3.右键选择转到槽 4.根据自己的需要选择信号事件 5.在自动生成的函数内编写自己需要完成的动作

【网络安全】服务基础第一阶段——第十一节:Windows系统管理基础----PKI技术与应用

目录​​​​​​​ 一、加密技术 1.1 基本保密通信模型 1.2 密码学发展 1.2.1 古典密码学&#xff08;1949年前&#xff09; 1.2.2 近代密码学&#xff08;1949&#xff5e;1975年&#xff09; 1.2.3 现代密码学&#xff08;1976年以后&#xff09; 1.3 古典密码 1.3.…

基因组学中的深度学习

----/ START /---- 基因组学其实是一门将数据驱动作为主要研究手段的学科&#xff0c;机器学习方法和统计学方法在基因组学中的应用一直都比较广泛。 不过现在多组学数据进一步激增——这个从目前逐渐增多的各类大规模人群基因组项目上可以看出来&#xff0c;这其实带来了新的挑…

数字签名,数字证书,时间戳

简介 数字签名、数字证书和时间戳是现代网络安全技术中的重要组成部分&#xff0c;它们共同确保了数据传输的安全性和完整性。 数字签名 数字签名是一种基于公钥加密技术的电子签名方式。它通过使用发送方的私钥对消息进行加密生成一个特定的签名值&#xff0c;并将该签名值与…

四川财谷通抖音小店新宠儿,科技生活一键购!

在数字经济蓬勃发展的今天&#xff0c;电商平台如雨后春笋般涌现&#xff0c;其中抖音小店凭借其庞大的用户基础、精准的算法推荐以及创新的营销模式&#xff0c;成为了众多商家竞相入驻的热门选择。而四川财谷通信息技术有限公司&#xff0c;作为这一领域内的佼佼者&#xff0…

煤矿广播通信系统

在煤矿这样的特殊工作环境中&#xff0c;煤矿广播通信系统发挥着至关重要的作用。它就如同煤矿中的“传音使者”&#xff0c;保障着各项工作的顺利进行和人员的安全。 系统功能 煤矿广播通信系统具备多种强大的功能。首先&#xff0c;它拥有实时广播功能&#xff0c;能够及时传…

应用商店优化(ASO)的四大误区

应用商店优化 (ASO) 是移动营销中最重要的部分之一&#xff0c;可以帮助开发人员吸引自然流量并在应用推广方面取得预期效果。近年来ASO优化在开发者中越来越受欢迎。虽然它已经证明了其有效性和对应用成功的影响力&#xff0c;但尽管如此仍然存在与ASO相关的误解&#xff0c;导…

Rust 赋能前端:PDF 分页/关键词标注/转图片/抽取文本/抽取图片/翻转...

❝ 我从不幻想成功。我只会为了成功努力实践 大家好&#xff0c;我是柒八九。一个专注于前端开发技术/Rust及AI应用知识分享的Coder ❝ 此篇文章所涉及到的技术有 WebAssembly Mupdf Pdf操作( 分页展示/文本抽离/文本标注/获取超链接/Pdf转图片/翻转/截取) 因为&#xff0c;行文…

Chrome 浏览器插件获取网页 window 对象(方案一)

前言 最近有个需求&#xff0c;是在浏览器插件中获取 window 对象下的某个数据&#xff0c;当时觉得很简单&#xff0c;和 document 一样&#xff0c;直接通过嵌入 content_scripts 直接获取&#xff0c;然后使用 sendMessage 发送数据到插件就行了&#xff0c;结果发现不是这…

【unplugin-vue-router】超级实用的自动路由,具体使用教程!

一、安装 vite 创建vue项目的时候选择 auto import 【推荐】 二、使用 原理&#xff1a;参考 vite 官网 来看一个简单的例子&#xff1a; 这是项目的pages目录结构 src/pages/ ├── index.vue ├── about.vue └── users/├── index.vue└── [id].vueunplugin-…

C语言08--指针数组结合

前言&#xff1a; 这次的指针数组结合乃作者呕心沥血之作&#xff0c;大家翻翻进度条就知道了&#xff0c;内容十分干货&#xff0c;各位读者若能全部耐心解析读懂了&#xff0c;想必也能理解掌握C语言中的数组指针这两把利剑了。 指针数组结合&#xff1a; 指针数组 概念&a…

异步编程学习

UniTask UniTask 访问UniTask的GitHub的主页可以直接下载unity Package进行导入&#xff0c;或者通过 Package Manager导入&#xff0c;导入完成之后根据文档加一下 宏定义“UNITASK_DOTWEEN_SUPPORT” 这样就可以正常的控制DoTween了 2.UniTask 的简单使用 // UniTask 是可以作…

lambda表达式用法——C#学习笔记

“Lambda 表达式”是一个匿名函数&#xff0c;它可以包含表达式和语句&#xff0c;并且可用于创建委托或表达式目录树类型。 实例如下&#xff1a; 代码如下&#xff1a; using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.…

景联文科技:专业视频标注服务助力计算机视觉应用升级

视频标注是指对视频内容进行分析&#xff0c;并在视频中的特定对象、行为或事件上添加标签的过程。 视频标注包括&#xff1a; 1. 对象检测与跟踪 •对象检测&#xff1a;在每一帧中识别并定位特定的对象&#xff0c;如人、车、动物等。 •对象跟踪&#xff1a;跟踪这些对象…

你知道吗?Python现在这么火爆的真相!

Python之所以如此火爆&#xff0c;主要得益于其多方面的优势和广泛的应用场景。以下是对Python火爆原因的详细归纳&#xff1a; 1. 易学易用 语法简洁&#xff1a;Python的语法设计非常简洁、直观&#xff0c;易于学习和理解。初学者能够快速上手&#xff0c;减少编写代码时的…