中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

JS中的進制轉換以及作用
來源:易賢網 閱讀:1037 次 日期:2016-07-12 15:17:57
溫馨提示:易賢網小編為您整理了“JS中的進制轉換以及作用”,方便廣大網友查閱!

這篇文章主要介紹了JS中的進制轉換以及作用的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

js的進制轉換, 分為2進制,8進制,10進制,16進制之間的相互轉換, 我們直接利用 對象.toString()即可實現:

運行下面代碼

//10進制轉為16進制

(10).toString(16) // =>"a"

//8進制轉為16進制

(012).toString(16) // =>"a"

//16進制轉為10進制

(0x16).toString(10) // =>"22"

//16進制轉為8進制

(0x16).toString(8) // =>"26"

//10進制轉為2進制 //=>

(1111).toString(2) // => "10001010111"

//8進制轉為2進制 //=>

(01111).toString(2) //=>"1001001001"

//16進制轉為2進制 //=>

(0x16).toString(2) // => "10110"

如果要處理2進制到10進制,16進制到10進制,8進制到10進制, 需要用了paresInt這個方法:

運行下面代碼

//2進制到10進制;

parseInt(10,2) //=>2

//2進制到10進制;

parseInt(100,2) //=>4

//16進制到10進制

parseInt(12, 16) //=>18

//8進制到10進制

parseInt(12,8); //=>10

進制轉換

如果要實現進制之間的轉換, 可以利用parseInt方法, 先轉化為10進制, 然后再利用toString(參數), 轉化成不同的進制;

利用toString和parseInt方法可以實現一個進制轉化的工具:

運行下面代碼

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>無標題文檔</title>

</head>

<body>

<script language="javascript">

function test()

{

var num=document.getElementById("in").value;

var type=document.getElementById("title");

var tynum,to;

for(var i=0;i<type.length;i++)

{

if(type[i].selected)

tynum=parseInt(type[i].value);

}

switch(tynum)

{

case(1):to=parseInt(num).toString(2);break;

case(2):to=parseInt(num).toString(8);break;

case(3):to=parseInt(num).toString(16);break;

case(4):to=parseInt(num,2);break;

case(5):to=parseInt(num,8);break;

case(6):to=parseInt(num,16);break;

case(7):to=parseInt(num,2).toString(8);break;

case(8):to=parseInt(num,8).toString(2);break;

case(9):to=parseInt(num,2).toString(16);break;

case(10):to=parseInt(num,16).toString(2);break;

case(11):to=parseInt(num,8).toString(16);break;

case(12):to=parseInt(num,16).toString(8);break;

}

if(isNaN(to))

to="輸入非法字符了哦"

document.getElementById("out").value=to;

}

</script>

<select name="title" id="title" style="width:152px;">

<option value="1">十進制轉二進制</option>

<option value="2">十進制轉八進制</option>

<option value="3">十進制轉十六進制</option>

<option value="4">二進制轉十進制</option>

<option value="5">八進制轉十進制</option>

<option value="6">十六進制轉十進制</option>

<option value="7">二進制轉八進制</option>

<option value="8">八進制轉二進制</option>

<option value="9">二進制轉十六進制</option>

<option value="10">十六進制轉二進制</option>

<option value="11">八進制轉十六進制</option>

<option value="12">十六進制轉八進制</option>

</select><br />

<input type="text" id="in" /><br>

<input type="text" id="out" /><br/>

<input type="button" value="change" onclick="test()" />

<font color="#FF0000" style="font-size:12px;">*注:存在非法字符時,我們只截斷有效字符進行轉換</font>

</body>

</html>

簡單加密解密

把字符串轉化成unicode, 然后再把unicode轉成不同的進制 , 實現代碼加密處理:

運行下面代碼

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8"/>

<title></title>

</head>

<body>

<script>

function en(code, h){

//簡單的jS加密解密<br>//code為對應的字符串,h為(2,8,10,16)就是要轉成的幾進制<br>function en(code, h) {

var monyer = new Array();var i;

for(i=0;i<code.length;i++)

monyer+=code.charCodeAt(i).toString(h)+"_";//就是把字符串轉成ascll碼,然后再轉成你想的幾進制

return monyer;

};

function de(code, h) {

var i,s="",code = code.split("_");

for(i=0;i<code.length;i++) {

s += String.fromCharCode(parseInt(code[i],h));

};

return s

};

en("1哇哈哈",8) //=> "61_52307_52310_52310_"

de("61_52307_52310_52310_",8) //=> "1哇哈哈

</script>

</body>

</html>

零寬字符

利用零寬字符的零寬度, 我們把所有的字符串轉化成二進制, 然后利用零寬字符進行表示, 那么生成的字符串長度就會為0, 主要反編譯即可還原,

運行下面代碼

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8"/>

<title></title>

</head>

<body>

<script>

function en(str) {

var rep = {

'00': '\u200b',

'01': '\u200c',

'10': '\u200d',

'11': '\uFEFF'

};

str = str.replace(/[^\x00-\xff]/g, function (a) { // 轉碼 Latin-1 編碼以外的字符。

return escape(a).replace('%', '\\');

});

str = str.replace(/[\s\S]/g, function (a) { // 處理二進制數據并且進行數據替換

a = a.charCodeAt().toString(2);

a = a.length < 8 ? Array(9 - a.length).join('0') + a : a;

return a.replace(/../g, function (a) {

return rep[a];

});

});

return str;

}

;

function de(str) {

return unescape(str.replace(/.{4}/g, function (a) {

var rep = {"\u200b": "00", "\u200c": "01", "\u200d": "10", "\uFEFF": "11"};

return String.fromCharCode(parseInt(a.replace(/./g, function (a) {

return rep[a]

}), 2)).replace(/\\/g,"%")

}))

}

var str = en("1哇哈哈");

console.log(str.length);

console.log(de(str));

</script>

</body>

</html>

以上所述是小編給大家介紹的JS中的進制轉換以及作用的全部敘述,希望對大家有所幫助

更多信息請查看網絡編程
易賢網手機網站地址:JS中的進制轉換以及作用
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
主站蜘蛛池模板: 明溪县| 临湘市| 论坛| 泸西县| 宝坻区| 安远县| 沈丘县| 从江县| 南漳县| 繁昌县| 登封市| 珲春市| 海淀区| 桦甸市| 饶阳县| 罗山县| 九龙县| 壤塘县| 上蔡县| 隆林| 鸡东县| 山东省| 三门县| 西林县| 遵义县| 临洮县| 盐池县| 财经| 化德县| 侯马市| 龙泉市| 缙云县| 天全县| 洛隆县| 台山市| 库尔勒市| 临颍县| 卓尼县| 绥德县| 扶沟县| 贵州省|