js获取随机数、日期格式化、全屏、首字母小写转大写、将十六进制颜色转换为 RGBA 格式

获取随机数

/**
 * 获取随机数
 * @param {*} min number 最小值
 * @param {*} max number 最大值
 * @returns number
 */
export const getRandomNum = (min = 0, max = 100) => {
  return Math.floor(Math.random() * (max - min)) + min
}

日期格式化

/**
 * 日期格式化
 * @param {*} date date 日期 new Date()
 * @param {*} fmt string 日期格式 'yyyy-MM-dd hh:mm:ss'
 * @returns string
 */
export const formatDate = (date = new Date(), fmt = 'yyyy-MM-dd hh:mm:ss') => {
  if (/(y+)/.test(fmt)) {
    fmt = fmt.replace(
      RegExp.$1,
      `${date.getFullYear()}`.substr(4 - RegExp.$1.length)
    )
  }
  let o = {
    'M+': date.getMonth() + 1,
    'd+': date.getDate(),
    'h+': date.getHours(),
    'm+': date.getMinutes(),
    's+': date.getSeconds(),
  }
  // 遍历这个对象
  for (let k in o) {
    if (new RegExp(`(${k})`).test(fmt)) {
      let str = `${o[k]}`
      fmt = fmt.replace(
        RegExp.$1,
        RegExp.$1.length === 1 ? str : padLeftZero(str)
      )
    }
  }
  return fmt
}

全屏

/** 全屏*/
export const toggleFullScreen = () => {
  if (
    !document.fullscreenElement &&
    !document.mozFullScreenElement &&
    !document.webkitFullscreenElement &&
    !document.msFullscreenElement
  ) {
    if (document.documentElement.requestFullscreen) {
      document.documentElement.requestFullscreen()
    } else if (document.documentElement.msRequestFullscreen) {
      document.documentElement.msRequestFullscreen()
    } else if (document.documentElement.mozRequestFullScreen) {
      document.documentElement.mozRequestFullScreen()
    } else if (document.documentElement.webkitRequestFullscreen) {
      document.documentElement.webkitRequestFullscreen(
        Element.ALLOW_KEYBOARD_INPUT
      )
    }
  } else {
    if (document.exitFullscreen) {
      document.exitFullscreen()
    } else if (document.msExitFullscreen) {
      document.msExitFullscreen()
    } else if (document.mozCancelFullScreen) {
      document.mozCancelFullScreen()
    } else if (document.webkitExitFullscreen) {
      document.webkitExitFullscreen()
    }
  }
}

首字母小写转大写

//首字母小写转大写
export const firstLetterLowToUp = (text) => {
  return text.replace(text[0], text[0].toUpperCase())
}

将十六进制颜色转换为 RGBA 格式

/**
   * 将十六进制颜色转换为 RGBA 格式
   * @param {string} hex - 十六进制颜色值,例如 '#0080FF'
   * @param {number} alpha - 透明度值 (0 到 1 之间)
   * @returns {string} RGBA 颜色字符串
   */
  hexToRgba(hex, alpha) {
    // 去掉前导的 #
    hex = hex.replace(/^#/, '');

    // 如果是短格式颜色 (如 #FFF), 扩展成长格式 (如 #FFFFFF)
    if (hex.length === 4) {
      hex = hex.split('').map(function (char) {
        return char + char;
      }).join('');
    }

    // 解析红、绿、蓝的十六进制值
    const r = parseInt(hex.substring(0, 2), 16);
    const g = parseInt(hex.substring(2, 4), 16);
    const b = parseInt(hex.substring(4, 6), 16);

    // 返回 RGBA 颜色字符串
    return `rgba(${r}, ${g}, ${b}, ${alpha})`;
    /* // 示例用法
    const hexColor = '#0080FF';
    const alpha = 0.8;
    console.log(hexToRgba(hexColor, alpha)); // 输出: rgba(0, 128, 255, 0.8) */
  }
RGBA(Red, Green, Blue, Alpha)是一种用来描述颜色的表示方式,其中红色、绿色和蓝色的分量加上透明度的值共同确定了一个颜色RGBA颜色可以通过将三原色的分量值和透明度的值转换十六进制表示来进行转换。 具体而言,对于一个十六进制颜色值,例如#RRGGBB,RR表示红色分量的值,GG表示绿色分量的值,BB表示蓝色分量的值,这些值的范围是0到255(或者00到FF)。而透明度的值以十六进制的方式表示为00到FF,其中00表示完全透明(即不可见),FF表示完全不透明(即完全可见)。 要将颜色值从RGBA转换十六进制颜色,我们可以简单地将红色、绿色和蓝色的分量值以及透明度的值转换十六进制表示,然后将它们连在一起即可。例如,如果我们有一个RGBA颜色rgba(255, 0, 0, 0.5),那么它的十六进制表示为#FF000080。其中,FF表示红色的分量值255,00表示绿色的分量值0,00表示蓝色的分量值0,80表示透明度的值0.5(转换十六进制时乘以255)。 相反地,要将一个十六进制颜色转换RGBA颜色,我们需要将十六进制颜色值拆分为红色、绿色和蓝色的分量以及透明度的值,然后将它们转换为十进制表示。例如,一个十六进制颜色值为#00FF0080,我们可以将它分解为红色分量值00(转换为十进制时为0)、绿色分量值FF(转换为十进制时为255)、蓝色分量值00(转换为十进制时为0)和透明度的值80(转换为十进制时为128)。 通过以上方法我们可以实现RGBA与十六进制颜色的互相转换。如果需要进行这样的转换,可以使用各种在线工具或编程语言中提供的函数来帮助我们进行转换。这些工具或函数可以接受RGBA或十六进制颜色作为输入,并返回转换后的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ciito

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值