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
}
将一个十六进制字符数组转十进制字符数组:文章来源:https://www.toymoban.com/news/detail-486851.html
/** 将一个十六进制字符数组转十进制字符数组:
* @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模板网!