Web APIs 4 日期对象、节点操作

news2025/1/11 22:29:02

Web APIs 4

  • 一、日期对象
    • 实例化
    • 日期对象方法
      • 案例:页面显示时间
    • 时间戳
  • 二、节点操作
    • 查找结点
      • ①父节点查找
      • ②子节点查找
      • ③兄弟节点查找
    • 增加节点
    • 克隆节点
    • 删除节点
  • 三、M端事件
  • 四、JS插件

一、日期对象

学习路径:实例化、日期对象方法、时间戳

实例化

创建一个时间对象并获取时间

获得当前时间

const date = new Date()
console.log(date) // Mon Feb 19 2024 16:45:04 GMT+0800 (中国标准时间)

获得指定时间

const date = new Date('2008-8-8')
console.log(date) // Fri Aug 08 2008 00:00:00 GMT+0800 (中国标准时间)

日期对象方法

在这里插入图片描述

const date = new Date()
console.log(date.getFullYear()); // 2024
console.log(date.getMonth() + 1); // 2
console.log(date.getDate()); // 19
console.log(date.getDay());//返回的是 周几,但是周天是0

案例:页面显示时间

需求:将当前时间以:YYYY-MM-DD HH:mm 形式显示在页面 2008-08-08 08:08

<style>
  div {
    width: 300px;
    height: 40px;
    border: 1px solid pink;
    text-align: center;
    line-height: 40px;
  }
</style>
<body>
  <div></div>
</body>
<script>
  function getMyDate() {
    const date = new Date()

    let month = date.getMonth() + 1
    let day = date.getDate()
    let h = date.getHours()
    let m = date.getMinutes()
    let s = date.getSeconds()

    month = month < 10 ? '0' + month : month
    day = day < 10 ? '0' + day : day
    h = h < 10 ? '0' + h : h
    m = m < 10 ? '0' + m : m
    s = s < 10 ? '0' + s : s

    return `${date.getFullYear()}${month}${day}${h}:${m}:${s}`
    // return `2024年2月19日 16:56:00`
  }

  const div = document.querySelector('div')
  

  div.innerHTML = getMyDate()
  //如果不写上面这一句 刷新的时候会有空白,回调函数的意思是隔了一秒再调用
  setInterval(function(){
    div.innerHTML = getMyDate()
  },1000)
</script>

或者还有几种方法

<script>
  const div = document.querySelector('div')
  const date = new Date()
  
  div.innerHTML = date.toLocaleString() //2024/2/19 17:10:43
  div.innerHTML = date.toLocaleDateString() //2024/2/19
  div.innerHTML = date.toLocaleTimeString() //17:11:35
</script>

时间戳

使用场景: 如果计算倒计时效果,前面方法无法直接计算,需要借助于时间戳完成

什么是时间戳: 是指1970年01月01日00时00分00秒起至现在的毫秒数,它是一种特殊的计量时间的方式

算法:

① 将来的时间戳 - 现在的时间戳 = 剩余时间毫秒数

② 剩余时间毫秒数 转换为 剩余时间的 年月日时分秒 就是 倒计时时间

③ 比如 将来时间戳 2000ms - 现在时间戳 1000ms = 1000ms

④ 1000ms 转换为就是 0小时0分1秒

在这里插入图片描述

// 指定时间的时间戳
console.log(+new Date('2022-4-1 18:30:00'))

二、节点操作

DOM节点:DOM树里每一个内容都称之为节点

节点类型

①元素节点

​ 所有的标签 比如 body、 div

​ html 是根节点

②属性节点

​ 所有的属性 比如 href

③文本节点

​ 所有的文本

④其他
在这里插入图片描述

重点记住元素节点

可以更好的让我们理清标签元素之间的关系

查找结点

关闭二维码案例:点击关闭按钮, 关闭的是二维码的盒子(也就是按钮的父节点), 还要获取二维码盒子

解法:关闭按钮 和 二维码是父子关系。所以,我们完全可以这样做:点击关闭按钮, 直接关闭它的爸爸,就无需获取二维码元素了

节点关系:针对的找亲戚返回的都是对象

​ 父节点

​ 子节点

​ 兄弟节点

查找结点默认元素节点。

①父节点查找

parentNode 属性

返回最近一级的父节点 找不到返回为null

语法 :子节点.parentNode

<body>
  <div class="grandfather">
    <div class="dad">
      <div class="baby"></div>
    </div>
  </div>
</body>
<script>
  const baby = document.querySelector('.baby')
  console.log(baby);
  console.log(baby.parentNode);
  console.log(baby.parentNode.parentNode);
</script>

在这里插入图片描述

广告关闭案例

  <div class="box">
    我是广告
    <div class="box1">X</div>
  </div>
  <script>
    const box1 = document.querySelector('.box1')
    box1.addEventListener('click', function() {
      this.parentNode.style.display = 'none'
        //这里用了this
    })
  </script>


这里如果有多个广告
<body>
  <div class="box">
    我是广告
    <div class="box1">X</div>
  </div>
  <div class="box">
    我是广告
    <div class="box1">X</div>
  </div>
  <div class="box">
    我是广告
    <div class="box1">X</div>
  </div>
  <script>
    const closeBtn = document.querySelectorAll('.box1')
    for(let i = 0; i < closeBtn.length; i++) {
      closeBtn[i].addEventListener('click', function() {
        this.parentNode.style.display = 'none'
      })
    }
  </script>

②子节点查找

  • childNodes

​ 获得所有子节点、包括文本节点(空格、换行)、注释节点等

  • children 属性 (重点)

​ 仅获得所有元素节点

​ 返回的还是一个伪数组,选的是最近的子节点

<body>
  <ul>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
  </ul>
</body>
<script>
  const ul = document.querySelector('ul')
  console.log(ul.children);
</script>

③兄弟节点查找

  • 下一个兄弟节点 nextElementSibling 属性
  • 上一个兄弟节点 previousElementSibling 属性
<body>
  <ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
  </ul>
</body>
<script>
  const li2 = document.querySelector('ul li:nth-child(2)')
  console.log(li2.previousElementSibling);
  console.log(li2.nextElementSibling);
</script>

增加节点

很多情况下,我们需要在页面中增加元素。比如,点击发布按钮,可以新增一条信息

一般情况下,我们新增节点,按照如下操作:

  • 创建一个新的节点

  • 把创建的新的节点放入到指定的元素内部

步骤1.创建节点

创建元素节点方法 document.createElement(‘标签名’)

步骤2.追加节点

要想在界面看到,还得插入到某个父元素中

  • 插入到父元素的最后一个子元素: 父元素.appendChild(要插入的元素)

  • 插入到父元素中某个子元素的前面: 父元素.insertBefore(要插入的元素,在那个元素前面)

<body>
  <ul>
    <li>哈哈哈</li>
  </ul>
</body>
<script>
  const ul = document.querySelector('ul')

  const li = document.createElement('li')
  li.innerHTML="我是追加的li"
  ul.appendChild(li)
</script>
<body>
  <ul>
    <li>哈哈哈</li>
  </ul>
</body>
<script>
  const ul = document.querySelector('ul')

  const li = document.createElement('li')
  li.innerHTML="我是追加的li"

  ul.insertBefore(li, ul.children[0])
</script>

克隆节点

特殊情况下,我们新增节点,按照如下操作:

复制一个原有的节点

把复制的节点放入到指定的元素内部 先克隆再追加

语法:元素.cloneNode(布尔值)

  • 克隆一个已有节点
  • 括号内传入布尔值:若为true,则代表克隆时会包含后代节点一起克隆;若为false,则代表克隆时不包含后代节点(只克隆标签); 默认为false,大部分情况都是true
<body>
  <ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
  </ul>
</body>
<script>
  const ul = document.querySelector('ul')
  // 克隆第一个li
  const li1_copy = ul.children[0].cloneNode(true)

  ul.appendChild(li1_copy)
</script>

删除节点

若一个节点在页面中已不需要时,可以删除它

在 JavaScript 原生DOM操作中,要删除元素必须通过父元素删除,这里必须是亲爸爸亲儿子

语法:父元素.removeChild(要删除的元素)

【注意】:

  • 如不存在父子关系则删除不成功

  • 删除节点和隐藏节点(display:none) 有区别的: 隐藏节点还是存在的,但是删除,则从html中删除节点,从DOM树中删除了

<body>
  <ul>
    <li>没用的</li>
    <li>有用的</li>
  </ul>
</body>
<script>
  const ul = document.querySelector('ul')
  ul.removeChild(ul.children[0])
</script>

三、M端事件

M端,就是mobile,移动端。

移动端也有自己独特的地方。比如触屏事件 touch(也称触摸事件),Android 和 IOS 都有。

  • 触屏事件 touch(也称触摸事件),Android 和 IOS 都有。

  • touch 对象代表一个触摸点。触摸点可能是一根手指,也可能是一根触摸笔。触屏事件可响应用户手指(或触控笔)对屏幕或者触控板操作。

  • 常见的触屏事件如下:
    在这里插入图片描述

<style>
  div {
    width: 300px;
    height: 400px;
    background-color: pink;
  }
</style>
<body>
  <div></div>
</body>
<script>
  const div = document.querySelector('div')
  div.addEventListener('touchstart', function() {
    console.log('开始触摸');
  })
  div.addEventListener('touchend', function() {
    console.log('触摸结束');
  })
  div.addEventListener('touchmove', function() {
    console.log('一直触摸');
  })
</script>

四、JS插件

  • 插件:就是别人写好的一些代码,我们只需要复制对应的代码,就可以直接实现对应的效果

  • 学习插件的基本过程

熟悉官网,了解这个插件可以完成什么需求 https://www.swiper.com.cn/

看在线演示,找到符合自己需求的demo https://www.swiper.com.cn/demo/index.html

查看基本使用流程 https://www.swiper.com.cn/usage/index.html

查看APi文档,去配置自己的插件 https://www.swiper.com.cn/api/index.html

注意: 多个swiper同时使用的时候, 类名需要注意区分

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

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

相关文章

论文学习——一种新的具有分层响应系统的动态多目标优化算法

论文题目&#xff1a;A Novel Dynamic Multiobjective Optimization Algorithm With Hierarchical Response System 一种新的具有分层响应系统的动态多目标优化算法&#xff08;Han Li , Zidong Wang , Fellow, IEEE, Chengbo Lan, Peishu Wu , and Nianyin Zeng , Member, IE…

c++ 常用的STL

前言 写这篇博客目的是为了记录在刷算法题中使用过的STL&#xff0c;因为有些不太常用的会遗忘。这篇博客只是作为笔记&#xff0c;不是详细的STL&#xff0c;因此只会对常用方法说明&#xff0c;不会详细介绍。此外在后面用到新的STL内容时会再补充。 列队 基础列队 基本列…

YOLOv8-Seg改进:特征融合篇 | GELAN(广义高效层聚合网络)结构来自YOLOv9

🚀🚀🚀本文改进:使用GELAN改进架构引入到YOLOv8 🚀🚀🚀YOLOv8-seg创新专栏:http://t.csdnimg.cn/KLSdv 学姐带你学习YOLOv8,从入门到创新,轻轻松松搞定科研; 1)手把手教你如何训练YOLOv8-seg; 2)模型创新,提升分割性能; 3)独家自研模块助力分割; 1.YO…

申请公众号上限是多少

一般可以申请多少个公众号&#xff1f;公众号申请限额在过去几年内的经历了很多变化。对公众号申请限额进行调整是出于多种原因&#xff0c;确保公众号内容的质量和合规性。企业公众号的申请数量从50个到5个最后到2个&#xff0c;对于新媒体公司来说&#xff0c;这导致做不了公…

基于深度视觉实现机械臂对目标的识别与定位

机械臂手眼标定 根据相机和机械臂的安装方式不同&#xff0c;手眼标定分为眼在手上和眼在手外两种方式&#xff0c;双臂机器人的相机和机械臂基座的相对位置固定&#xff0c;所以应该采用眼在手外的手眼标定方式。 后续的视觉引导机械臂抓取测试实验基于本实验实现&#xf…

CentOS 7 devtoolset编译addressSanitizer版本失败的问题解决

在我的一个Cent OS7开发环境中&#xff0c;按https://yeyongjin.blog.csdn.net/article/details/134178420的方法升级GCC版本到8.3.1。 这两天&#xff0c;要用Google的addressSanitizer检验内存问题&#xff0c;加上编译参数后&#xff0c;却发现编译不通过。configure时直接退…

微服务韧性工程:利用Sentinel实施有效服务容错与限流降级

目录 一、雪崩效应 二、Sentinel 服务容错 2.1 Sentinel容错思路 2.2 内部异常兼容 2.3 外部流量控制 三、Sentinel 项目搭建 四、Sentinel 工作原理 服务容错是微服务设计中一项重要原则和技术手段&#xff0c;主要目标是在服务出现故障、网络波动或其他不可预见的异常情况…

5G 网络切片VLAN ID配置错误导致业务不可用

【摘要】随着电联5G共建共享工作的开展&#xff0c;无法及时有效观测到单逻辑站点的相关指标&#xff0c;导致单运营商用户业务出现异常。本案例中着重对单运营商用户无法使用网络进行相关参数排查&#xff0c;从KPI性能指标结合故障告警发生时间&#xff0c;从而分析由于网络切…

Web APIs 5 Window对象、本地存储

Web APIs 5 一、Window对象1、BOM2、定时器-延时函数3、JS执行机制4、location对象案例&#xff1a;5秒钟之后跳转的页面 5、navigator对象6、histroy对象 二、本地存储本地存储 localStorage本地存储 sessionStorage存储复杂数据类型案例&#xff1a;学生就业统计表字符串拼接…

光致发光谱荧光量子效率测量系统

荧光量子积分球是一个专门用于测量荧光量子效率的设备。荧光量子效率是指物质吸收光后所发射的荧光光子数与所吸收的激发光光子数之间的比值。这种设备通过比较待测荧光物质和已知荧光量子产率的参比物质&#xff0c;在相同激发条件下所测得的积分荧光强度&#xff08;即校正的…

微信小程序实现上拉加载更多

一、前情提要 微信小程序中实现上拉加载更多&#xff0c;其实就是pc端项目的分页。使用的是scroll-view&#xff0c;scroll-view详情在微信开发文档/开发/组件/视图容器中。每次上拉&#xff0c;就是在原有数据基础上&#xff0c;拼接/合并上本次上拉请求得到的数据。这里采用…

搜狐新闻Hybrid AI引擎端侧离线大语言模型探索

本文字数&#xff1a;3027字 预计阅读时间&#xff1a;20分钟 01 一、导读 • LLM 以及移动平台落地趋势 • 搜狐AI引擎内建集成离线可运行的GPT模型 • Keras 定制预训练模型 • TensorFlow Lite converter 迁移到移动设备 02 二、LLM 1.1什么是LLM L…

HTML入门:属性

你好&#xff0c;我是云桃桃。今天来聊一聊 HTML 属性写法和特点。 HTML 属性是用于向 HTML 标签&#xff08;也叫 HTML 元素&#xff09;提供附加信息或配置的特性。 如果说&#xff0c;把HTML 标签比作一个房子&#xff0c;HTML 标签定义了房子的结构和用途&#xff0c;比如…

蓝桥杯之【01背包模版】牛客例题展示

牛客链接 #include <bits/stdc.h> using namespace std; int n,V; const int N1010; int v[N],w[N]; int dp[N][N]; int main() {cin>>n>>V;for(int i1;i<n;i){cin>>v[i]>>w[i];}for(int i1;i<n;i){for(int j1;j<V;j){dp[i][j]dp[i-1][…

idea远程服务器debug

前提 本地代码和服务器代码一致 idea中创建远程服务 一般只需要修改ip&#xff0c;注意这边的端口是监听Socket的端口&#xff0c;不是服务的端口 然后把运行参数复制一下 -agentlib:jdwptransportdt_socket,servery,suspendn,address5005 tomcat启动 在tomcat的lib下的c…

OJ_二叉排序树

题干 C实现 循环双指针法(一个指向父亲&#xff0c;一个指向待插入结点) #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <queue> using namespace std;struct TreeNode {char data;TreeNode* left;TreeNode* right; };void InsertBST(TreeNode* …

扩展黄永刚原始晶体塑性程序加入AF背应力模拟金属疲劳问题

参考文献&#xff1a;《Low-cycle fatigue life prediction of a polycrystalline nickel-base superalloy using crystal plasticity modelling approach》 在原始程序中修改流动方程&#xff0c;加入背应力项&#xff0c;引入运动硬化项&#xff0c;从而可以描述多晶金属循环…

智慧公厕系统的运作过程

智慧公厕是一种新型的未来城市公共厕所&#xff0c;通过物联网、互联网、大数据、云计算、自动化控制等技术&#xff0c;实现公共厕所使用、运营、管理、养护的全过程全方位信息化。 那么&#xff0c;智慧公厕是如何运作的&#xff1f;智慧公厕的运作过程包括什么技术&#xf…

悬浮工具球(仿 iphone 辅助触控)

悬浮工具球&#xff08;仿 iphone 辅助触控&#xff09; 兼容移动端 touch 事件点击元素以外位置收起解决鼠标抬起触发元素的点击事件问题 Demo Github <template><divref"FloatingBal"class"floating_ball":class"[dragging, isClick]&q…

【Docker4】使用Harbor搭建私有仓库

Docker私有仓库一、搭建本地私有仓库1、daemon.json 配置文件中常用配置项2、搭建私有仓库3、Docker容器重启策略 二、Docker--harbor私有仓库部署与管理1、Harbor 简介2、Harbor的特性3、Harbor的构成4、Harbor 部署4.1、部署 Docker-Compose 服务4.2、部署 Harbor 服务4.3、启…