h5實(shí)現(xiàn)一鍵復(fù)制文本到剪切板
// 復(fù)制文本到剪切板
export function copyText (text) {
// 將內(nèi)容轉(zhuǎn)換為字符串:
const textString = text.toString()
// 獲取input輸入框,沒(méi)有dom元素的話需要自動(dòng)生成
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()方法在蘋果端無(wú)法進(jìn)行選擇,所以需要自己實(shí)現(xiàn)
// 選擇文本。createTextRange(setSelectionRange)是input方法
function selectText (textbox, startIndex, stopIndex) {
if (textbox.createTextRange) { // ie
const range = textbox.createTextRange()
range.collapse(true)
range.moveStart('character', startIndex)// 起始光標(biāo)
range.moveEnd('character', stopIndex - startIndex)// 結(jié)束光標(biāo)
range.select()// 不兼容蘋果
} else { // firefox/chrome
textbox.setSelectionRange(startIndex, stopIndex)
textbox.focus()
}
}
}
ArrayBuffer轉(zhuǎn)16進(jìn)制字符串:
/**ArrayBuffer轉(zhuǎn)16進(jìn)制字符串
* @param {Buffer} buffer 傳入二進(jìn)制數(shù)據(jù)流
* @return {String} 十六進(jìn)制字符串
*/
function ab2hex(buffer){
const hexArr = Array.prototype.map.call(
new Uint8Array(buffer),
function(bit) {
return ('00' + bit.toString(16)).slice(-2)
}
)
return hexArr.join('')
}
字符串轉(zhuǎn)為ArrayBuffer對(duì)象
/**
* 字符串轉(zhuǎn)為ArrayBuffer對(duì)象
* @param {String} str 字符串
* @return {Buffer} buffer對(duì)象
*/
function str2ab(str){
let buf = new ArrayBuffer(str.length / 2) // buff數(shù)組
let bufView = new Uint8Array(buf) // 一個(gè)8位無(wú)符號(hào)整型數(shù)組
for (let i = 0, strLen = str.length; i < strLen; i++) {
bufView[i] = parseInt(str.slice(i * 2, i * 2 + 2),16)
}
return buf
}
十六進(jìn)制轉(zhuǎn)10進(jìn)制
/***
* 十六進(jìn)制轉(zhuǎn)10進(jìn)制
* 16進(jìn)制轉(zhuǎn)10進(jìn)制(parseInt(str,a)可以將str按a進(jìn)制進(jìn)行轉(zhuǎn)換,toString(b)將一個(gè)值轉(zhuǎn)換為b進(jìn)制的,如果只是簡(jiǎn)單的十六進(jìn)制轉(zhuǎn)十進(jìn)制可以直接parseInt(str,16)默認(rèn)轉(zhuǎn)換為十進(jìn)制,下面方法繼續(xù)調(diào)用toString就是想再將其轉(zhuǎn)換為其它進(jìn)制比如八進(jìn)制等)
* @param {Strng} str 十六進(jìn)制字符串
* @return {String} 十六進(jìn)制字符串
*/
function hex2dex (str) {
return parseInt(str, 16).toString(10)
}
十六進(jìn)制轉(zhuǎn)浮點(diǎn):
/**
* 十六進(jìn)制轉(zhuǎn)浮點(diǎn):
* @param {String} param 十六進(jìn)制字符串
* @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 , 有的數(shù)據(jù)前面四位和后面四位可能會(huì)調(diào)換,這個(gè)需要根據(jù)硬件中程序決定,因此這里需要根據(jù)硬件做調(diào)試進(jìn)行start和end前后位置調(diào)換
t = t.replace(/\s+/g, "") // 去掉十進(jìn)制值中的空格,但是因?yàn)樯厦鎡 = start + end 前面slice的需要(js中空格也占長(zhǎng)度),因此一般都是在調(diào)用此函數(shù)時(shí)直接去掉空格的
if (t == "") { // 如果傳入空字符,直接輸出
return ""
}
if (t == "00000000") { // 如果傳入8個(gè)0,直接輸出0
return "0"
}
if ((t.length > 8) || (isNaN(parseInt(t, 16)))) { // 如果傳入字符超過(guò)8個(gè)或不能轉(zhuǎn)十進(jìn)制的字符,則返回錯(cuò)誤
return "Error"
}
if (t.length < 8) { // 當(dāng)傳入的值不夠8個(gè)字符時(shí)用0補(bǔ)齊8個(gè)字符
t = FillString(t, "0", 8, true)
}
t = parseInt(t, 16).toString(2) // 將十六進(jìn)制字符串轉(zhuǎn)換為十進(jìn)制再轉(zhuǎn)換為二進(jìn)制
t = FillString(t, "0", 32, true) // 將二進(jìn)制字符串補(bǔ)齊32個(gè)字符
let s = t.substring(0, 1) // 截取32個(gè)字符中第一個(gè)字符
let e = t.substring(1, 9) // 截取32個(gè)字符中第2-10中8個(gè)字符
let m = t.substring(9) // 截取32個(gè)字符中第10個(gè)開(kāi)始到最后個(gè)字符
e = parseInt(e, 2) - 127 // 將e按二進(jìn)制轉(zhuǎn)換后 - 127
m = "1" + m // 給m 前面拼接'1'
if (e >= 0) { // e 大于等于0時(shí)
m = m.substr(0, e + 1) + "." + m.substring(e + 1) // 截取整數(shù)部分 + . + 小數(shù)部分
} else {
m = "0." + FillString(m, "0", m.length - e - 1, true) // 小于0時(shí): '0.' + 小數(shù)部分(繼續(xù)補(bǔ)齊字符)
}
if (m.indexOf(".") == -1) { // 當(dāng)沒(méi)有小數(shù)點(diǎn)時(shí)(即整數(shù)時(shí)),后面拼接 '.0'
m = m + ".0";
}
let a = m.split(".") // 以.分割m成數(shù)組a:[0101,001]
let mi = parseInt(a[0], 2) // a數(shù)組第一值轉(zhuǎn)二進(jìn)制
let mf = 0 // 聲明一個(gè)變量mf并初始化為0
for (let i = 0; i < a[1].length; i++) { // 用數(shù)組第二個(gè)值的長(zhǎng)度做遍歷
mf += parseFloat(a[1].charAt(i)) * Math.pow(2, -(i + 1)) // Math.pow(a,b)方法獲得值的類型是double型,含義是a的b次方 ,charAt(i)取第i個(gè)字符
}
m = parseInt(mi) + parseFloat(mf) // 整數(shù)部分 + 小數(shù)部分
if (s == 1) { // 當(dāng)二進(jìn)制第一個(gè)字符為1時(shí)將其轉(zhuǎn)負(fù)數(shù)
m = 0 - m
}
return m
}
// 處理字符不夠情況:
function FillString(t, c, n, b) {
if ((t == "") || (c.length != 1) || (n <= t.length)) { // 當(dāng)傳入的值為:t為空字符或t長(zhǎng)度大于8或c的長(zhǎng)度不等于1時(shí),直接返回t
return t
}
let l = t.length // 得到t的長(zhǎng)度
for (let i = 0; i < n - l; i++) { //判斷以t = c + t或t = t + c 方式用'0'補(bǔ)齊8個(gè)字符
if (b == true) {
t = c + t
}
else {
t += c // t = t + c
}
}
return t
}
return hexToSingle(param)
}
浮點(diǎn)型轉(zhuǎn)十六進(jìn)制:
/**
* 浮點(diǎn)型轉(zhuǎn)換為十六進(jìn)制:
*/
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)
}
將某段字符串使用某字符補(bǔ)齊
/**
* 將某段字符串使用某段字符補(bǔ)齊:
* @param {String} hexStr 需要轉(zhuǎn)換的字符串
* @param {Number} count 轉(zhuǎn)換后字符串的總長(zhǎng)度
* @param {String} str 要拼接的字符
* @param {Boolean} isFront 是否在前面拼接,值為true時(shí)將str拼接到元字符串的前面,false則相反
* @return {String} 十六進(jìn)制字符串
*/
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)
}
}
十六進(jìn)制轉(zhuǎn)帶符號(hào)(-負(fù)號(hào))整型
/**
* 十六進(jìn)制轉(zhuǎn)帶符號(hào)整型
* @param {String} hexStr 十六進(jìn)制字符串
*/
function hex2int(hexStr) {
// 將十六轉(zhuǎn)十進(jìn)制,再轉(zhuǎn)2進(jìn)制
let twoStr = parseInt(hexStr,16).toString(2)
// 1個(gè)字節(jié) = 8bit ,0xff 一個(gè) "f"就是4位
let bitNum = hexStr.length * 4
if(twoStr.length < bitNum){
while(twoStr.length < bitNum){
twoStr = "0" + twoStr
}
}
if(twoStr.substring(0,1) == "0"){
// 正數(shù), // 二進(jìn)制轉(zhuǎn)十進(jìn)制
twoStr = parseInt(twoStr,2)
return twoStr
}else{
// 負(fù)數(shù)
let twoStr_unsign = ""
// 補(bǔ)碼:(負(fù)數(shù))反碼+1,符號(hào)位不變;相對(duì)十進(jìn)制來(lái)說(shuō)也是 +1,但這里是負(fù)數(shù),+1就是絕對(duì)值數(shù)據(jù)-1
twoStr = parseInt(twoStr,2) - 1
twoStr = twoStr.toString(2)
// 舍棄首位(符號(hào)位)
twoStr_unsign = twoStr.substring(1,bitNum)
// 去除首字符,將0轉(zhuǎn)為1,將1轉(zhuǎn)為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
}
}
帶符號(hào)(負(fù)號(hào))整數(shù)轉(zhuǎn)十六進(jìn)制字符串(得到8個(gè)字符十六進(jìn)制字符串)
/**
* 帶符號(hào)(負(fù)號(hào))整數(shù)轉(zhuǎn)十六進(jìn)制字符串
* @param {Number} number 整型,可帶符號(hào)
* @return {String} 8個(gè)字符長(zhǎng)度的十六進(jìn)制字符串
*/
function decToHex(number){
return (parseInt(number,10)>>>0).toString(16)
}
帶符號(hào)(負(fù)號(hào))整數(shù)轉(zhuǎn)二進(jìn)制字符串(4個(gè)字符)
可以將上一個(gè)方法decToHex得到的結(jié)果截取后四位,效果一樣
/**
* 帶符號(hào)(負(fù)號(hào))整數(shù)轉(zhuǎn)二進(jìn)制字符串(4個(gè)字符)
* @param {Number} number 整型,可帶符號(hào)
*/
function signDecToHex(i) {
return (i+0x10000).toString(16).substr(-4).toUpperCase()
}
十六進(jìn)制轉(zhuǎn)包含中文字符串,解碼十六進(jìn)制字符(強(qiáng)調(diào)小程序和瀏覽器不同)
/**
* 十六進(jìn)制字符串轉(zhuǎn)中文
* @param {String} hex 為十六進(jìn)制字符串
* @return {String} 包含中文的字符串
*/
function hexToStr(hex) {
// 去掉字符串首尾空格
let trimedStr = hex.trim()
// 判斷trimedStr前兩個(gè)字符是否為0x,如果是則截取從第三個(gè)字符及后面所有,否則返回全部字符
let rawStr = trimedStr.substr(0, 2).toLowerCase() === "0x" ? trimedStr.substr(2) : trimedStr
// 得到rawStr的長(zhǎng)度
let len = rawStr.length
// 如果長(zhǎng)度不能被2整除,那么傳入的十六進(jìn)制值有誤,返回空字符
if (len % 2 !== 0) {
return ""
}
let curCharCode // 接收每次循環(huán)得到的字符
let resultStr = [] // 存轉(zhuǎn)換后的十進(jìn)制值數(shù)組
for (let i = 0; i < len; i = i + 2) {
curCharCode = parseInt(rawStr.substr(i, 2), 16)
resultStr.push(curCharCode)
}
// encoding為空時(shí)默認(rèn)為utf-8
let bytesView = new Uint8Array(resultStr) // 8 位無(wú)符號(hào)整數(shù)值的類型化數(shù)組
// TextEncoder和TextDecoder對(duì)字符串和字節(jié)流互轉(zhuǎn)
// let str = new TextDecoder(encoding).decode(bytesView)因?yàn)樾〕绦蛑袥](méi)有TextDecoder,經(jīng)查閱資料,下載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
}
包含中文字符串轉(zhuǎn)十六進(jìn)制
注意:在微信小程序中可能不支持,中文,但是其他語(yǔ)言是支持的,不支持可能的原因和上面hexToStr一樣,需要借助TextEncoder,進(jìn)行轉(zhuǎn)換,因?yàn)闀r(shí)間關(guān)系,當(dāng)時(shí)放棄了小程序中文轉(zhuǎn)十六進(jìn)制這一功能。
// 中文字符串轉(zhuǎn)十六進(jìn)制:
/**
* @param {String} str 可包含中文的字符串
* @return {String} 返回十六進(jìn)制字符串
*/
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位小數(shù)點(diǎn)
/**
* 保留n位小數(shù),四舍五入
* @param {Number} _m_ 原始數(shù)字
* @param {Number} _n_ 保留n位,默認(rè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位小數(shù),向下取整
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; // 標(biāo)記小數(shù)點(diǎn)位置
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轉(zhuǎn)十六進(jìn)制
/**
* 保留n位小數(shù)
* @param {Number} r
* @param {Number} g
* @param {Number} b
* @return {String} 十六進(jìn)制字符串
*/
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)
}
將十六進(jìn)制Ascall碼字符串轉(zhuǎn)換為Ascall碼字符字符串:
注意:此方法需要借助本封裝函數(shù)中的substrHexStrToHexArray方法 將字符串平均分割n份(這里是將十六進(jìn)制Ascall碼字符串分割出來(lái)后再處理)和hexArrayToDecArray方法 將一個(gè)十六進(jìn)制字符數(shù)組轉(zhuǎn)十進(jìn)制字符數(shù)組
/** 將十六進(jìn)制字符串轉(zhuǎn)ascall碼轉(zhuǎn)對(duì)應(yīng)的字符拼接字符串:
* @param {String} hexStr 傳入十六進(jìn)制字符串
* @return {String} 返回十六進(jìn)制字符串轉(zhuǎn)換為十六進(jìn)制ascall碼對(duì)應(yīng)字符拼接的字符串:
*/
function hexStrToAscllChar (hexStr) {
// 獲取字符串的長(zhǎng)度:
const strLength = hexStr.length
// 如果傳入的字符串不能被2整除,直接返回空字符
if (strLength % 2 !== 0) return ''
// 計(jì)算要分割的份數(shù):
const count = strLength / 2
// 調(diào)用本工具函數(shù)中substrHexStrToHexArray方法得到十六進(jìn)制字符串對(duì)應(yīng)的十六進(jìn)制ascall碼數(shù)組
const hexArray = substrHexStrToHexArray(hexStr,count)
// 調(diào)用本工具函數(shù)中的hexArrayToDecArray方法將十六進(jìn)制字符串?dāng)?shù)組轉(zhuǎn)十進(jìn)制數(shù)組:
const decArray = hexArrayToDecArray(hexArray)
// 查詢十進(jìn)制ascall碼對(duì)應(yīng)的字符并拼接為字符串:
let str = ''
for (let i = 0; i < decArray.length; i++) {
// 查詢對(duì)應(yīng)的字符:
str += String.fromCharCode(decArray[i])
}
return str
}
將一個(gè)十六進(jìn)制字符串分割為n份存到數(shù)組并返回 :
/** 將一個(gè)十六進(jìn)制字符串分割為n份存到數(shù)組并返回:
* @param {String} hexStr 傳入十六進(jìn)制字符串
* @return {Array} 返回一個(gè)存十六進(jìn)制ascall碼的數(shù)組:
*/
function substrHexStrToHexArray (hexstr,cop) {
// 存放十六進(jìn)制的數(shù)組
let valueArray = []
// 一個(gè)值對(duì)應(yīng)的字符長(zhǎng)度
let itemLength = hexstr.length / cop
// 截取到某個(gè)值的十六進(jìn)制字符串
let itemStrHex
// 循環(huán)截取每個(gè)值,并將每個(gè)值保存到valueArray
for (let i = 0; i < cop; i++) {
// 截取到某個(gè)值的十六進(jìn)制字符串
itemStrHex = hexstr.slice(itemLength * i,itemLength * i + itemLength)
// 將截取的值存到數(shù)據(jù)中
valueArray.push(itemStrHex)
}
// 返回有效的十六進(jìn)制值
return valueArray
}
將一個(gè)十六進(jìn)制字符數(shù)組轉(zhuǎn)十進(jìn)制字符數(shù)組:
本方法中調(diào)用了本封裝的方法中的hex2int方法 將一個(gè)十六進(jìn)制字符數(shù)組轉(zhuǎn)十進(jìn)制字符數(shù)組
/** 將一個(gè)十六進(jìn)制字符數(shù)組轉(zhuǎn)十進(jìn)制字符數(shù)組:
* @param {Array} hexArray 傳入十六進(jìn)制字符串?dāng)?shù)組
* @return {Array} 返回一個(gè)存十進(jìn)制數(shù)據(jù)的數(shù)組:
*/
function hexArrayToDecArray (hexArray) {
let arr = []
let num
for (let i = 0; i < hexArray.length; i++) {
// 調(diào)用本工具函數(shù)中的hex2int方法將十六進(jìn)制字符串轉(zhuǎn)十進(jìn)制數(shù)字:
num = hex2int(hexArray[i])
// 并將轉(zhuǎn)換后的結(jié)果存到arr中
arr.push(num)
}
return arr
}
將一個(gè)十六進(jìn)制字符數(shù)組轉(zhuǎn)十進(jìn)制字符數(shù)組:文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-486851.html
/** 將一個(gè)十六進(jìn)制字符數(shù)組轉(zhuǎn)十進(jìn)制字符數(shù)組:
* @param {Array} hexArray 傳入十六進(jìn)制字符串?dāng)?shù)組
* @return {Array} 返回一個(gè)存十進(jìn)制數(shù)據(jù)的數(shù)組:
*/
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)
}
計(jì)算crc校驗(yàn)位
/**
* 計(jì)算crc校驗(yàn)位
* @param {Number} parapms 需要計(jì)算的值
* @return {String} 帶有校驗(yàn)位的值
*/
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, "");
//若字符個(gè)數(shù)為奇數(shù),補(bǔ)一個(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)
}
提示:本文圖片等素材來(lái)源于網(wǎng)絡(luò),若有侵權(quán),請(qǐng)發(fā)郵件至郵箱:810665436@qq.com聯(lián)系筆者刪除。
筆者:苦海文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-486851.html
到了這里,關(guān)于JS十六進(jìn)制轉(zhuǎn)浮點(diǎn)、字符串轉(zhuǎn)為ArrayBuffer、ArrayBuffer轉(zhuǎn)16進(jìn)制字符串、16進(jìn)制轉(zhuǎn)10進(jìn)制、crc校驗(yàn)位、十六進(jìn)制轉(zhuǎn)中文字符串(小程序、瀏覽器)、十六進(jìn)制字符串轉(zhuǎn)ascall字串的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!