优秀的JavaScript代码技巧大分享

简介: 优秀的JavaScript代码技巧大分享
  1. 将内容复制到剪贴板
    为了提高网站的用户体验,我们经常需要将内容复制到剪贴板,以便用户可以将其粘贴到指定位置。

const copyToClipboard = (content) => navigator.clipboard.writeText(content)
copyToClipboard("Hello fatfish")

  1. 获取鼠标选中内容
    你以前遇到过这种情况吗?我们需要获取用户选择的内容。
    const getSelectedText = () => window.getSelection().toString()
    getSelectedText()
  2. 打乱一个数组
    打乱一个数组?这在彩票程序中非常常见,但它并不是真正的随机。
    const shuffleArray = array => array.sort(() => Math.random() - 0.5)
    shuffleArray([ 1, 2,3,4, -1, 0 ]) // [3, 1, 0, 2, 4, -1]
    4.将rgba转换为十六进制
    我们可以将rgba和十六进制颜色值互相转换。
    const rgbaToHex = (r, g, b) => "#" + [r, g, b].map(num => parseInt(num).toString(16).padStart(2, '0')).join('')
    rgbaToHex(0, 0 ,0) // #000000
    rgbaToHex(255, 0, 127) //#ff007f
    5.将十六进制转换为rgba
    const hexToRgba = hex => {
    const [r, g, b] = hex.match(/\w\w/g).map(val => parseInt(val, 16))
    return rgba(${r}, ${g}, ${b}, 1);
    }
    hexToRgba('#000000') // rgba(0, 0, 0, 1)
    hexToRgba('#ff007f') // rgba(255, 0, 127, 1)
    6.获取多个数字的平均值
    使用reduce函数,我们可以非常方便地得到一组数组的平均值。
    const average = (...args) => args.reduce((a, b) => a + b, 0) / args.length
    average(0, 1, 2, -1, 9, 10) // 3.5
    7.检查一个数字是偶数还是奇数
    怎么判断一个数字是奇数还是偶数?
    const isEven = num => num % 2 === 0
    isEven(2) // true
    isEven(1) // false
    8.在数组中去重元素
    使用Set来删除数组中的重复元素,会让这个过程变得非常简单。
    const uniqueArray = (arr) => [...new Set(arr)]
    uniqueArray([ 1, 1, 2, 3, 4, 5, -1, 0 ]) // [1, 2, 3, 4, 5, -1, 0]
    //代码效果参考:http://www.guizao.net/sitemap/post1.html
    9.检查一个对象是否为空对象
    const isEmpty = obj => Reflect.ownKeys(obj).length === 0 && obj.constructor === Object
    isEmpty({}) // true
    isEmpty({ name: 'fatfish' }) // false
    10.反转字符串
    const reverseStr = str => str.split('').reverse().join('')
    reverseStr('fatfish') // hsiftaf
    11.计算两个日期之间的间隔
    const dayDiff = (d1, d2) => Math.ceil(Math.abs(d1.getTime() - d2.getTime()) / 86400000)
    dayDiff(new Date("2023-06-23"), new Date("1997-05-31")) // 9519
  3. 找出日期所在的年份中的天数
    const dayInYear = (d) => Math.floor((d - new Date(d.getFullYear(), 0, 0)) / 1000 / 60 / 60 / 24)
    dayInYear(new Date('2023/06/23'))// 174
    13.将字符串的首字母大写
    const capitalize = str => str.charAt(0).toUpperCase() + str.slice(1)
    capitalize("hello fatfish") // Hello fatfish
    14.生成指定长度的随机字符串
    const generateRandomString = length => [...Array(length)].map(() => Math.random().toString(36)[2]).join('')
    generateRandomString(12) // cysw0gfljoyx
    generateRandomString(12) // uoqaugnm8r4s
    15.在两个整数之间获取一个随机整数
    const random = (min, max) => Math.floor(Math.random() (max - min + 1) + min)
    random(1, 100) // 27
    random(1, 100) // 84
    random(1, 100) // 55
    16.指定位数四舍五入
    const round = (n, d) => Number(Math.round(n + "e" + d) + "e-" + d)
    round(3.1415926, 3) //3.142
    round(3.1415926, 1) //3.1
    17.清除所有的cookies
    const clearCookies = document.cookie.split(';').forEach(cookie => document.cookie = cookie.replace(/^ +/, '').replace(/=.
    /, =;expires=${new Date(0).toUTCString()};path=/))
    18.检测是否为暗黑模式
    const isDarkMode = window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches
    console.log(isDarkMode)
    19.滚动到页面顶部
    const goToTop = () => window.scrollTo(0, 0)
    goToTop()
    20.判断是否为苹果设备
    const isAppleDevice = () => /Mac|iPod|iPhone|iPad/.test(navigator.platform)
    isAppleDevice()
    21.随机布尔值
    const randomBoolean = () => Math.random() >= 0.5
    randomBoolean()
    22.获取变量的类型
    const typeOf = (obj) => Object.prototype.toString.call(obj).slice(8, -1).toLowerCase()
    typeOf('') // string
    typeOf(0) // number
    typeOf() // undefined
    typeOf(null) // null
    typeOf({}) // object
    typeOf([]) // array
    typeOf(() => {}) // function
    23.判断当前选项卡是否处于活动状态
    const checkTabInView = () => !document.hidden
    24.检查元素是否处于焦点状态
    const isFocus = (ele) => ele === document.activeElement
  4. 随机IP
    const generateRandomIP = () => {
    return Array.from({length: 4}, () => Math.floor(Math.random() * 256)).join('.');
    generateRandomIP() // 220.187.184.113
    generateRandomIP() // 254.24.179.151
相关文章
|
8天前
|
JavaScript 前端开发 Python
用python执行js代码:PyExecJS库
文章讲述了如何使用PyExecJS库在Python环境中执行JavaScript代码,并提供了安装指南和示例代码。
45 1
用python执行js代码:PyExecJS库
|
4天前
|
编解码 前端开发 JavaScript
javascript检测网页缩放演示代码
javascript检测网页缩放演示代码
|
6天前
|
Web App开发 JavaScript 前端开发
添加浮动按钮点击滚动到网页底部的纯JavaScript演示代码 IE9、11,Maxthon 1.6.7,Firefox30、31,360极速浏览器7.5.3.308下测试正常
添加浮动按钮点击滚动到网页底部的纯JavaScript演示代码 IE9、11,Maxthon 1.6.7,Firefox30、31,360极速浏览器7.5.3.308下测试正常
|
7天前
|
存储 JavaScript 前端开发
webSocket+Node+Js实现在线聊天(包含所有代码)
文章介绍了如何使用WebSocket、Node.js和JavaScript实现在线聊天功能,包括完整的前端和后端代码示例。
34 0
|
4天前
|
存储 JavaScript 前端开发
改进JavaScript代码,给水果有序赋色
改进JavaScript代码,给水果有序赋色
|
5天前
|
存储 JSON JavaScript
JavaScript帮我编写快递自动分拣的代码,区分省份市区县城乡镇
JavaScript帮我编写快递自动分拣的代码,区分省份市区县城乡镇在JavaScript中编写一个用于快递自动分拣的代码,区分省份、市区、县、城乡镇,通常意味着你需要一个数据结构来存储这些地理区域的信息,并编写逻辑来根据快递地址中的信息将其分配到正确的分类中。 这里,我将提供一个简化的示例,说明如何使用JavaScript对象和函数来实现这一功能。请注意,这个示例是高度简化的,并且假设你已经有了某种方式(如正则表达式或API调用)来从快递地址中提取省份、市区、县等信息。 ----------------------------------- ©著作权归作者所有:来自51CTO博客作者goS
|
6天前
|
JavaScript 前端开发 Python
python执行js代码
本文档详细介绍如何安装Node.js环境及PyExecJS库,并提供示例代码展示其功能。首先,通过指定链接安装Node.js,安装完毕后可在命令行中输入`node --version`来验证安装是否成功。接着,使用`pip install PyExecJS`安装PyExecJS库,该库允许Python程序执行JavaScript代码。文档还提供了多个示例代码,展示了如何在Python环境中执行和编译JavaScript代码,并可以选择特定的JavaScript运行时环境,如Node.js或JScript。最后,通过具体案例展示了PyExecJS的功能与使用方法。
14 3
|
15天前
|
JavaScript
网站内容禁止复制的js代码
网站内容禁止复制的js代码
|
21天前
|
缓存 JavaScript 前端开发
js和html代码一定要分离吗
JavaScript(JS)和HTML代码的分离虽非绝对必要,但通常被推荐
|
24天前
|
移动开发 JavaScript 安全
总有一款适合您分享78个JS相册代码
本文分享了78款JS相册代码,包括3D相册旋转木马、图片悬浮效果、倾斜图片幻灯片切换等特效,适用于各种图片展示场景。无论您需要哪种样式,都能在这里找到满意的解决方案。快来挑选吧!参考链接:[点击这里](https://www.vipwb.com/sitemap.xml)。
28 4
下一篇
无影云桌面