首页 > 其他分享 >Web APIs 4:日期对象、时间戳、节点操作、swiper插件

Web APIs 4:日期对象、时间戳、节点操作、swiper插件

时间:2024-09-27 10:50:07浏览次数:9  
标签:Web 插件 const APIs Date let date document 节点

Web APIs 4(日期对象、节点操作、swiper插件)

1.实例化日期对象
  • 获得当前时间:const date = new Date()
  • 获得指定时间:const data = new Date(‘2024-1-1 08:30:30’)
2.日期对象方法
方法作用说明
getFullTear()获得年份获取四位年份
getMonth()获得月份取值为0~11
getDate()获取月份中的每一天不同月份取值不同
getDay()获取星期取值为0~6
getHours()获取小时取值为0~23
getMinutes()获取分钟取值为0~59
getSeconds()获取秒取值为0~59
  • 单个获取日期实现自定义格式:
<body>
  <div></div>
  <script>
    function getMyDate() {
      const date = new Date()
      console.log(date);
      let h = date.getHours()
      h = h < 10 ? '0' + h : h
      let m = date.getMinutes()
      m = m < 10 ? '0' + m : m
      let s = date.getSeconds()
      s = s < 10 ? '0' + s : s
      return `今天是:${date.getFullYear()}年${date.getMonth() + 1}月${date.getDate()}日${h}:${m}:${s} 星期${date.getDay()}`
    }
    const div = document.querySelector('div')
    div.innerHTML = getMyDate()  //使第一秒不是空白
    setInterval(function () {
      div.innerHTML = getMyDate()
    }, 1000)
  </script>
</body>
  • 使用toLocaleString()方法格式显示:
 <script>
    const div = document.querySelector('div')
    const date = new Date()
    div.innerHTML = date.toLocaleDateString() //2024/925
    div.innerHTML = date.toLocaleString() //2024/9/25 15:47:25
  </script>
3.时间戳
  • 概念:是指1970年01月01日00时00分00秒起至现在的毫秒数,它是一种特殊的计量时间的方式
  • 使用场景:倒计时效果
  • 将来的时间戳-现在的时间戳=剩余时间的毫秒数(转换为时间的年月日时分秒就是倒计时时间)
  • 获取时间戳方法:
    • getTime()方法:需要先实例化
    • +new Date()方法:常用
    • Date.now()方法:只能得到当前的时间戳
 <script>
    //第一种方法
    const date = new Date('2024-1-1 08:30:30')
    console.log(date.getTime())
    //第二种方法
    console.log(+new Date('2024-1-1 08:30:30'))
    //第三种方法
    console.log(Date.now())
  </script>

案例:倒计时

<body>
  <div class="countdown">
    <p class="next">今天是2222年2月22日</p>
    <p class="title">下班倒计时</p>
    <p class="clock">
      <span id="hour">00</span>
      <i>:</i>
      <span id="minutes">25</span>
      <i>:</i>
      <span id="scond">20</span>
    </p>
    <p class="tips">18:30:00下课</p>
  </div>
  <script>
    const date = new Date()
    const next = document.querySelector('.next')
    next.innerHTML = `今天是${date.getFullYear()}年${date.getMonth() + 1}月${date.getDate()}日`
    function getCountTime() {
      //当前时间戳
      const now = +new Date()
      console.log(now)
      //将来时间戳
      const last = +new Date('2024-9-26 18:30:00')
      //剩余时间戳
      const time = (last - now) / 1000
      //获取时分秒
      let h = parseInt(time / 60 / 60 % 24)
      h = h < 10 ? '0' + h : h
      let m = parseInt(time / 60 % 60)
      m = m < 10 ? '0' + m : m
      let s = parseInt(time % 60)
      s = s < 10 ? '0' + s : s
      //写到对应盒子
      const hour = document.querySelector('#hour')
      const min = document.querySelector('#minutes')
      const sec = document.querySelector('#scond')
      hour.innerHTML = h
      min.innerHTML = m
      sec.innerHTML = s
    }
    //先调用一次,防止最开始的空白
    getCountTime()
    //定时器函数不要加小括号
    setInterval(getCountTime, 1000)
    // 随机颜色函数
    // 1. 自定义一个随机颜色函数
    function getRandomColor(flag = true) {
      if (flag) {
        // 3. 如果是true 则返回 #ffffff
        let str = '#'
        let arr = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f']
        // 利用for循环随机抽6次 累加到 str里面
        for (let i = 1; i <= 6; i++) {
          // 每次要随机从数组里面抽取一个  
          // random 是数组的索引号 是随机的
          let random = Math.floor(Math.random() * arr.length)
          // str = str + arr[random]
          str += arr[random]
        }
        return str

      } else {
        // 4. 否则是 false 则返回 rgb(255,255,255)
        let r = Math.floor(Math.random() * 256)  // 55
        let g = Math.floor(Math.random() * 256)  // 89
        let b = Math.floor(Math.random() * 256)  // 255
        return `rgb(${r},${g},${b})`
      }

    }
    const countdown = document.querySelector('.countdown')
    countdown.style.backgroundColor = getRandomColor()
  </script>
</body>
4.节点操作(针对元素节点)
  • DOM节点:DOM树中的每一个内容

  • 节点类型:

    • 元素节点:所有的标签,eg:body、div
    • 属性节点:所有的属性,eg:href
    • 文本节点:所有文本
  • 节点关系

    • 父节点
    • 子节点
    • 兄弟节点
  • 查找节点:(通过节点间关系):不用多次使用querySelector()去获取节点

    • 父节点:子元素.parentNode(最近一级)
    • 子节点:
      • 父元素.childNodes:获取所有子节点,包括文本、注释等
      • children(重点):仅获取所有元素节点,返回伪数组
    • 兄弟节点:
      • 下一个兄弟节点:nextElementSibling属性
      • 上一个兄弟节点:previousElementSibling属性
  • 增加节点

    • 创建节点:

      document.createElement(‘标签名’)

    • 追加节点:

      //插入到这个父元素的最后
          父元素.appendChild(要插入的元素)
      //插入到父元素中某个子元素的前面
          父元素.insertBefore(要插入的元素, 在哪个元素前面)
      
    <body>
      <ul>
        <li>我是第一个</li>
      </ul>
      <script>
        const ul = document.querySelector('ul')
        //创建节点
        const li2 = document.createElement('li')
        li2.innerHTML = '我是第二个'
        //将li2插入ul的最后
        ul.appendChild(li2)
        //创建节点
        const lim = document.createElement('li')
        lim.innerHTML = '我在第一个和第二个之间'
        //将lim节点插到li2的前面
        ul.insertBefore(lim, li2)
      </script>
    </body>
    
    • 克隆节点:元素.cloneNode(布尔值)
      • true:克隆包含后代节点一起克隆
      • false:克隆不包含后代节点,默认为false
  • 删除节点:必须通过父元素删除

    • 父元素.removeChild(要删除的元素)
    <body>
      <ul>
        <li></li>
      </ul>
      <script>
        const ul = document.querySelector('ul')
        ul.removeChild(ul.children[0])
      </script>
    </body>
    
5.M端(移动端)事件:触摸事件
  • touchstart:手指触摸到
  • touchmove:手指滑动
  • touchend:手指移开
6.swiper插件
  • 纯javascript打造的滑动特效插件,面向手机、平板电脑等移动终端。能实现触屏焦点图、触屏Tab切换、触屏轮播图切换等常用效果。
  • 操作步骤:
    • 进入swiper官网
    • 下载插件
    • 根据官网使用方法导入.css和.js文件
    • 在官网查看演示视频,并在新窗口点击查看源码进行复制
    • 根据API文档添加想要的效果

案例:轮播图

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <link rel="stylesheet" href="./swiper-bundle.min.css">
  <style>
    .box {
      position: relative;
      margin: 100px auto;
      width: 600px;
      height: 300px;
      background-color: pink;
    }

    html,
    body {
      position: relative;
      height: 100%;
    }

    body {
      background: #eee;
      font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
      font-size: 14px;
      color: #000;
      margin: 0;
      padding: 0;
    }

    .swiper {
      width: 100%;
      height: 100%;
    }

    .swiper-slide {
      text-align: center;
      font-size: 18px;
      background: #fff;
      display: flex;
      justify-content: center;
      align-items: center;
    }

    .swiper-slide img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
  </style>
</head>

<body>
  <div class="box">
    <div class="swiper mySwiper">
      <div class="swiper-wrapper">
        <div class="swiper-slide">Slide 1</div>
        <div class="swiper-slide">Slide 2</div>
        <div class="swiper-slide">Slide 3</div>
        <div class="swiper-slide">Slide 4</div>
        <div class="swiper-slide">Slide 5</div>
        <div class="swiper-slide">Slide 6</div>
        <div class="swiper-slide">Slide 7</div>
        <div class="swiper-slide">Slide 8</div>
        <div class="swiper-slide">Slide 9</div>
      </div>
      <div class="swiper-pagination"></div>
    </div>

  </div>
  <script src="./swiper-bundle.min.js"></script>
  <!-- Initialize Swiper -->
  <script>
    var swiper = new Swiper(".mySwiper", {
      loop: true,
      pagination: {
        el: ".swiper-pagination",
      },
      autoplay: {
        delay: 1000,//1秒切换一次
        pauseOnMouseEnter: true,
      },
    });
  </script>
</body>

</html>

标签:Web,插件,const,APIs,Date,let,date,document,节点
From: https://blog.csdn.net/weixin_72043867/article/details/142588227

相关文章

  • ifream跟webview 嵌套orchard core的登录
    orchardcore默认的安全策略很高。所以要设置后台要开启ocrs跟安全program.cs要配置cookie可以跨域。`builder.Services.ConfigureApplicationCookie(options=>{options.Cookie.SameSite=SameSiteMode.None;options.Cookie.SecurePolicy=......
  • pbootcms如何修改上传格式和支持webp图片
    要在PBootCMS中添加对WebP格式图片的支持,主要需要修改配置文件中的上传格式设置。以下是一个详细的步骤指南:修改步骤打开 config.php 文件找到PBootCMS安装目录下的 /config/config.php 文件。修改上传格式配置在 config.php 文件中找到上传配置部分,并增加 webp......
  • 495. 响应式潮流小游戏网页 大学生期末大作业 Web前端网页制作 html+css+js
    目录一、网页概述二、网页文件 三、网页效果四、代码展示1.html2.CSS3.JS五、总结1.简洁实用2.使用方便3.整体性好4.形象突出5.交互式强六、更多推荐欢迎光临仙女的网页世界!这里有各行各业的Web前端网页制作的案例,样式齐全新颖,并持续更新!感谢CSDN,提供了这......
  • 【dify解析】插件接口解析
    安装插件调用的接口:2024-09-2615:45:44.342INFO[Thread-89(process_request_thread)][_internal.py:97]-127.0.0.1--[26/Sep/202415:45:44]"OPTIONS/console/api/workspaces/current/tool-provider/builtin/azuredalle/updateHTTP/1.1"200-2024-09-2615:......
  • 易优CMS上传图片webp格式为何上传失败?-eyoucms
    当你遇到上传webp格式图片失败的情况时,通常有以下几个可能的原因:PHP版本过低:PHP7.1.0或更高版本才支持webp格式。图片格式问题:某些webp图片实际上并不是真正的webp格式,而是伪装成webp的jpg或png格式。解决方案检查PHP版本确认当前使用的PHP版本是......
  • 编写您的第一个 Web 组件(学习 Modulojs - 第 f 部分
    ?欢迎所有新订阅者和返回的组件编码者!我即将开始一个新的10部分教程系列。虽然我的其他教程使用modulo.js构建特定的、有趣的小应用程序,例如口袋妖怪舞会、复古挤压文本编辑器或视频游戏画廊,但本教程系列将建立在基本原则上,从第一部分开始:什么是web组件吗?html和css......
  • 构建可扩展的 Azure 静态 Web 应用程序来处理高流量网站
    tl;dr:azurestaticwebapps的免费托管计划可能无法满足高流量需求。通过最小化和压缩资产、优化图像加载、实施缓存、使用企业级边缘和自动缩放来扩展这些应用程序,以增强全球用户的性能、安全性和效率。在当今的软件开发世界中,您的应用程序不仅服务于本地社区,还覆盖来自全球各......
  • 前端使用webpack本地实现编译时出现错误[cached] 1 asset ERROR in main Module not
    一:概述Webpack是一个现代JavaScript应用程序的静态模块打包工具。它主要用于将JavaScript代码、CSS、图片等资源模块化管理,并最终打包成一个或多个文件,方便在浏览器中使用。以下是对Webpack的详细介绍:主要特点模块化:Webpack支持ES6模块、CommonJS和AMD模块,能够将各种......
  • java使用webservice 调用天气预报接口
    市场上有许多免费的和付费的天气预报API,例如OpenWeatherMap、WeatherAPI、Weatherstack等。这里我们以OpenWeatherMap为例,因为它提供了广泛的天气数据和相对简单的API接口。访问OpenWeatherMap的官网(https://openweathermap.org/) ,注册一个账户,并创建一个API密钥(APIkey)。这个密钥将......
  • Cinemachine相机控制插件(转载)
    Cinemachine插件在Unity中的实现原理主要依赖于其虚拟相机(VirtualCamera)系统和一系列算法来控制Unity中的真实相机。以下是Cinemachine插件实现原理的详细解析:一、核心组件VirtualCamera(虚拟相机):虚拟相机是Cinemachine的核心组件,它不直接渲染画面,而是存储了一系列关于相机......