阿里云「飞天发布时刻」2024来啦!新产品、新特性、新能力、新方案,等你来探~ 了解详情
写点什么

解决实际问题的 24 个 ES6 代码段

  • 2020-10-28
  • 本文字数:4133 字

    阅读完需:约 14 分钟

解决实际问题的24个ES6代码段

这篇文章基于实际使用场景总结了 24 个 ES6 代码段,可用来解决项目中可能遇到的一系列问题。

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

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

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

const hasClass = (el, className) => el.classList.contains(className);// ExamplehasClass(document.querySelector('p.special'), 'special'); // true
复制代码

3. 如何切换元素的类?

const toggleClass = (el, className) => el.classList.toggle(className);// ExampletoggleClass(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});// ExamplegetScrollPosition(); // {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);  }};// ExamplescrollToTop();
复制代码

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

const elementContains = (parent, child) => parent !== child && parent.contains(child);// ExampleselementContains(document.querySelector('head'), document.querySelector('title')); // trueelementContains(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;};// ExampleselementIsVisibleInViewport(el); // (不完全可见)elementIsVisibleInViewport(el, true); // (部分可见)
复制代码

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

const getImages = (el, includeDuplicates = false) => {  const images = [...el.getElementsByTagName('img')].map(img => img.getAttribute('src'));  return includeDuplicates ? images : [...new Set(images)];};// ExamplesgetImages(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';// ExampledetectDeviceType(); // "Mobile" or "Desktop"
复制代码

10. 如何获取当前 URL?

const currentURL = () => window.location.href;// ExamplecurrentURL(); // '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),    {}  );// ExamplesgetURLParameters('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    }),    {}  );// ExampleformToObject(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' }] };// Exampleget(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 }));// ExamplestriggerEvent(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(', ');};// ExamplesformatDuration(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);// ExamplegetDaysDiffBetweenDates(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;};// Examplecounter('#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);  }};// ExamplecopyToClipboard('Lorem ipsum'); // 'Lorem ipsum' copied to clipboard.
复制代码

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

const isBrowserTabFocused = () => !document.hidden;// ExampleisBrowserTabFocused(); // true
复制代码

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

const fs = require('fs');const createDirIfNotExists = dir => (!fs.existsSync(dir) ? fs.mkdirSync(dir) : undefined);// ExamplecreateDirIfNotExists('test'); // creates the directory 'test', if it doesn't exist
复制代码


原文链接:


https://madza.hashnode.dev/24-modern-es6-code-snippets-to-solve-practical-js-problems


2020-10-28 10:001566

评论

发布
暂无评论
发现更多内容

融云直播 SDK 升级,让直播「PK」起来

融云 RongCloud

直播 IM 场景化

恒源云(GpuShare)_这个春天,GpuShare与你同行

恒源云

抗疫

MASA Blazor入门这一篇就够了

MASA技术团队

C# .net 组件 组件库

中台和多云管理是伪问题?运维要集体下岗了吗?

火线安全

DevOps 云原生 云安全

DevOps落地思考

火线安全

DevOps 云原生 云安全 DevOps认证

内存之旅——如何提升CMA利用率?

OpenHarmony开发者

内存 OpenHarmony

VuePress 博客之 SEO 优化(六)站长工具

冴羽

Vue 前端 vuepress SEO 博客搭建

龙蜥社区一周动态 | 3.14-3.18

OpenAnolis小助手

开源 操作系统 龙蜥社区 一周动态

以太坊的扩容革命:ETH2.0

不登山的小鲁

以太坊 扩容 Ethereum eth eth2.0

一文来了解关于分布式锁的那些事儿

Linux服务器开发

redis 分布式 分布式锁 Linux服务器开发 Linux后台开发

融云互联网通信安全揭秘之链路安全

融云 RongCloud

网络安全

公有云市场百舸争流!天翼云稳居第一梯队,进入领导者象限

天翼云开发者社区

跑马灯带你深入浅出TextView的源码世界

vivo互联网技术

android 源码分析 TextView

架构设计作业一

yang

译文《Java并发编程之volatile》

潘大壮

并发编程 volatile 后端 Java EE

长连接网关技术专题(七):小米小爱单机120万长连接接入层的架构演进

JackJiang

网络编程 websocket 即时通讯 网关 长连接

OceanBase 社区 Webinar 首播官宣|社区版 RoadMap 和性能调优!周四见

OceanBase 数据库

OceanBase 社区版

大数据项目实施的成功与失败

松子(李博源)

数据中台 数据产品经理 数据治理 数据资产

Rust 用于移动开发的几种方式

非凸科技

Java c++ Python rust 量化

2022年最热门的招聘技术技能是什么,您绝对想不到

禅道项目管理

项目管理 开发技能

安全Linux 内核提权漏洞分析

网络安全学海

网络安全 信息安全 渗透测试 WEB安全 漏洞挖掘

墨天轮访谈 | Pika数据库陈磊:云时代下,键值数据库是否会被替代?

墨天轮

数据库 KV存储引擎 国产数据库

跨境电商数据融合实践|OceanBase 助力致欧家居打造分布式跨境电商

OceanBase 数据库

oceanbase 致欧家居

行程码带星喜提八天(杂记篇)

松子(李博源)

游记 旅行

信通院推出数字化赋能者新标准天翼云获评数字化转型赋能服务集体

天翼云开发者社区

QoS 设计:车联网平台消息传输质量保障|车联网平台搭建从入门到精通 04

EMQ映云科技

物联网 IoT mqtt coap emq

洞见科技成为华东江苏大数据交易中心会员单位,创始人姚明获颁「年度数字经济卓越领袖奖」

洞见科技

数据中心 隐私计算 数据交易

Nydus 镜像加速插件迁入 Containerd 旗下

SOFAStack

“互联网+”

OpenHarmony 3.1 Beta版本关键特性解析——探秘隐式查询

OpenHarmony开发者

OpenHarmony 隐式查询

Docker Build时的安全问题

火线安全

Docker 云原生 云安全 docker build

Linux云计算之linux grep命令详解

学神来啦

云计算 Linux 运维 grep

解决实际问题的24个ES6代码段_语言 & 开发_Madza_InfoQ精选文章