20230310----重返学习-DOM元素的操作-时间对象-定时器
创始人
2024-06-01 13:06:54
0

day-024-twenty-four-20230310-DOM元素的操作-时间对象-定时器

复习

  • 获取元素
    • id
      • document.getElementById()
    • 类名
      • document.getElementsByClassName()
    • 标签名
      • document.getElementsByTagName()
    • name属性
      • document.getElementsByName()
    • 选择器
      • document.querySelector()
      • document.querySelectorAll()
    • 简写
      • document.documentElement
      • document.head
      • document.body
  • 获取屏幕宽高
    • screenWidth = document.documentElement.clientWidth||document.body.clientWidth
    • screenHeight = document.documentElement.clientHeight||document.body.clientHeight
  • 节点类型
    • 元素节点
    • 属性节点
    • 文本节点
    • 注释节点
    • 文档节点
  • 节点与元素节点是不一样的
  • 获取关联节点
    • parentNode 父节点 节点只可能是元素节点
    • childNodes 子节点
    • children 子元素节点
    • firstChild 第一个子节点
    • firstElementChild 第一个子元素节点
    • lastChild 最后一个子节点
    • lastElementChild 最后一个子元素节点
    • previousSibling 上一个兄弟节点
    • previousElementSibling 上一个兄弟元素节点
    • nextSibling 下一个兄弟节点
    • nextElementSibling 下一个兄弟元素节点

如果一个属性名称或方法单词拼写忘记了

  • 直接用dir打印出该对象,看它身上的属性,得大概知道那个属性或方法的样子
  • 打开MDN文档查看一下该方法或属性,得大概知道它的开头

DOM

  • 增删改

    • document.createElement(tagName) 创建元素节点
    • document.createTextNode(textContent) 创建文本节点
  • 节点插入

    • 父节点.appendChild(当前节点)

    • 父节点.insertBefore(当前节点, 后方参照节点)

      var  insertedNode = parentNode.insertBefore(newNode, referenceNode)
      //newNode:将要插入的节点
      //referenceNode:被参照的节点(即要插在该节点之前)
      //insertedNode:插入后的节点
      //parentNode:父节点
      
  • 创建了DOM元素,如果没插入到页面,那么页面上就不会显示

    
    DOM元素增删改
    box
  • DOM元素对象.innerHTML

    • 不能直接插入DOM节点对象
  • DOM元素对象.innerText

    • 不能直接插入DOM节点对象
  • cloneNode() 克隆节点

    • cloneNode()用于把某一个节点进行克隆
      • element.cloneNode(); 浅克隆,只是克隆了一个节点,里面的内容还有样式都没克隆
      • element.cloneNode(true); 深克隆,把节点包含的所有内容进行克隆
  • removeChild() 删除节点

    • parentNode.removeChild(item)
  • 属性节点操作属性值

    • getAttribute() 获取对应属性的属性值
      • targetElement.getAttribute(‘class’)
    • setAttribute() 设置对应属性的属性值
      • 必须要有两个参数,只有一个参数会报错
      • targetElement.setAttribute(‘fang1’,‘fangtofang1’)
    • removeAttribute() 删除对应属性
      • targetElement.removeAttribute(‘name’)
  • 中括号语法操作DOM属性

    • elementObject.fang3='fangtofang3'elementObject['fang3']='fangtofang3' 设置对应属性的属性值
    • elementObject.fang3elementObject['fang3'] 获取对应属性的属性值
    • delete elementObject.fang4delete elementObject['fang3']
  • 属性节点操作与中括号语法操作有区别,不能混用

    • 属性节点的操作是放在标签身上的
      • 基于Attribute dom方法增删改,是修改html结构来完成的(此种方法设置的在结构上可以看到)
    • 中括号语法的操作是放在DOM元素对象上的
      • 基于键值对方式 增删改:修改当前对象的堆内存空间完成的(在堆内存空间可以看到)
    • 以上两种方式不能混用

复习
box原生内容

box原生子元素

案例

  • 利用a标签上的search属性与hash属性来处理url字符串

时间对象

  • 时间对象的作用
    • Date 对象用于处理日期和时间。
  • 创建时间对象
    • new Date()
    • 时间对象是一个对象
  • 相关方法
    • getFullYear();获取年
    • getMonth();获取月 0到11 代表1月到12月
    • getDate();获取日期
    • getDay();星期几 (0—6)代表周日到到周六
    • getHours();时
    • getMinutes();分
    • getSeconds();秒
    • getMilliseconds();毫秒
    • getTime();获取当前日期到1970年1月1号 00:00:00 之间的毫秒差
    • toLocaleString();// 获取到的是年月日,时分秒"2019/12/25 上午10:15:50"
    • toLocaleDateString();// 获取到是字符串的年月日,例如:“2019/12/25”
    • toLocaleTimeString();/ 获取到的是字符串的时分秒上午10:18:28
  • 看到new就是构造函数,如果不传参数,函数的小括号可以省略。
  const date = new Date();console.log(date, "当前时间");const dateType = typeof new Date();console.log(dateType, "时间对象的类型"); //'object'const dateObject = new Date("Sat Jul 09 2022 01:02:03 GMT+0800 (中国标准时间)");console.log([dateObject]); //"Sat Jul 09 2022 01:02:03 GMT+0800 (中国标准时间)";//因为调用toString()隐式转化了。// console.dir(dateObject)//可以看到它就是一个对象。console.log(dateObject.getFullYear()); //2022console.log(dateObject.getMonth()); //6console.log(dateObject.getDate()); //9console.log(dateObject.getDay()); //6 [0,6] [周日 到 周一 到 周六]console.log(dateObject.getHours()); //1console.log(dateObject.getMinutes()); //2console.log(dateObject.getSeconds()); //3console.log(dateObject.getMilliseconds()); //0console.log(dateObject.getTime()); //1657299723000console.log(dateObject.toLocaleString()); //2022/7/9 01:02:03console.log(dateObject.toLocaleDateString()); //2022/7/9console.log(dateObject.toLocaleTimeString()); //01:02:03

当日静态时间

  function getTimeString() {function addZero(num) {return num > 9 ? num : `0${num}`;}const time = new Date();const year = time.getFullYear();const month = time.getMonth() + 1;const date = time.getDate();const hours = time.getHours();const minutes = time.getMinutes();const seconds = time.getSeconds();const milliseconds = time.getMilliseconds();const weekIndex = time.getDay();const weeksList = ["日", "一", "二", "三", "四", "五", "六"];const day = weeksList[weekIndex];const nowTime = `${addZero(year)}年${addZero(month)}月${addZero(date)}日 ${addZero(hours)}时${addZero(minutes)}分${addZero(seconds)}秒${addZero(milliseconds)} 周${day}`;return nowTime;}console.log(getTimeString())

定时器

  • 定时器是异步任务,只要当同步代码执行完毕之后,才能执行。

  • 定时器的参数说明

    • 定时器可以传递多个参数
      1. 执行的函数
      2. 时间
      3. 后面的参数就是执行函数在执行的时候传递的实参
  • setInterval() 间隔多少时间后,去执行某些事情,是多次调用

      // setInterval(function(){},1000)const timer1 = setInterval(() => {console.log("setInterval(),每过一次时间间隔就执行一次", 1);}, 1000);const theFunction = () => {console.log("定时器可以传递多个参数:1、执行的函数 2、时间 3、后面的参数就是执行函数在执行的时候传递的实参 定时器是有返回值的,返回值代表定时器处于当前页面中的第几个", 2);}const timer2 = setInterval(theFunction, 1000);
    
  • setTimeout() 一定的时间后,去执行某些事情,是单次调用

      // setTimeout(function(){},1000)const timer2 = setTimeout(() => {console.log("setTimeout(),第一次时间执行一次,之后都不再执行", 1);}, 1000);const theFunction = (arg1,arg2) => {console.log("定时器可以传递多个参数", arg1,arg2);//"定时器可以传递多个参数",'入参一','入参二'}const timer2 = setTimeout(theFunction, 1000,'入参一','入参二');
    
  • 每个定时器都会返回一个定时器编号

    • 返回值代表当前定时器是当前页面中的第几个定时器

      • 定时器编号是延时定时器与重复执行定时器共用的。

        • 但清除定时器时,延时定时器与重复执行定时器都各自要调用各自对应的方法
    • 可以用对应的清理定时器的方法来清除该定时器。

        const timer1 = setInterval(() => {console.log("setInterval()");}, 1000);const timer2 = setTimeout(() => {console.log("setTimeout()");}, 1000);console.log("timer1--->", timer1);console.log("timer2--->", timer2);clearInterval(timer1);clearTimeout(timer2);
      
  • 清除定时器

    • clearInterval()

      • 用来清除setInterval()所生成的定时器

          const timer1 = setInterval(() => {console.log("setInterval()");}, 1000);clearInterval(timer1);
        
    • clearTimeout()

      • 用来清除setTimeout()所生成的定时器

          const timer2 = setTimeout(() => {console.log("setTimeout()");}, 1000);clearTimeout(timer2);
        

进阶参考

  1. async/await原理揭秘
  2. JS中attribute和property的区别 - DOM元素上的属性两种设置方法的区别

相关内容

热门资讯

南瓜先生1新版安卓系统,体验全... 你知道吗?最近手机界可是炸开了锅,南瓜先生1新版安卓系统横空出世,简直让人眼前一亮!这款系统不仅带来...
安卓系统怎么按压开枪键,安卓系... 你有没有想过,在安卓手机上玩游戏时,那个按压开枪键到底是怎么设置的?是不是有时候按得不够快,或者不够...
福特派支持安卓系统吗,福特派车... 你有没有想过,你的手机和汽车之间能有什么交集呢?想象当你驾驶着福特汽车,车内的娱乐系统可以无缝连接你...
安卓系统原理详解图,深入剖析底... 你有没有想过,那个陪伴你每天刷抖音、玩游戏、办公的安卓系统,它里面到底藏着怎样的秘密呢?今天,就让我...
如何在安卓系统上装驱动,轻松实... 你有没有遇到过在安卓系统上安装驱动的时候,感觉就像是在迷宫里找出口一样?别急,今天就来手把手教你如何...
安卓系统80手机,80手机性能... 你有没有发现,最近安卓系统80手机在市场上可是火得一塌糊涂呢!这不,我就来给你好好扒一扒这款手机的那...
安卓系统怎么设定闹钟,轻松设定... 你有没有发现,每天早上闹钟一响,整个人就像被电击了一样,瞬间清醒?没错,闹钟可是我们每天早晨的“闹钟...
封闭安卓车机系统破解,破解之旅... 你有没有遇到过这样的情况:买了一辆新车,车机系统封闭得像一座城堡,想装个导航、听听音乐都变得超级麻烦...
如何换手机安卓系统桌面,轻松打... 亲爱的手机控们,是不是觉得自己的安卓手机桌面已经乱七八糟,急需来个大变身呢?别急,今天就来手把手教你...
安卓系统自动打开定位,安卓系统... 手机里的安卓系统是不是有时候会自动打开定位功能,让你觉得有点儿尴尬呢?比如,你只是想悄悄地查个地图,...
华为安卓系统屏锁忘了,解锁攻略... 你是不是也遇到了这个让人头疼的问题?华为安卓系统屏锁忘了密码,这可真是让人抓耳挠腮的。别急,今天就来...
安卓系统升级清理,深度清理与性... 亲爱的手机控们,你是不是也和我一样,对安卓系统的升级清理充满了好奇和期待呢?每次系统更新,都仿佛是给...
安卓系统更改wifi的dns 你有没有发现,家里的WiFi有时候上网速度慢得让人抓狂?别急,别急,让我来告诉你一个小秘密:通过更改...
安卓系统取消休眠设置,解锁设备... 你知道吗?最近安卓系统来了一次大变动,那就是取消了休眠设置。这可真是让人眼前一亮,让我们一起来看看这...
夏普电视安卓系统吗,畅享无限 亲爱的读者们,你是否在寻找一款既时尚又实用的电视呢?夏普电视可是近年来市场上的一大热门,而它的操作系...
安卓系统能连键盘,畅享便捷输入... 你有没有想过,你的安卓手机或者平板,竟然可以轻松连接键盘呢?没错,就是那种你打字时能感受到指尖触感的...
ios系统跟安卓系统哪个内存大... 你有没有想过,为什么你的手机有时候会卡得像蜗牛一样爬?这背后其实隐藏着一个有趣的秘密——那就是iOS...
骁龙888安卓系统手机,性能与... 你有没有发现,最近手机圈里有个大热门啊?没错,就是骁龙888安卓系统手机!这可是今年最火的处理器,各...
安卓系统apk安装包,从APK... 你有没有遇到过这种情况?手机里突然缺了个啥,比如一款超好用的游戏或者实用的工具,一看,得,得下载个A...
小米手环如何装安卓系统,系统升... 你有没有想过,你的小米手环也能升级成安卓系统呢?没错,就是那个让手机焕然一新的操作系统!今天,就让我...