当前位置: 首页 > article >正文

JavaScript常用技巧专题一

文章目录

  • 一、前言
  • 二、生成随机颜色的两种方式
    • 2.1、生成`RandomHexColor`
    • 2.2、生成随机`RGBA`
  • 三、复制内容到剪贴板的两种方式
    • 3.1、方式1
    • 3.2、方式2
  • 四、获取`URL`中的查询参数
  • 五、打乱数组
  • 六、深拷贝一个对象
  • 七、确保元素在可见区域内
  • 八、获取当前选中的文本
  • 九、浏览器`cookie`
    • 9.1、获取所有浏览器`cookie`
    • 9.2、删除指定名称的`cookie`
  • 十、将多维数组转换为一维数组
  • 十一、最后

一、前言

本专题主要是分享JavaScript实用小技巧,希望能提高大家的工作效率。

二、生成随机颜色的两种方式

2.1、生成RandomHexColor

const generateRandomHexColor = () => {
  return `#${Math.floor(Math.random() * 0xffffff).toString(16).padStart(6, '0')}`
}
generateRandomHexColor() // #a8277c
generateRandomHexColor() // #09c20c
generateRandomHexColor() // #dbc319

2.2、生成随机RGBA

const generateRandomRGBA = () => {
  const r = Math.floor(Math.random() * 256)
  const g = Math.floor(Math.random() * 256)
  const b = Math.floor(Math.random() * 256)
  const a = Math.random().toFixed(2)
  return `rgba(${[ r, g, b, a ].join(',')})`
}
generateRandomRGBA() // rgba(242,183,70,0.21)
generateRandomRGBA() // rgba(65,171,97,0.72)
generateRandomRGBA() // rgba(241,74,149,0.33)

三、复制内容到剪贴板的两种方式

3.1、方式1

const copyToClipboard = (text) => navigator.clipboard && navigator.clipboard.writeText && navigator.clipboard.writeText(text)
copyToClipboard('hello medium')

3.2、方式2


const copyToClipboard = (content) => {
  const textarea = document.createElement("textarea")
  textarea.value = content
  document.body.appendChild(textarea)
  textarea.select()
  document.execCommand("Copy")
  textarea.remove()
}
copyToClipboard('hello medium')

四、获取URL中的查询参数

const parseQuery = (name) => {
  return new URL(window.location.href).searchParams.get(name)
}
// https://medium.com?name=fatfish&age=100
parseQuery('name') // fatfish
parseQuery('age') // 100
parseQuery('sex') // null

五、打乱数组

const shuffle = (array) => array.sort(() => 0.5 - Math.random())
shuffle([ 1, -1, 2, 3, 0, -4 ]) // [2, -1, -4, 1, 3, 0]
shuffle([ 1, -1, 2, 3, 0, -4 ]) // [3, 2, -1, -4, 0, 1]

六、深拷贝一个对象

如何深拷贝对象?使用 StructuredClone 使其变得非常容易。

const obj = {
  name: 'fatfish',
  node: {
    name: 'medium',
    node: {
      name: 'blog'
    }
  }
}
const cloneObj = structuredClone(obj)
cloneObj.name = '1111'
cloneObj.node.name = '22222'
console.log(cloneObj)
/*
{
    "name": "1111",
    "node": {
        "name": "22222",
        "node": {
            "name": "blog"
        }
    }
}
*/
console.log(obj)
/*
{
    "name": "fatfish",
    "node": {
        "name": "medium",
        "node": {
            "name": "blog"
        }
    }
}
*/

七、确保元素在可见区域内

IntersectionObserver可以轻松检测某个元素是否在可见区域内

const isElInViewport = (el) => {
  return new Promise(function(resolve) {
    const observer = new IntersectionObserver((entries) => {
      entries.forEach((entry) => {
        if (entry.target === el) {
          resolve(entry.isIntersecting)
        }
      })
    })
    observer.observe(el)
  })
}
const inView = await isElInViewport(document.body)
console.log(inView) // true

八、获取当前选中的文本

许多翻译网站都有此功能,你可以选择文本并将其翻译成另一个国家的语言。

const getSelectedContent = () => window.getSelection().toString()

九、浏览器cookie

9.1、获取所有浏览器cookie

非常方便的帮助我们获取浏览器中的cookie信息

const getAllCookies = () => {
  return document.cookie.split(";").reduce(function(cookieObj, cookie) {
    const cookieParts = cookie.split("=")
    cookieObj[cookieParts[0].trim()] = cookieParts[1].trim()
    return cookieObj
  }, {})
}
getAllCookies() 
/*
{
    "_ga": "GA1.2.496117981.1644504126",
    "lightstep_guid/medium-web": "bca615c0c0287eaa",
    "tz": "-480",
    "nonce": "uNIhvQRF",
    "OUTFOX_SEARCH_USER_ID_NCOO": "989240404.2375598",
    "sz": "2560",
    "pr": "1",
    "_dd_s": "rum"
}
*/

9.2、删除指定名称的cookie

只能删除没有 HttpOnly 标志的 cookie

const clearCookie = (name) => {
  document.cookie = name + "=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;";
}
clearCookie('_ga') // _ga is removed from the cookie

十、将多维数组转换为一维数组

虽然,我们通过递归函数将多维数组转换为一维数组,但是有一个非常简单的方法可以解决这个问题。

const flatten = (array) => {
  return array.reduce((result, it) => {
    return result.concat(Array.isArray(it) ? flatten(it) : it)
  }, [])
}
const arr = [
  1,
  [
    2,
    [
      3,
      [
        4,
        [
          5,
          [
            6
          ]
        ]
      ]
    ]
  ]
]
console.log(flatten(arr)) // [1, 2, 3, 4, 5, 6]

秘诀就是使用数组的扁平化方法。

const arr = [
  1,
  [
    2,
    [
      3,
      [
        4,
        [
          5,
          [
            6
          ]
        ]
      ]
    ]
  ]
]
console.log(arr.flat(Infinity)) // [1, 2, 3, 4, 5, 6]

十一、最后

本人每篇文章都是一字一句码出来,希望对大家有所帮助,多提提意见。顺手来个三连击,点赞👍收藏💖关注✨,一起加油☕


http://www.kler.cn/news/163298.html

相关文章:

  • Flink流批一体计算(23):Flink SQL之多流kafka写入多个mysql sink
  • 达梦数据库dm8守护集群部署手册
  • 浅谈Elastic Stack组件集成和应用
  • (时域和频域)控制系统响应速度和稳定性分析
  • 三种定时任务总结
  • C# .NET平台提取PDF表格数据,并转换为txt、CSV和Excel表格文件
  • 【51单片机系列】74HC595实现对LED点阵的控制
  • JS中的闭包
  • 做数据分析为何要学统计学(5)——什么问题适合使用t检验?
  • C语言 - 字符函数和字符串函数
  • 【vSphere | VM】虚拟机自定义规范Ⅲ —— 创建 Linux 虚拟机自定义规范
  • mongdb配置ssl
  • 用Python实现十大经典排序算法(附动图)
  • 周赛374(枚举、思维题、分组循环+枚举、组合数学)
  • Docker网络原理及Cgroup硬件资源占用控制
  • Apollo新版本Beta自动驾驶技术沙龙参会体验有感—百度自动驾驶开源框架
  • 电脑软件:TileIconifier开始菜单美化工具介绍
  • 大电流H桥电机驱动电路的设计与解析(包括自举电路的讲解,以IR2104+LR7843为例)
  • linux常用命令-yum命令详解(超详细)
  • 视频处理关键知识
  • 用C++实现队列顺序结构的基本操作
  • 年底不同外贸客户催单模板分享
  • 大数据技术4:Lambda和Kappa架构区别
  • 机器学习实验三:支持向量机模型
  • RedHat8.1安装mysql5.6(GLIBC方式)
  • Criteria类
  • 【Linux systemctl命令控制软件的启动和关闭】
  • Python面向对象基础
  • 【SpringCache】快速入门 通俗易懂
  • 玩转大数据11:数据可视化与交互式分析