解决实际问题的ES6代码段

2023-11-04

1、如何隐藏所有指定元素?

 const hide = (...el) => [...el].forEach(e => (e.style.display = 'none'));  
    // Example  
    hide(document.querySelectorAll('img')); // 隐藏页面上的所有  元素

2、 如何确认元素是否具有指定的类?

const hasClass = (el, className) => el.classList.contains(className);  
    // Example  
    hasClass(document.querySelector('p.special'), 'special'); // true

3、 如何切换元素的类?

 const toggleClass = (el, className) => el.classList.toggle(className);  
    // Example  
    toggleClass(document.querySelector('p.special'), 'special');   
    // 该段不再有 'special' 类

4、如何获取当前页面的滚动位置?

 const getScrollPosition = (el = window) => ({  
      x: el.pageXOffset !== undefined ? el.pageXOffset : el.scrollLeft,  
      y: el.pageYOffset !== undefined ? el.pageYOffset : el.scrollTop  
    });  
    // Example  
    getScrollPosition(); // {x: 0, y: 200}

5、如何平滑滚动到页面顶部?

const scrollToTop = () => {  
      const c = document.documentElement.scrollTop || document.body.scrollTop;  
      if (c > 0) {  
        window.requestAnimationFrame(scrollToTop);  
        window.scrollTo(0, c - c / 8);  
      }  
    };  
    // Example  
    scrollToTop();

6、 如何确认父元素是否包含子元素?

const elementContains = (parent, child) => parent !== child && parent.contains(child);  
    // Examples  
    elementContains(document.querySelector('head'), document.querySelector('title'));   
    // true  
    elementContains(document.querySelector('body'), document.querySelector('body')); // false

7、如何确认指定元素是否在视口可见?

const elementIsVisibleInViewport = (el, partiallyVisible = false) => {  
      const { top, left, bottom, right } = el.getBoundingClientRect();  
      const { innerHeight, innerWidth } = window;  
      return partiallyVisible  
        ? ((top > 0 && top < innerHeight) || (bottom > 0 && bottom < innerHeight)) &&  
            ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))  
        : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;  
    };  
    // Examples  
    elementIsVisibleInViewport(el); // (不完全可见)  
    elementIsVisibleInViewport(el, true); // (部分可见)

8、如何获取一个元素内的所有图像?

 const getImages = (el, includeDuplicates = false) => {  
      const images = [...el.getElementsByTagName('img')].map(img => img.getAttribute('hide'));  
      return includeDuplicates ? images : [...new Set(images)];  
    };  
    // Examples  
    getImages(document, true); // ['image1.jpg', 'image2.png', 'image1.png', '...']  
    getImages(document, false); // ['image1.jpg', 'image2.png', '...']

9、如何分辨设备是移动设备还是桌面设备?

const detectDeviceType = () =>  
      /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)  
        ? 'Mobile'  
        : 'Desktop';  
    // Example  
    detectDeviceType(); // "Mobile" or "Desktop"

10、 如何获取当前 URL?

const currentURL = () => window.location.href;  
    // Example  
    currentURL(); // 'https://google.com'

11、 如何创建一个包含当前 URL 参数的对象?

const getURLParameters = url =>  
      (url.match(/([^?=&]+)(=([^&]*))/g) || []).reduce(  
        (a, v) => ((a[v.slice(0, v.indexOf('='))] = v.slice(v.indexOf('=') + 1)), a),  
        {}  
      );  
    // Examples  
    getURLParameters('http://url.com/page?n=Adam&s;=Smith'); // {n: 'Adam', s: 'Smith'}  
    getURLParameters('google.com'); // {}

12、如何将一组表单元素编码为一个对象?

const formToObject = form =>  
      Array.from(new FormData(form)).reduce(  
        (acc, [key, value]) => ({  
          ...acc,  
          [key]: value  
        }),  
        {}  
      );  
    // Example  
    formToObject(document.querySelector('#form')); // { email: 'test@email.com', name: 'Test Name' }

13、 如何从对象中检索给定选择器指示的一组属性?

const get = (from, ...selectors) =>  
      [...selectors].map(s =>  
        s  
          .replace(/\[([^\[\]]*)\]/g, '.$1.')  
          .split('.')  
          .filter(t => t !== '')  
          .reduce((prev, cur) => prev && prev[cur], from)  
      );  
    const obj = { selector: { to: { val: 'val to select' } }, target: [1, 2, { a: 'test' }] };  
    // Example  
    get(obj, 'selector.to.val', 'target[0]', 'target[2].a'); // ['val to select', 1, 'test']

14、 如何在等待一定时间后调用提供的函数(单位毫秒)?

 const delay = (fn, wait, ...args) => setTimeout(fn, wait, ...args);  
    delay(  
      function(text) {  
        console.log(text);  
      },  
      1000,  
      'later'  
    );   
    // 一秒后记录 'later' 。

15、如何在给定元素上触发特定事件,且可选传递自定义数据?

 const triggerEvent = (el, eventType, detail) =>  
      el.dispatchEvent(new CustomEvent(eventType, { detail }));  
    // Examples  
    triggerEvent(document.getElementById('myId'), 'click');  
    triggerEvent(document.getElementById('myId'), 'click', { username: 'bob' });

16、 如何移除一个元素的事件侦听器?

 const off = (el, evt, fn, opts = false) => el.removeEventListener(evt, fn, opts);  
    const fn = () => console.log('!');  
    document.body.addEventListener('click', fn);  
    off(document.body, 'click', fn); // no longer logs '!' upon clicking on the page

17、 如何获得给定毫秒数的可读格式?

const formatDuration = ms => {  
      if (ms < 0) ms = -ms;  
      const time = {  
        day: Math.floor(ms / 86400000),  
        hour: Math.floor(ms / 3600000) % 24,  
        minute: Math.floor(ms / 60000) % 60,  
        second: Math.floor(ms / 1000) % 60,  
        millisecond: Math.floor(ms) % 1000  
      };  
      return Object.entries(time)  
        .filter(val => val[1] !== 0)  
        .map(([key, val]) => `${val} ${key}${val !== 1 ? 's' : ''}`)  
        .join(', ');  
    };  
    // Examples  
    formatDuration(1001); // '1 second, 1 millisecond'  
    formatDuration(34325055574); // '397 days, 6 hours, 44 minutes, 15 seconds, 574 milliseconds'

18、 如何获取两个日期之间的天数间隔?

 const getDaysDiffBetweenDates = (dateInitial, dateFinal) =>  
      (dateFinal - dateInitial) / (1000 * 3600 * 24);  
    // Example  
    getDaysDiffBetweenDates(new Date('2017-12-13'), new Date('2017-12-22')); // 9

19、 如何对传递的 URL 进行 GET 请求?

 const httpGet = (url, callback, err = console.error) => {  
      const request = new XMLHttpRequest();  
      request.open('GET', url, true);  
      request.onload = () => callback(request.responseText);  
      request.onerror = () => err(request);  
      request.send();  
    };  
    httpGet(  
      'https://jsonplaceholder.typicode.com/posts/1',  
      console.log  
    );   
    // Logs: {"userId": 1, "id": 1, "title": "sample title", "body": "my text"}

20、 如何对传递的 URL 进行 POST 请求?

const httpPost = (url, data, callback, err = console.error) => {  
      const request = new XMLHttpRequest();  
      request.open('POST', url, true);  
      request.setRequestHeader('Content-type', 'application/json; charset=utf-8');  
      request.onload = () => callback(request.responseText);  
      request.onerror = () => err(request);  
      request.send(data);  
    };  
    const newPost = {  
      userId: 1,  
      id: 1337,  
      title: 'Foo',  
      body: 'bar bar bar'  
    };  
    const data = JSON.stringify(newPost);  
    httpPost(  
      'https://jsonplaceholder.typicode.com/posts',  
      data,  
      console.log  
    );   
    // Logs: {"userId": 1, "id": 1337, "title": "Foo", "body": "bar bar bar"}

21、 如何为指定选择器创建具有指定范围、步长和持续时间的计时器?

const counter = (selector, start, end, step = 1, duration = 2000) => {  
      let current = start,  
        _step = (end - start) * step < 0 ? -step : step,  
        timer = setInterval(() => {  
          current += _step;  
          document.querySelector(selector).innerHTML = current;  
          if (current >= end) document.querySelector(selector).innerHTML = end;  
          if (current >= end) clearInterval(timer);  
        }, Math.abs(Math.floor(duration / (end - start))));  
      return timer;  
    };  
    // Example  
    counter('#my-id', 1, 1000, 5, 2000); // 为 id="my-id" 的元素创建一个两秒的计时器

22、 如何将一个字符串复制到剪贴板?

const copyToClipboard = str => {  
      const el = document.createElement('textarea');  
      el.value = str;  
      el.setAttribute('readonly', '');  
      el.style.position = 'absolute';  
      el.style.left = '-9999px';  
      document.body.appendChild(el);  
      const selected =  
        document.getSelection().rangeCount > 0 ? document.getSelection().getRangeAt(0) : false;  
      el.select();  
      document.execCommand('copy');  
      document.body.removeChild(el);  
      if (selected) {  
        document.getSelection().removeAllRanges();  
        document.getSelection().addRange(selected);  
      }  
    };  
    // Example  
    copyToClipboard('Lorem ipsum'); // 'Lorem ipsum' copied to clipboard.

23、 如何确定页面的浏览器选项卡是否处于前台活跃状态?

const isBrowserTabFocused = () => !document.hidden;  
    // Example  
    isBrowserTabFocused(); // true

24、如果一个目录不存在,如何创建它?

 const fs = require('fs');  
    const createDirIfNotExists = dir => (!fs.existsSync(dir) ? fs.mkdirSync(dir) : undefined);  
    // Example  
    createDirIfNotExists('test'); // creates the directory 'test', if it doesn't exist
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

解决实际问题的ES6代码段 的相关文章

  • 仿中国婚博会微信小程序

    仿中国婚博会微信小程序 app json pages pages index index pages cash cash pages marry marry pages community community pages me me pag
  • VUE项目中的全局格式化时间过滤器

    自定义格式化时间 一 问题 这是一个后台管理系统中的商品列表页 其中的时间这一项在调用接口后会发现是以毫秒来计算的 这样当然是不行的啦 要换算成我们日常使用的2020 04 07 17 13 这样的时间格式 二 解决办法 1 打开项目中的m
  • 元字符的详细解析

    上一篇文章介绍了正则的用处以及正则中这些元字符的基本含义 但是如果我们只知道那些元字符的含义 不知道怎么使用和加以练习 那么对于正则我们还只是看见了门槛 并没有踏入 那么本篇文章就让我们迈起脚步正式走入正则的世界吧 let s go 我的学
  • JS中的发布-订阅

    发布订阅模式 什么是发布 订阅模式 发布 订阅模式的实现 发布 订阅实现思路 总结 优点 缺点 Vue 中的实现 观察者模式和发布订阅的区别 观察者模式 发布订阅模式 什么是发布 订阅模式 发布 订阅模式其实是一种对象间一对多的依赖关系 当
  • 问题记录:js的=>和function

    这个问题搞了一整天 是这么一个功能
  • 微信小程序自动检测版本并提示更新新版本

    微信小程序自动检测版本并提示更新新版本 微信小程序开发过程中 我们在版本更新迭代后 微信小程序客户端并不能触发自动更新 需要用户手动清理小程序后重新搜索进入后才能获取到最新的小程序版本 但是这个是用户所不能感知到的操作 也很麻烦 故需要提醒
  • Vue中鼠标悬停更换图片/文字内容,动态展示/修改某些属性

    Vue中鼠标悬停更换图片 文字内容 动态展示 修改某些属性 鼠标悬停时 mouseenter 鼠标离开时 mouseleave 利用以上来绑定相应方法 例如 div 分别为鼠标悬停时和离开时绑定方法changeImageSrc 并传递参数
  • JavaScript重写Symbol(Symbol.iterator)实现迭代器(1)

    iterator迭代 做的跟java集合迭代差不多就行了 示例图 h1 对象遍历重写iterator接口1 h1
  • IntelliJ IDEA 15款 神级超级牛逼插件推荐(自用,真的超级牛逼)

    来源 http suo im 5X5Rql 满满的都是干货 所有插件都是在 ctrl alt s 里的plugins 里进行搜索安装 1 CodeGlance 代码迷你缩放图插件 2 Codota 代码提示工具 扫描你的代码后 根据你的敲击
  • JS声明二维数组常见办法

    JS声明二维数组常见办法 目录 文章目录 前言 new Array 和 fill fill 灵活插入 for 笨办法 Array from 前言 目前论坛常见的办法代码质量奇差 因此针对这个问题进行整理 new Array和fill con
  • 通过点击按钮在页面添加图片

    点击添加按钮 在盒子中加入图片 点击图片实现删除图片效果 代码如下
  • JavaScript every() 方法:提示、技巧和用例

    JavaScript 巩固了其作为世界上最流行和最广泛使用的编程语言之一的地位 这是有充分理由的 它的动态特性和多功能性使其成为 Web 开发 从客户端交互到服务器端编程 的首选 提高其效率的一个重要因素是内置方法的多样性 其中一种有用的方
  • js 手机、邮箱、身份证格式验证

  • 前端学习教程:快速入门前端图表插件ECharts

    前言 在前端项目开发中 有很多地方会遇到绘制图表的需求 一般的图表可以通过canvas来绘制 但是遇到复杂一点的图表怎么办呢 不要慌 在下今天就给大家推荐一个前端大佬们用的非常火的图表插件 ECharts ECharts特性简介 EChar
  • react(craco)移动端使用postcss-px-to-viewport自适应布局

    Craco 使用postcss px to viewport devDependencies craco craco 6 4 3 xianzhengquan postcss px 2 vw 0 0 1 postcss 8 3 0 peerD
  • Js中的defer属性和async属性

    Js中的defer属性和async属性 一 defer和async 1 defer 指外部js文件和当前html页面同时加载 异步加载 但只在当前页面解析完成之后执行js代码 async 指外部js文件和当前html页面同时加载 异步加载
  • 6.js--布尔值和null

    提示 文章写完后 目录可以自动生成 如何生成可参考右边的帮助文档 文章目录 目录 1 布尔数据 boolean 2 null 3 null和undefined的意义 1 布尔数据 boolean var a true var b false
  • 大数相乘,限制:不可用 BigInt

    大数相乘 限制 不可用 BigInt 大数相乘 限制 不可用 BigInt 例如 输入 a 11111111111111111111 b 22222222222222222222 返回 246913580246913580241975308
  • vue2项目实现excel文件导入导出和拖拽上传

    文章目录 一 excle文件导出 二 excel文件导入 三 文件拖拽上传 四 完整代码 文件导入导出实现逻辑图 一 excle文件导出 导出员工接口返回的是二进制流 axios配置responseType为blob接收二进制流文件为Blo
  • 课设:NFA确定化和最小化程序的设计与实现(html+css+js实现)

    文章目录 问题描述 待解决问题 1 如何存储NFA或者是DFA 2 NFA多初态问题 3 子集化过程思路 4 分割法过程思路 使用方法 下载链接 问题描述

随机推荐

  • 分类模型之职员离职分析

    今天要带来的是机器学习中几种重要的分类模型 分别是 逻辑回归 支持向量机 决策树 随机森林这四种算法模型 这里就不主要介绍模型背后的理论知识了 直接上数据 在数据分析中再来谈这些算法模型 今天要讨论的是Kaggle上的公司职员离职数据集 这
  • JS 简单实现电子时钟

    时钟的确是非常简单的一个功能 我们只需要通过js编写一个方法来获取时间的时分秒 再用定时器每隔一秒进行刷新即可 注意 通过Date类拿到的时分秒直接拼接起来可能是这样的 8 2 3 而我们想看到的效果应该是 08 02 03 所以这里我们会
  • 对于区块链,各个国家对它又是一种什么态度呢?

    在这场席卷全球的区块链技术 数字资产变革中 区块链作为一种颠覆性的技术 它的出现对各国政府提出了新的问题 对于这个问题 各国政府给出了怎样的答复 区块链在各国发展的政策环境又如何 并且我们除了要了解本国的立场之外 也需要掌握其他国家的态度
  • 谁发明了区块链?谁是中本聪?

    区块链技术首次在由中本聪 Satoshi Nakamoto 撰写的题为 比特币 对等电子现金系统 的论文中介绍 在这篇文章中 中本聪描述了区块链技术的基础 所有区块链创新都可以追溯到中本聪 他是区块链和比特币的发明者 但是 谁是中本聪 没人
  • 使用vscode搭建vue项目并引用element-ui

    1 环境准备 Visual studio code nodejs vue cli yarn 2 新建项目 1 打开Visual studio code 打开一个你想要创建项目的文件夹 2 打开集成终端如下图所示或者使用快捷键 3 在终端中输
  • LevelDB.NET 使用

    LevelDB是google实现的非常高效的kv数据库 多数是和redis比较 这里记录下如何使用 新建项目 Nuget添加类库 通过反编译发现运行时是 NET 4 0 这里我用4 5测试需要选择64位平台 代码 写数据 db Put Wr
  • python3排序 sorted(key=lambda)

    python3排序sorted key lambda 当待排序列表的元素由多字段构成时 我们可以通过sorted iterable key reverse 的参数key来制定我们根据那个字段对列表元素进行排序 key lambda 元素 元
  • 【华为OD统一考试B卷

    华为OD统一考试A卷 B卷 新题库说明 2023年5月份 华为官方已经将的 2022 0223Q 1 2 3 4 统一修改为OD统一考试 A卷 和OD统一考试 B卷 你收到的链接上面会标注A卷还是B卷 请注意 根据反馈 目前大部分收到的都是
  • StringBuilder.append()与String的"+"的效率PK

    如果String通过 来拼接 如果拼接的字符串是常量 则效率会非常高 因为会进行编译时优化 这个时候StringBuilder的append 是达不到的 如果将String的 放在循环中 会创建很多的StringBuilder对象 并且执行
  • 信贷风控中Vintage、滚动率、迁移率的理解

    风控业务背景 信贷风险管理是一门艺术 更是一门科学 资产质量分析中常会涉及到三个理论 账龄分析 Vintage Analysis 用以分析账户成熟期 变化规律等 滚动率分析 Roll Rate Analysis 用以定义账户好坏程度 迁移率
  • 未解决,fsmgmt.msc共享文件夹管理中,文件夹无属性选项

    之前用的win10家庭版 都没有fsmgmt msc 现在升级成专业版发现没有属性 https jingyan baidu com article 358570f69e9b13ce4724fce9 html 我的电脑
  • windows下redis设置redis开机自启动方法

    1 查看一下Redis服务是否注册 1 Win R快捷键输入services msc 然后回车或者点击确定 2 win10桌面 此电脑 右键单击 管理 gt 服务与应用程序 gt 服务 此处输入R 即可看到R开头的服务列表 在没有添加服务的
  • IDEA+Springboot+Git+jenkins+tomcat实现自动部署-基本流程

    jenkins构建 前言 测试项目准备 一 jenkins构建一个新项目 把Gitee仓库的项目获取到本地打包运行 二 jenkins构建一个新项目 把Gitee仓库的项目获取到本地打包 通过Publish Over SSH传输到另外一台机
  • 《在IDEA中配置MySQL的驱动程序》

    一 下载mysql connecter 下载地址 http dev mysql com downloads connector j 具体步骤已在下图中标注 注意是下载zip压缩包格式 因为解压缩安装很方便 下载完成后得到压缩包如下 二 安装
  • 深度详解ResNet到底在解决一个什么问题?

    点击上方 小白学视觉 选择加 星标 或 置顶 重磅干货 第一时间送达 https www zhihu com question 64494691 本文仅作为学术分享 如果侵权 会删文处理 最近看到不少ResNet的变体 比如ResNeSt
  • 【软考】-高项-整合管理-重要知识点思维导图

    整合管理 文章目录 整合管理 含义 内容 项目管理计划 含义 组件 开工 会议 分类 目的作用 如何召开高效会议 批准的变更请求 可交付成果 工作绩效数据 变更的流程 1 提出与记录变更申请 2 初审变更 初审目的 常见方式为变更申请文档的
  • 实例分割模型Mask R-CNN详解:从R-CNN,Fast R-CNN,Faster R-CNN再到Mask R-CNN

    Mask R CNN是ICCV 2017的best paper 彰显了机器学习计算机视觉领域在2017年的最新成果 在机器学习2017年的最新发展中 单任务的网络结构已经逐渐不再引人瞩目 取而代之的是集成 复杂 一石多鸟的多任务网络模型 M
  • React黑马视频自学笔记02

    14 react事件处理 14 1事件绑定 语法 on 事件名称 事件处理程序 比如 onClick gt 注意 React事件采用驼峰命名法 比如 onMouseEnter onFocus 函数组件绑定事件的时候不用this 14 2事件
  • 监控Oracle(oracledb_exporter)

    我们以监控Oracle为例 目前仅有x86版本 可以下载源码针对不同环境使用golang环境自己编译 监控什么指标下载对应系统的exporter插件 统一下载地址 https prometheus io download 监控指标对应的gr
  • 解决实际问题的ES6代码段

    1 如何隐藏所有指定元素 const hide el gt el forEach e gt e style display none Example hide document querySelectorAll img 隐藏页面上的所有 元