JavaScript 非常大的特点容易上手且非常灵活,代码实现方式五花八门;有时候能一行代码解决,就尽量不用两行。
本文整理了非常有用的单行代码,这些需求都是在开发中非常常见的,用单行代码可以帮助你提高工作效率。
数组去重
从数组中删除所有重复值,实现方式非常多,我们这里就说最简单的方式,一行代码搞定:
const uniqueArr = (arr) => [...new Set(arr)]; console.log(uniqueArr(["前端","js","html","js","css","html"])); // ['前端', 'js', 'html', 'css']
uniqueArr
方法将数据转为Set,然后再解构为数组返回。
从url获取参数并转为对象
网页路径经常是:www.baidu.com?search=js&xxx=kkk
这种形式的,我们是经常需要取参数的,可以使用第三方的qs
包实现,如果你只是要实现去参数,这一句代码就可以实现,不用再引入qs
了。
const getParameters = URL => JSON.parse(`{"${decodeURI(URL.split("?")[1]).replace(/"/g, '\\"').replace(/&/g, '","').replace(/=/g, '":"')}"}` ) getParameters("https://www.google.com.hk/search?q=js+md&newwindow=1"); // {q: 'js+md', newwindow: '1'}
检查对象是否为空
检查对象是否为空,实际上并不那么简单,即使对象为空,每次检查对象是否等于 {}
也会返回 false
。
幸运的是,下面的单行代码正是我们想要的。
const isEmpty = obj => Reflect.ownKeys(obj).length === 0 && obj.constructor === Object; isEmpty({}) // true isEmpty({a:"not empty"}) //false
反转字符串
反转字符串可以使用split
结合reverse
和join
方法轻松实现。
const reverse = str => str.split('').reverse().join(''); reverse('this is reverse'); // esrever si siht
生成随机十六进制
生成随机数相信你能信手拈来,那随机生成十六进制,例如生成十六进制颜色值。
const randomHexColor = () => `#${Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, "0")}` console.log(randomHexColor()); // #a2ce5b
检查当前选项卡是否在后台
浏览器使用选项卡式浏览,任何网页都有可能在后台,此时对用户来说是没有在浏览的, 知道怎么快速检测到,你的网页对用户是隐藏还是可见吗?
const isTabActive = () => !document.hidden; isTabActive() // true|false
检测元素是否处于焦点
activeElement
属性返回文档中当前获得焦点的元素。
const elementIsInFocus = (el) => (el === document.activeElement); elementIsInFocus(anyElement) // 元素处于焦点返回true,反之返回false
检查设备类型
使用navigator.userAgent
判断是移动设备还是电脑设备:
const judgeDeviceType = () => /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|OperaMini/i.test(navigator.userAgent) ? 'Mobile' : 'PC'; judgeDeviceType() // PC | Mobile
文字复制到剪贴板
Clipboard API
它的所有操作都是异步的,返回 Promise
对象,不会造成页面卡顿。而且,它可以将任意内容(比如图片)放入剪贴板。
const copyText = async (text) => await navigator.clipboard.writeText(text) copyText('单行代码 前端世界')
获取选定的文本
使用内置的 getSelection
获取用户选择的文本:
const getSelectedText = () => window.getSelection().toString(); getSelectedText(); // 返回选中的内容
查询某天是否为工作日
我们自己写日历组件时经常会用到,判断某个日期是否为工作日;周一至周五为工作日:
const isWeekday = (date) => date.getDay() % 6 !== 0; isWeekday(new Date(2022, 03, 11)) // true
转换华氏/摄氏
处理温度有时会晕头转向。这两个函数则能帮助大家将华氏温度转换为摄氏温度,以及将摄氏温度转换为华氏温度。
- 将华氏温度转换为摄氏温度
const fahrenheitToCelsius = (fahrenheit) => (fahrenheit - 32) * 5/9; fahrenheitToCelsius(50); // 10
- 将摄氏温度转华氏温度
const celsiusToFahrenheit = (celsius) => celsius * 9/5 + 32; celsiusToFahrenheit(100) // 212
两日期之间相差的天数
日常开发中经常遇到需要显示剩余天数, 一般我们就需要计算两日期之间相差天数:
const dayDiff = (date1, date2) => Math.ceil(Math.abs(date1.getTime() - date2.getTime()) / 86400000); dayDiff(new Date("2021-10-21"), new Date("2022-02-12")) // Result: 114
将 RGB 转换为十六进制
const rgbToHex = (r, g, b) => "#" + ((1 <h3 id="strong-计算数组平均值-strong"><strong>计算数组平均值</strong></h3><p>计算平均值的方式很多,计算的逻辑都是一样的, 但是实现方式各不相同,一行代码简单实现:</p><p><img src="https://img.php.cn/upload/image/458/884/487/16655730787706515%EA%B0%9C%EC%9D%98%20%EC%9A%B0%EC%95%84%ED%95%98%EA%B3%A0%20%EA%B0%84%EB%8B%A8%ED%95%9C%20JS%20%ED%95%9C%20%EC%A4%84%20%EC%BD%94%EB%93%9C%EB%A1%9C%20%EC%9E%91%EC%97%85%EC%9D%84%20%EC%A0%88%EB%B0%98%EC%9D%98%20%EB%85%B8%EB%A0%A5%EC%9C%BC%EB%A1%9C%20%EB%8D%94%EC%9A%B1%20%ED%9A%A8%EC%9C%A8%EC%A0%81%EC%9C%BC%EB%A1%9C%20%EB%A7%8C%EB%93%A4%20%EC%88%98%20%EC%9E%88%EC%8A%B5%EB%8B%88%EB%8B%A4!?x-oss-process=image/resize,p_40" title="16655730787706515개의 우아하고 간단한 JS 한 줄 코드로 작업을 절반의 노력으로 더욱 효율적으로 만들 수 있습니다!" alt="115개의 우아하고 간단한 JS 한 줄 코드로 작업을 절반의 노력으로 더욱 효율적으로 만들 수 있습니다!"></p><pre class="brush:php;toolbar:false">const average = (arr) => arr.reduce((a, b) => a + b) / arr.length; average([1,9,18,36]) //16
原文地址:https://juejin.cn/post/7145623660680708104

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

Dreamweaver Mac版
시각적 웹 개발 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
