JS十六进制转浮点、字符串转为ArrayBuffer、ArrayBuffer转16进制字符串、16进制转10进制、crc校验位、十六进制转中文字符串(小程序、浏览器)、十六进制字符串转ascall字串

这篇具有很好参考价值的文章主要介绍了JS十六进制转浮点、字符串转为ArrayBuffer、ArrayBuffer转16进制字符串、16进制转10进制、crc校验位、十六进制转中文字符串(小程序、浏览器)、十六进制字符串转ascall字串。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

h5实现一键复制文本到剪切板
// 复制文本到剪切板
export function copyText (text) {
  // 将内容转换为字符串:
  const textString = text.toString()
  // 获取input输入框,没有dom元素的话需要自动生成
  let input = document.querySelector('#copy-input')
  if (!input) {
    input = document.createElement('input')
    input.id = 'copy-input'
    input.readOnly = 'readOnly'
    input.style.position = 'absolute'
    input.style.left = '-1000px'
    input.style.zIndex = '-1000'
    document.body.appendChild(input)
  }
  input.value = textString
  // ios必须先选中文字且不支持 input.select()
  selectText(input, 0, textString.length)
  if (document.execCommand('copy')) {
    document.execCommand('copy')
  } else {
    console.log('不兼容')
  }
  input.blur()
  // input自带的select()方法在苹果端无法进行选择,所以需要自己实现
  // 选择文本。createTextRange(setSelectionRange)是input方法
  function selectText (textbox, startIndex, stopIndex) {
    if (textbox.createTextRange) { // ie
      const range = textbox.createTextRange()
      range.collapse(true)
      range.moveStart('character', startIndex)// 起始光标
      range.moveEnd('character', stopIndex - startIndex)// 结束光标
      range.select()// 不兼容苹果
    } else { // firefox/chrome
      textbox.setSelectionRange(startIndex, stopIndex)
      textbox.focus()
    }
  }
}
ArrayBuffer转16进制字符串:
/**ArrayBuffer转16进制字符串
 * @param {Buffer} buffer 传入二进制数据流
 * @return {String} 十六进制字符串
 */
function ab2hex(buffer){
  const hexArr = Array.prototype.map.call(
    new Uint8Array(buffer),
    function(bit) {
      return ('00' + bit.toString(16)).slice(-2)
    }
  )
  return hexArr.join('')
}
字符串转为ArrayBuffer对象
/** 
 * 字符串转为ArrayBuffer对象
 * @param {String} str 字符串
 * @return {Buffer} buffer对象
 */
function str2ab(str){
  let buf = new ArrayBuffer(str.length / 2) // buff数组
  let bufView = new Uint8Array(buf) // 一个8位无符号整型数组
  for (let i = 0, strLen = str.length; i < strLen; i++) {
    bufView[i] = parseInt(str.slice(i * 2, i * 2 + 2),16)
  }
  return buf
}
十六进制转10进制
/***
 * 十六进制转10进制
 * 16进制转10进制(parseInt(str,a)可以将str按a进制进行转换,toString(b)将一个值转换为b进制的,如果只是简单的十六进制转十进制可以直接parseInt(str,16)默认转换为十进制,下面方法继续调用toString就是想再将其转换为其它进制比如八进制等)
 * @param {Strng} str 十六进制字符串
 * @return {String} 十六进制字符串
 */
function hex2dex (str) {
  return parseInt(str, 16).toString(10)
}

十六进制转浮点:

/**
 * 十六进制转浮点:
 * @param {String} param 十六进制字符串
 * @return {Float} Float
  */
function hexToSingleFlow (param) {
  function hexToSingle(t) {
    let start = t.slice(0,4)
    let end = t.slice(4,8)
    t = start + end // 有可能是 t = end + start , 有的数据前面四位和后面四位可能会调换,这个需要根据硬件中程序决定,因此这里需要根据硬件做调试进行start和end前后位置调换
    t = t.replace(/\s+/g, "") // 去掉十进制值中的空格,但是因为上面t = start + end 前面slice的需要(js中空格也占长度),因此一般都是在调用此函数时直接去掉空格的
    if (t == "") { // 如果传入空字符,直接输出
      return ""
    }
    if (t == "00000000") { // 如果传入8个0,直接输出0
      return "0"
    }
    if ((t.length > 8) || (isNaN(parseInt(t, 16)))) { // 如果传入字符超过8个或不能转十进制的字符,则返回错误
      return "Error"
    }
    if (t.length < 8) { // 当传入的值不够8个字符时用0补齐8个字符
      t = FillString(t, "0", 8, true)
    }
    t = parseInt(t, 16).toString(2) // 将十六进制字符串转换为十进制再转换为二进制
    t = FillString(t, "0", 32, true) // 将二进制字符串补齐32个字符
    let s = t.substring(0, 1) // 截取32个字符中第一个字符
    let e = t.substring(1, 9) // 截取32个字符中第2-10中8个字符
    let m = t.substring(9) // 截取32个字符中第10个开始到最后个字符
    e = parseInt(e, 2) - 127 // 将e按二进制转换后 - 127
    m = "1" + m // 给m 前面拼接'1'
    if (e >= 0) { // e 大于等于0时
      m = m.substr(0, e + 1) + "." + m.substring(e + 1) // 截取整数部分 + . + 小数部分
    } else {
      m = "0." + FillString(m, "0", m.length - e - 1, true) // 小于0时: '0.' + 小数部分(继续补齐字符)
    }
    if (m.indexOf(".") == -1) { // 当没有小数点时(即整数时),后面拼接 '.0'
      m = m + ".0";
    }
    let a = m.split(".") // 以.分割m成数组a:[0101,001]
    let mi = parseInt(a[0], 2) // a数组第一值转二进制
    let mf = 0 // 声明一个变量mf并初始化为0
    for (let i = 0; i < a[1].length; i++) { // 用数组第二个值的长度做遍历
      mf += parseFloat(a[1].charAt(i)) * Math.pow(2, -(i + 1)) // Math.pow(a,b)方法获得值的类型是double型,含义是a的b次方 ,charAt(i)取第i个字符
    }
    m = parseInt(mi) + parseFloat(mf) // 整数部分 + 小数部分
    if (s == 1) { // 当二进制第一个字符为1时将其转负数
      m = 0 - m
    }
    return m
  }
  // 处理字符不够情况:
  function FillString(t, c, n, b) {
    if ((t == "") || (c.length != 1) || (n <= t.length)) { // 当传入的值为:t为空字符或t长度大于8或c的长度不等于1时,直接返回t
      return t
    }
    let l = t.length // 得到t的长度
    for (let i = 0; i < n - l; i++) { //判断以t = c + t或t = t + c 方式用'0'补齐8个字符
      if (b == true) {
        t = c + t
      }
      else {
        t += c // t = t + c
      }
    }
    return t
  }
  return hexToSingle(param)
}

浮点型转十六进制:

/**
 * 浮点型转换为十六进制:
 */
function floatToHex(decString) {
  function DecToBinTail(dec, pad){
    let bin = ""
    let i
    for (i = 0; i < pad; i++) {
      dec *= 2
      if (dec >= 1) {
        dec -= 1
        bin += "1"
      } else {
        bin += "0"
      }
    }
    return bin
  }
  function DecToBinHead(dec,pad) {
    let bin=""
    let i
    for (i = 0; i < pad; i++) {
      bin = (parseInt(dec % 2).toString()) + bin
      dec /= 2
    }
    return bin
  }
  function Right(String, Length) {
    if (String == null) return (false)
      let dest = ''
      for (let i = (String.length - 1); i >= 0; i--) {
        dest = dest + String.charAt(i)
      }
      String = dest
      String = String.substr(0, Length)
      dest = ''
      for (let i = (String.length - 1); i >= 0; i--) {
        dest = dest + String.charAt(i)
      }
      return dest
  }
  let dec = decString
  let sign
  let signString
  let decValue = parseFloat(Math.abs(decString))
  let exponent
  if (decString.toString().charAt(0) == '-') {
    sign = 1;
    signString = "1"
  } else {
    sign = 0
    signString = "0"
  } if (decValue==0) {
    fraction = 0
    exponent = 0
  } else {
    exponent = 127;
    if (decValue>=2) {
      while (decValue >=2 ) {
        exponent++
        decValue /= 2
      }
    } else if (decValue <1 ) {
      while (decValue < 1) {
        exponent--
        decValue *= 2
        if (exponent ==0) break
      }
    }
    if (exponent!=0) decValue-=1; else decValue /= 2
  }
  let fractionString = DecToBinTail(decValue, 23)
  let exponentString = DecToBinHead(exponent, 8)
  return Right('00000000'+parseInt(signString + exponentString + fractionString, 2).toString(16),8)
}

将某段字符串使用某字符补齐

/**
 * 将某段字符串使用某段字符补齐:
 * @param {String} hexStr 需要转换的字符串
 * @param {Number} count 转换后字符串的总长度
 * @param {String} str 要拼接的字符
 * @param {Boolean} isFront 是否在前面拼接,值为true时将str拼接到元字符串的前面,false则相反
 * @return {String} 十六进制字符串
 */
function useStrFill (hexStr,count,str,isFront) {
  let hexlength = hexStr.toString().length
  let n = count -hexlength
  let strHal = ''
  if (n > 0) {
    for (let i = 0; i < n / str.length; i++) {
      strHal += str
    }
    let result = ''
    if (isFront) {
     result = strHal + hexStr
    } else (
      result = hexStr + strHal
    )
    return result
  } else {
    return hexStr.slice(hexlength  - count,hexlength)
  }
}

十六进制转带符号(-负号)整型

/**
 * 十六进制转带符号整型
 * @param {String} hexStr 十六进制字符串
 */
function hex2int(hexStr) {
  // 将十六转十进制,再转2进制
  let twoStr = parseInt(hexStr,16).toString(2)
  // 1个字节 = 8bit ,0xff 一个 "f"就是4位
  let bitNum = hexStr.length * 4
  if(twoStr.length < bitNum){
    while(twoStr.length < bitNum){
      twoStr = "0" + twoStr
    }
  }
  if(twoStr.substring(0,1) == "0"){
    // 正数, // 二进制转十进制
    twoStr = parseInt(twoStr,2)
    return twoStr
  }else{
    // 负数
    let twoStr_unsign = ""
    // 补码:(负数)反码+1,符号位不变;相对十进制来说也是 +1,但这里是负数,+1就是绝对值数据-1
    twoStr = parseInt(twoStr,2) - 1
    twoStr = twoStr.toString(2)
     // 舍弃首位(符号位)
    twoStr_unsign = twoStr.substring(1,bitNum)
    // 去除首字符,将0转为1,将1转为0   反码
    twoStr_unsign = twoStr_unsign.replace(/0/g, "z")
    twoStr_unsign = twoStr_unsign.replace(/1/g, "0")
    twoStr_unsign = twoStr_unsign.replace(/z/g, "1")
    twoStr = parseInt(-twoStr_unsign, 2);
    return twoStr
  }
}

带符号(负号)整数转十六进制字符串(得到8个字符十六进制字符串)

/** 
 * 带符号(负号)整数转十六进制字符串
 * @param {Number} number 整型,可带符号
 * @return {String} 8个字符长度的十六进制字符串
*/
function decToHex(number){
  return (parseInt(number,10)>>>0).toString(16)
}

带符号(负号)整数转二进制字符串(4个字符)

可以将上一个方法decToHex得到的结果截取后四位,效果一样

/** 
 * 带符号(负号)整数转二进制字符串(4个字符)
 * @param {Number} number 整型,可带符号
*/
function signDecToHex(i) {
  return (i+0x10000).toString(16).substr(-4).toUpperCase()
}

十六进制转包含中文字符串,解码十六进制字符(强调小程序和浏览器不同)

/** 
 * 十六进制字符串转中文
 * @param {String} hex 为十六进制字符串
 * @return {String} 包含中文的字符串
*/
function hexToStr(hex) {
  // 去掉字符串首尾空格
  let trimedStr = hex.trim()
  // 判断trimedStr前两个字符是否为0x,如果是则截取从第三个字符及后面所有,否则返回全部字符
  let rawStr = trimedStr.substr(0, 2).toLowerCase() === "0x" ? trimedStr.substr(2) : trimedStr
  // 得到rawStr的长度
  let len = rawStr.length
  // 如果长度不能被2整除,那么传入的十六进制值有误,返回空字符
  if (len % 2 !== 0) {
    return ""
  }
  let curCharCode // 接收每次循环得到的字符
  let resultStr = [] // 存转换后的十进制值数组
  for (let i = 0; i < len; i = i + 2) {
    curCharCode = parseInt(rawStr.substr(i, 2), 16)
    resultStr.push(curCharCode)
  }
  // encoding为空时默认为utf-8
  let bytesView = new Uint8Array(resultStr) // 8 位无符号整数值的类型化数组
  // TextEncoder和TextDecoder对字符串和字节流互转  
  // let str = new TextDecoder(encoding).decode(bytesView)因为小程序中没有TextDecoder,经查阅资料,下载https://github.com/inexorabletash/text-encoding并const encoding = require("./text-encoding-master/lib/encoding.js")引入后使用下面方式即可:
  let str = new encoding.TextDecoder("gbk").decode(bytesView)
  return str
}

包含中文字符串转十六进制

注意:在微信小程序中可能不支持,中文,但是其他语言是支持的,不支持可能的原因和上面hexToStr一样,需要借助TextEncoder,进行转换,因为时间关系,当时放弃了小程序中文转十六进制这一功能。

// 中文字符串转十六进制:
/**
 * @param {String} str 可包含中文的字符串
 * @return {String} 返回十六进制字符串
 */
function strToHex (str) {
  let val = ''
  for (let i = 0;i < str.length;i++) {
    if (val==='') {
      val = str.charCodeAt(i).toString(16)
    } else {
      val += str.charCodeAt(i).toString(16)
    }
  }
  return val
  // const uint8array = new encoding.TextEncoder().encode(str)
  // console.log(uint8array)
  // return uint8array[0]
}

四舍五入保留n位小数点

/**
 * 保留n位小数,四舍五入
 * @param {Number} _m_ 原始数字
 * @param {Number} _n_ 保留n位,默认2位
 * @returns 
 */
 function fixed(_m_, _n_ = 2){
  const num = Number(_m_),
   n = Number(_n_);
   return num.toFixed(n)
  //  或者
  // Number.prototype.toFixed.call(num,n)
}
// 保留n位小数,向下取整
function fixedFloor(_m_, _n_ = 2) {
  let num = Number(_m_);
  const n = Number(_n_);
  if (!isNaN(num) && !isNaN(n)) {
    const multiple = 10 ** n;
    num = Math.floor(num * multiple) / multiple;
    let str = num.toString();
    let index = str.indexOf(".");
    if (index < 0) {
      index = str.length; // 标记小数点位置
      str += ".";
    }
    while (str.length <= index + n) {
      str += "0";
    }
    return str;
  }
  return "0.00";
}
function fixedUp(_m_, _n_ = 2) {
  let num = Number(_m_);
  const n = Number(_n_);
  if (!isNaN(num) && !isNaN(n)) {
    const list = [...Math.floor(num * 10 ** n).toString()];
    list.splice(-n, 0, ".");
    return list.join("");
  }
  return "0.00";
}

rgb转十六进制

/** 
 * 保留n位小数
 * @param {Number} r 
 * @param {Number} g 
 * @param {Number} b
 * @return {String}  十六进制字符串
*/
function rgb2hex(r,g,b) {
  if (g !== undefined) 
    return Number(0x1000000 + r*0x10000 + g*0x100 + b).toString(16).substring(1)
  else
    return Number(0x1000000 + r[0]*0x10000 + r[1]*0x100 + r[2]).toString(16).substring(1)
}

将十六进制Ascall码字符串转换为Ascall码字符字符串:
注意:此方法需要借助本封装函数中的substrHexStrToHexArray方法 将字符串平均分割n份(这里是将十六进制Ascall码字符串分割出来后再处理)和hexArrayToDecArray方法 将一个十六进制字符数组转十进制字符数组

/** 将十六进制字符串转ascall码转对应的字符拼接字符串:
 * @param {String} hexStr 传入十六进制字符串
 * @return {String} 返回十六进制字符串转换为十六进制ascall码对应字符拼接的字符串:
 */
function hexStrToAscllChar (hexStr) {
  // 获取字符串的长度:
  const strLength = hexStr.length
  // 如果传入的字符串不能被2整除,直接返回空字符
  if (strLength % 2 !== 0) return ''
  // 计算要分割的份数:
  const count = strLength / 2
  // 调用本工具函数中substrHexStrToHexArray方法得到十六进制字符串对应的十六进制ascall码数组
  const hexArray = substrHexStrToHexArray(hexStr,count)
  // 调用本工具函数中的hexArrayToDecArray方法将十六进制字符串数组转十进制数组:
  const decArray = hexArrayToDecArray(hexArray)
  // 查询十进制ascall码对应的字符并拼接为字符串:
  let str = ''
  for (let i = 0; i < decArray.length; i++) {
    // 查询对应的字符:
    str += String.fromCharCode(decArray[i])
  }
  return str
}

将一个十六进制字符串分割为n份存到数组并返回 :

/** 将一个十六进制字符串分割为n份存到数组并返回:
 * @param {String} hexStr 传入十六进制字符串
 * @return {Array} 返回一个存十六进制ascall码的数组:
*/
function substrHexStrToHexArray (hexstr,cop) {
  // 存放十六进制的数组
  let valueArray = []
  // 一个值对应的字符长度
  let itemLength = hexstr.length / cop
  // 截取到某个值的十六进制字符串
  let itemStrHex
  // 循环截取每个值,并将每个值保存到valueArray
  for (let i = 0; i < cop; i++) {
      // 截取到某个值的十六进制字符串
      itemStrHex = hexstr.slice(itemLength * i,itemLength * i + itemLength)
      // 将截取的值存到数据中
      valueArray.push(itemStrHex)
  }
  // 返回有效的十六进制值
  return valueArray
}

将一个十六进制字符数组转十进制字符数组:
本方法中调用了本封装的方法中的hex2int方法 将一个十六进制字符数组转十进制字符数组

/** 将一个十六进制字符数组转十进制字符数组:
 * @param {Array} hexArray 传入十六进制字符串数组
 * @return {Array} 返回一个存十进制数据的数组:
*/
function hexArrayToDecArray (hexArray) {
  let arr = []
  let num
  for (let i = 0; i < hexArray.length; i++) {
    // 调用本工具函数中的hex2int方法将十六进制字符串转十进制数字:
    num = hex2int(hexArray[i])
    // 并将转换后的结果存到arr中
    arr.push(num)
  }
  return arr
}

将一个十六进制字符数组转十进制字符数组:

/** 将一个十六进制字符数组转十进制字符数组:
 * @param {Array} hexArray 传入十六进制字符串数组
 * @return {Array} 返回一个存十进制数据的数组:
*/
function hex2int(hex) {
  const hexStrLength = hex.length
  let array = new Array(hexStrLength)
  let num
  for (let i = 0; i < hexStrLength; i++) {
    num = hex.charCodeAt(i)
    if (48 <= num && num < 58) {
      num -= 48
    } else {
      num = (num & 0xdf) - 65 + 10
    }
    array[i] = num
  }
  return array.reduce(function(acc, c) {
    acc = 16 * acc + c
    return acc
  }, 0)
}
计算crc校验位
/** 
 * 计算crc校验位
 * @param {Number} parapms 需要计算的值
 * @return {String}  带有校验位的值
*/
function (parapms) {
  let CRC = {}
  CRC._auchCRCHi = [
    0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
    0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
    0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
    0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
    0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
    0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41,
    0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
    0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
    0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
    0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
    0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
    0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
    0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
    0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
    0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
    0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
    0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
    0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
    0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
    0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
    0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
    0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40,
    0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1,
    0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
    0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
    0x80, 0x41, 0x00, 0xC1, 0x81, 0x40
  ]
  CRC._auchCRCLo = [
    0x00, 0xC0, 0xC1, 0x01, 0xC3, 0x03, 0x02, 0xC2, 0xC6, 0x06,
    0x07, 0xC7, 0x05, 0xC5, 0xC4, 0x04, 0xCC, 0x0C, 0x0D, 0xCD,
    0x0F, 0xCF, 0xCE, 0x0E, 0x0A, 0xCA, 0xCB, 0x0B, 0xC9, 0x09,
    0x08, 0xC8, 0xD8, 0x18, 0x19, 0xD9, 0x1B, 0xDB, 0xDA, 0x1A,
    0x1E, 0xDE, 0xDF, 0x1F, 0xDD, 0x1D, 0x1C, 0xDC, 0x14, 0xD4,
    0xD5, 0x15, 0xD7, 0x17, 0x16, 0xD6, 0xD2, 0x12, 0x13, 0xD3,
    0x11, 0xD1, 0xD0, 0x10, 0xF0, 0x30, 0x31, 0xF1, 0x33, 0xF3,
    0xF2, 0x32, 0x36, 0xF6, 0xF7, 0x37, 0xF5, 0x35, 0x34, 0xF4,
    0x3C, 0xFC, 0xFD, 0x3D, 0xFF, 0x3F, 0x3E, 0xFE, 0xFA, 0x3A,
    0x3B, 0xFB, 0x39, 0xF9, 0xF8, 0x38, 0x28, 0xE8, 0xE9, 0x29,
    0xEB, 0x2B, 0x2A, 0xEA, 0xEE, 0x2E, 0x2F, 0xEF, 0x2D, 0xED,
    0xEC, 0x2C, 0xE4, 0x24, 0x25, 0xE5, 0x27, 0xE7, 0xE6, 0x26,
    0x22, 0xE2, 0xE3, 0x23, 0xE1, 0x21, 0x20, 0xE0, 0xA0, 0x60,
    0x61, 0xA1, 0x63, 0xA3, 0xA2, 0x62, 0x66, 0xA6, 0xA7, 0x67,
    0xA5, 0x65, 0x64, 0xA4, 0x6C, 0xAC, 0xAD, 0x6D, 0xAF, 0x6F,
    0x6E, 0xAE, 0xAA, 0x6A, 0x6B, 0xAB, 0x69, 0xA9, 0xA8, 0x68,
    0x78, 0xB8, 0xB9, 0x79, 0xBB, 0x7B, 0x7A, 0xBA, 0xBE, 0x7E,
    0x7F, 0xBF, 0x7D, 0xBD, 0xBC, 0x7C, 0xB4, 0x74, 0x75, 0xB5,
    0x77, 0xB7, 0xB6, 0x76, 0x72, 0xB2, 0xB3, 0x73, 0xB1, 0x71,
    0x70, 0xB0, 0x50, 0x90, 0x91, 0x51, 0x93, 0x53, 0x52, 0x92,
    0x96, 0x56, 0x57, 0x97, 0x55, 0x95, 0x94, 0x54, 0x9C, 0x5C,
    0x5D, 0x9D, 0x5F, 0x9F, 0x9E, 0x5E, 0x5A, 0x9A, 0x9B, 0x5B,
    0x99, 0x59, 0x58, 0x98, 0x88, 0x48, 0x49, 0x89, 0x4B, 0x8B,
    0x8A, 0x4A, 0x4E, 0x8E, 0x8F, 0x4F, 0x8D, 0x4D, 0x4C, 0x8C,
    0x44, 0x84, 0x85, 0x45, 0x87, 0x47, 0x46, 0x86, 0x82, 0x42,
    0x43, 0x83, 0x41, 0x81, 0x80, 0x40
  ]
  CRC.CRC16 = function (buffer) {
    let hi = 0xff
    let lo = 0xff
    for (let i = 0; i < buffer.length; i++) {
        let idx = hi ^ buffer[i]
        hi = (lo ^ CRC._auchCRCHi[idx])
        lo = CRC._auchCRCLo[idx]
    }
    return CRC.padLeft((hi << 8 | lo ).toString(16).toUpperCase(), 4, '0')
  }
  CRC.isArray = function (arr) {
    return Object.prototype.toString.call(arr) === '[object Array]'
  }
  CRC.ToCRC16 = function (str) {
    return CRC.CRC16(CRC.isArray(str) ? str : CRC.strToByte(str))
  }
  CRC.ToModbusCRC16 = function (str) {
    return CRC.CRC16(CRC.isArray(str) ? str : CRC.strToHex(str))
  }
  CRC.strToByte = function (str) {
    let tmp = str.split(''), arr = []
    for (let i = 0, c = tmp.length; i < c; i++) {
        let j = encodeURI(tmp[i])
        if (j.length == 1) {
            arr.push(j.charCodeAt())
        } else {
            let b = j.split('%')
            for (let m = 1; m < b.length; m++) {
                arr.push(parseInt('0x' + b[m]))
            }
        }
    }
    return arr
  }
  CRC.convertChinese = function (str) {
    let tmp = str.split(''), arr = []
    for (let i = 0, c = tmp.length; i < c; i++) {
        let s = tmp[i].charCodeAt()
        if (s <= 0 || s >= 127) {
            arr.push(s.toString(16))
        }
        else {
            arr.push(tmp[i])
        }
    }
    return arr
  }
  CRC.filterChinese = function (str) {
    let tmp = str.split(''), arr = []
    for (let i = 0, c = tmp.length; i < c; i++) {
        let s = tmp[i].charCodeAt()
        if (s > 0 && s < 127) {
            arr.push(tmp[i])
        }
    }
    return arr
  }
  CRC.strToHex = function (hex, isFilterChinese) {
    hex = isFilterChinese ? CRC.filterChinese(hex).join('') : CRC.convertChinese(hex).join('')
    //清除所有空格
    hex = hex.replace(/\s/g, "");
    //若字符个数为奇数,补一个空格
    hex += hex.length % 2 != 0 ? " " : ""
    let c = hex.length / 2, arr = []
    for (let i = 0; i < c; i++) {
        arr.push(parseInt(hex.substr(i * 2, 2), 16))
    }
    return arr
  }
  CRC.padLeft = function (s, w, pc) {
    if (pc == undefined) {
        pc = '0'
    }
    for (let i = 0, c = w - s.length; i < c; i++) {
        s = pc + s
    }
    return s
  }
  return parapms + CRC.ToModbusCRC16(parapms)
}

提示:本文图片等素材来源于网络,若有侵权,请发邮件至邮箱:810665436@qq.com联系笔者删除。
笔者:苦海文章来源地址https://www.toymoban.com/news/detail-486851.html

到了这里,关于JS十六进制转浮点、字符串转为ArrayBuffer、ArrayBuffer转16进制字符串、16进制转10进制、crc校验位、十六进制转中文字符串(小程序、浏览器)、十六进制字符串转ascall字串的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 字符串string转换长整型int(八进制、十进制、十六进制)

    strtoul() 是C语言标准库中用于将字符串转换成无符号长整数的函数。它的完整原型如下: 其中, nptr 代表要被转换成无符号长整数的字符串; endptr 是一个指向字符指针的指针,该指针指向已经转换了的最后一个字符的下一个位置; base 指定要采用的进制,范围是2 ~ 36。 该函

    2024年02月07日
    浏览(53)
  • python中str、bytes、十六进制字符串的相互转换

    python中str、bytes、十六进制字符串的介绍 str是python的内置函数,str字符串在python中使用 \\\'\\\' 或者 \\\"\\\" 括起来的字符串,比如: bytes也是python的内置函数,bytes字符串通常以b开头,比如: 十六进制字符串是指字符串中每个字符表示一个十六进制数,两个字符组成一个字节,比如

    2024年02月21日
    浏览(54)
  • 51单片机LCD1602液晶屏显示字符,字符串,(有)无符号整数,十六进制数,二进制数等

    LCD1602液晶显示器是广泛使用的一种字符型液晶显示模块。液晶显示模块具有体积小、功耗低、显示内容丰富、超薄轻巧等优点,在嵌入式应用系统中得到越来越广泛的应用,这讲中向大家介绍的LCD1602 液晶显示模块(其内部控制器为HD44780 芯片),它可以显示两行,每行16 个字

    2024年02月04日
    浏览(64)
  • JS十六进制,CRC冗余,小程序发送蓝牙数据,十六进制GBK编码转换等

    小程序问题:https://kf.qq.com/faq/170705YVZFZZ170705eyI7Rr.html 调用: 注意:这里的true和false代表是否大端小端转换 调用: 调用: 调用: 调用: 调用: 此代码写到小程序utils目录下的utuils.js文件中 调用:页面最上边先引入,然后再使用 调用: 这里发送buffer1给小程序公用api就可 调

    2024年02月16日
    浏览(72)
  • 【计算机网络】TCP中payload的解析,在python中的体现?字节、字符?为啥字节用十六进制表示?

    问题来源 最近要根据一份国家标准协议进行解码,但是对于进制,字节,字符,编码,转码有比较多的问题。其中我想实现的主要需求如下: 有客户端与服务端,进行tcp通信,客户端要发送一个请求,tcp中payload请求大概是这样,有很多个十六进制表示的字节组成 根据协议的

    2024年02月11日
    浏览(57)
  • Qt将十二位整形十进制转换成十六进制,在转为ascii字符,并下发串口。在接受端完整还原这个十二位的十进制数。

    可以按照以下步骤进行操作: 将十进制数123456789012转换成十六进制字符串: 其中, %1 表示替换第1个参数, 0 表示输出的最小位数为0, 16 表示输出的进制为16, ull 表示无符号长长整型。 2. 将十六进制字符串转换成ASCII字符:

    2024年02月05日
    浏览(53)
  • python实现十六进制转十进制

    先来看下十六进制的定义以及表示方式,以下是百度百科上的解释: 十六进制 (简写为 hex 或下标16)是一种基数为16的计数系统,是一种逢16进1的进位制。通常用数字0、1、2、3、4、5、6、7、8、9和字母A、B、C、D、E、F(a、b、c、d、e、f)表示,其中:A~F表示10~15,这些称作

    2023年04月19日
    浏览(48)
  • 十六进制转换到十进制(java)

    一、前言  首先我们要知道十六进制的转换以及十以上的进制的转换与十以下的进制转换是不一样的,它们在一位上会用超过9的数字,这个我们在利用以前的方法就行不通了,我接下来就向大家分享一种方法。(注:在Java中10---15分别用A B C D E F表示,不分大小写) 二、正文

    2024年02月11日
    浏览(57)
  • 【FPGA仿真】Matlab生成二进制、十六进制的txt数据以及Vivado读取二进制、十六进制数据并将结果以txt格式保存

    在使用Vivado软件进行Verilog程序仿真时可能需要对模块输入仿真的数据,因此我们需要一个产生数据的方法(二进制或者十六进制的数据),Matlab软件是一个很好的工具,当然你也可以使用VS等工具。 以下分别给出了使用Matlab模拟产生二进制和十六进制数据的例子,例子仅供参

    2024年02月01日
    浏览(56)
  • MATLAB十六进制与十进制互相转换

    包含单个数字进行转换和数组进行转换(可用于串口数据解析) 1.十六进制转十进制

    2024年01月16日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包