JavaScript转换二进制编码为ASCII码的方法


Posted in Javascript onApril 16, 2015

本文实例讲述了JavaScript转换二进制编码为ASCII码的方法。分享给大家供大家参考。具体如下:

<html>
<head>
<script type="text/javascript">
var input_id = "bin_text";
var answer_id = "answer";
function convertToASCII() {
 var bin_text = document.getElementById(input_id);
 var answer = document.getElementById(answer_id);
 if (!answer) {
  alert("Error: No element with id \""+answer_id+"\".");
  return;
 }
 if (bin_text)
  var text = bin_text.value;
 else {
  error("No element with id \""+input_id+"\".");
  return;
 }
 var divisible = text.length % 8;
 var nonBinary = /[^0|1]/.test(text);
 if (text.length > 0 && divisible == 0 && !nonBinary) {
  var regex = /[0|1]{8}/g;
  var str = text.match(regex);
  var code = 0;
  var placeVal, exp, digit;
  var ascii = '';
  while (str.length > 0) {
   code = 0;
   for (var i=0; i<str[0].length; i++) {
    placeVal = 7-i;
    exp = Math.pow(2, i);
    digit = str[0].charAt(placeVal);
    code += exp*digit;
   }
   str.shift();
   ascii += String.fromCharCode(code);
  }
  answer.innerHTML = "<p class=\"binary\">" + ascii + "</p>";
 }
 else {
  error("Malformed binary.");
  return;
 }
 function error(errText) {
  answer.innerHTML = "<span class=\"error\">Error: " + 
  errText + "</span>";
 }
}
</script>
<style type="text/css">
.block {
 width: 45%;
 border: 1px solid #000000;
 padding: 10px;
}
.binary {
 background-color: #C6FFC7;
 padding: 3px;
}
.error {
 background-color: #FFC6C6;
 padding: 3px;
}
</style>
</head>
<body>
<div style="float:left;" class="block">
 <form onSubmit="convertToASCII(); return false;">
  <p>Enter some binary to decode:</p>
  <input type="text" id="bin_text"/>
 </form>
</div>
<div style="float:right;" class="block">
 <p id="answer"><br/></p>
</div>
</body>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
自适应图片大小的弹出窗口
Jul 27 Javascript
JavaScript Prototype对象
Jan 07 Javascript
Javascript setInterval的两种调用方法(实例讲解)
Nov 29 Javascript
javascript制作loading动画效果 loading效果
Jan 14 Javascript
jQuery实现为控件添加水印文字效果(附源码)
Dec 02 Javascript
Angular的模块化(代码分享)
Dec 26 Javascript
jQuery简介_动力节点Java学院整理
Jul 04 jQuery
Express下采用bcryptjs进行密码加密的方法
Feb 07 Javascript
LayUI动态设置checkbox不显示的解决方法
Sep 02 Javascript
Vuex实现购物车小功能
Aug 17 Javascript
Node.js 中判断一个文件是否存在
Aug 24 Javascript
详解ES6中class的实现原理
Oct 03 Javascript
JavaScript实现彩虹文字效果的方法
Apr 16 #Javascript
JavaScript监听文本框回车事件并过滤文本框空格的方法
Apr 16 #Javascript
JQuery跳出each循环的方法
Apr 16 #Javascript
jQuery $.each遍历对象、数组用法实例
Apr 16 #Javascript
jQuery Ajax中的事件详细介绍
Apr 16 #Javascript
JavaScript实现页面5秒后自动跳转的方法
Apr 16 #Javascript
JavaScript实现随机替换图片的方法
Apr 16 #Javascript
You might like
如何对PHP程序中的常见漏洞进行攻击
2006/10/09 PHP
Ha0k 0.3 PHP 网页木马修改版
2009/10/11 PHP
使用php发送有附件的电子邮件-(PHPMailer使用的实例分析)
2013/04/26 PHP
php编写的简单页面跳转功能实现代码
2013/11/27 PHP
PHP实现支持CURL字符串证书传输的方法
2019/03/23 PHP
WordPress伪静态规则设置代码实例
2020/12/10 PHP
权威JavaScript 中的内存泄露模式
2007/08/13 Javascript
JS判定是否原生方法
2013/07/22 Javascript
JQuery勾选指定name的复选框集合并显示的方法
2015/05/18 Javascript
Javascript实现检测客户端类型代码封包
2015/12/03 Javascript
JavaScript中用let语句声明作用域的用法讲解
2016/05/20 Javascript
JavaScript编码风格指南(中文版)
2016/08/26 Javascript
Webpack中css-loader和less-loader的使用教程
2017/04/27 Javascript
vue左侧菜单,树形图递归实现代码
2018/08/24 Javascript
Laravel 如何在blade文件中使用Vue组件的示例代码
2020/06/28 Javascript
js异步接口并发数量控制的方法示例
2020/11/22 Javascript
python cookielib 登录人人网的实现代码
2012/12/19 Python
python类型强制转换long to int的代码
2013/02/10 Python
Python tempfile模块学习笔记(临时文件)
2014/05/25 Python
python中执行shell的两种方法总结
2017/01/10 Python
pandas Dataframe行列读取的实例
2018/06/08 Python
Python计算开方、立方、圆周率,精确到小数点后任意位的方法
2018/07/17 Python
postman和python mock测试过程图解
2020/02/22 Python
初学者学习Python好还是Java好
2020/05/26 Python
HTML5拖拽的简单实例
2016/05/30 HTML / CSS
Nike瑞典官方网站:Nike.com (SE)
2018/11/26 全球购物
日本化妆品植村秀俄罗斯官方网站:Shu Uemura俄罗斯
2020/02/01 全球购物
Linux内核的同步机制是什么?主要有哪几种内核锁
2013/01/03 面试题
2014自荐信的写作技巧
2014/01/28 职场文书
2015年财务科工作总结范文
2015/05/13 职场文书
2016十一国庆节感言
2015/12/09 职场文书
新西兰:最新留学学习计划书写作指南
2019/07/15 职场文书
关于感恩的素材句子(38句)
2019/11/11 职场文书
超外差式晶体管收音机的组装与统调
2021/04/22 无线电
Python机器学习之基础概述
2021/05/19 Python
webpack介绍使用配置教程详解webpack介绍和使用
2022/06/25 Javascript