现在位置首页 / Jquery/Jquery Mobile /正文

javascript各种进制转换方法

作者: IT小兵 | 2016年6月25日| 热度:℃ | 评论: |参与:

开发中,我们一般遇到进制的转换,也无非是下面几种:2进制,8进制,10进制,16进制。今天分享一下在JavaScript中,怎么进行各种进制转换的方法。

我们直接利用 对象.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"

 如果要实现进制之间的转换, 可以利用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>


点击阅读本文所属分类的更多文章: Jquery/Jquery Mobile 。和高手一起交流:346717337
友荐云推荐

未注明转发、原文均为本站原创。分享本文请注明 原文链接

给您更多信息和帮助

在这里您可以找到更多:

技术交流群:346717337 Jquery插件交流

投稿:[email protected]

承接:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/业务咨询

echarts教程系列
本月最热文章

微信扫一扫,徜徉悠嘻网,您的休闲乐园

微信公众号:快乐每一天

随机文章
标签

技术交流群:346717337

投稿:[email protected]

专业专注:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/付费问题咨询