JS全角与半角转化实例(分享)


Posted in Javascript onJuly 04, 2017

最近在做PC端网站的页面的一个表单校验,需要把全角输入转化成半角符号。之前没有了解过这些编码的知识,还是得Google一下查查资料,故简单总结一下。

什么是全角、半角

传统上,英语或拉丁字母语言使用的电脑系统,每一个字母或符号,都是使用一字节的空间(一字节由8比特组成,共256个编码空间)来储存;而汉语、日语及韩语文字,由于数量大大超过256个,故惯常使用两字节来储存一个字符。在使用等宽字体(如DOS、部分文字编辑器等)的环境下,中日韩文字此时占据两倍于西文字符的显示宽度。所以,中、日、韩等文字称为全角字符,相比起来,拉丁字母或数字就称为半角字符。有时为了使字体看起来齐整,英文字母、数字及其他符号也由原来只占一个字空间,改为占用两个字的空间显示、使用两个字节储存的格式。(维基百科)

转化原理

全角空格unicode编码为12288,半角空格为32

其他字符半角(33-126)与全角(65281-65374)的unicode编码对应关系是:均相差65248

全角转半角

function ToCDB(str) {
    var tmp = "";
    for (var i = 0; i < str.length; i++) {
      if (str.charCodeAt(i) > 65248 && str.charCodeAt(i) < 65375) {
        tmp += String.fromCharCode(str.charCodeAt(i) - 65248);
      }
      else {
        tmp += String.fromCharCode(str.charCodeAt(i));
      }
    }
    return tmp
  }

半角转全角

function ToDBC(txtstring) {
    var tmp = "";
    for (var i = 0; i < txtstring.length; i++) {
      if (txtstring.charCodeAt(i) == 32) {
        tmp = tmp + String.fromCharCode(12288);
      }
      if (txtstring.charCodeAt(i) < 127) {
        tmp = tmp + String.fromCharCode(txtstring.charCodeAt(i) + 65248);
      }
    }
    return tmp;
  }

以上这篇JS全角与半角转化实例(分享)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery EasyUI中对表格进行编辑的实现代码
Jun 10 Javascript
jQuery EasyUI API 中文文档 - MenuButton菜单按钮使用介绍
Oct 06 Javascript
jQuery渐变发光导航菜单的实例代码
Mar 27 Javascript
一个判断抢购时间是否到达的简单的js函数
Jun 23 Javascript
Vue.js快速入门实例教程
Oct 15 Javascript
JS实现重新加载当前页面
Nov 29 Javascript
JQuery 封装 Ajax 常用方法(推荐)
May 21 jQuery
AngularJS+Bootstrap3多级导航菜单的实现代码
Aug 16 Javascript
在react-router4中进行代码拆分的方法(基于webpack)
Mar 08 Javascript
扫微信小程序码实现网站登陆实现解析
Aug 20 Javascript
js实现录音上传功能
Nov 22 Javascript
JS判断数组是否包含某元素实现方法汇总
Jun 24 Javascript
详解如何提高 webpack 构建 Vue 项目的速度
Jul 03 #Javascript
vue.js源代码core scedule.js学习笔记
Jul 03 #Javascript
lhgcalendar时间插件限制只能选择三个月的实现方法
Jul 03 #Javascript
JavaScript生成图形验证码
Aug 24 #Javascript
JS滚动到指定位置导航栏固定顶部
Jul 03 #Javascript
mac上node.js环境的安装测试
Jul 03 #Javascript
关于页面刷新vuex数据消失问题解决方案
Jul 03 #Javascript
You might like
ftp类(myftp.php)
2006/10/09 PHP
PHP中批量生成静态html(命令行下运行PHP)
2014/04/19 PHP
如何使用PHP对网站验证码进行破解
2015/09/17 PHP
你必须知道的Javascript知识点之&quot;字面量和对应类型&quot;说明介绍
2013/04/23 Javascript
Jquery获取复选框被选中值的简单方法
2013/07/04 Javascript
JS 按钮点击触发(兼容IE、火狐)
2013/08/07 Javascript
parentElement,srcElement的使用小结
2014/01/13 Javascript
jQuery函数的第二个参数获取指定上下文中的DOM元素
2014/05/19 Javascript
jquery实现人性化的有选择性禁用鼠标右键
2014/06/30 Javascript
JS创建类和对象的两种不同方式
2014/08/08 Javascript
使用AngularJS 应用访问 Android 手机的图片库
2015/03/24 Javascript
javascript实现Email邮件显示与删除功能
2015/11/21 Javascript
js将json格式的对象拼接成复杂的url参数方法
2016/05/25 Javascript
js实现PC端根据IP定位当前城市地理位置
2017/02/22 Javascript
vue项目总结之文件夹结构配置详解
2017/12/13 Javascript
webpack-dev-server自动更新页面方法
2018/02/22 Javascript
详解Vue.js项目API、Router配置拆分实践
2018/03/16 Javascript
layUI的验证码功能及校验实例
2019/10/25 Javascript
Vue组件模板的几种书写形式(3种)
2020/02/19 Javascript
Vue 使用typescript如何优雅的调用swagger API
2020/09/01 Javascript
PyCharm安装第三方库如Requests的图文教程
2018/05/18 Python
Django中提示消息messages的设置方式
2019/11/15 Python
在flask中使用python-dotenv+flask-cli自定义命令(推荐)
2020/01/05 Python
sklearn的predict_proba使用说明
2020/06/28 Python
Pycharm Git 设置方法
2020/09/15 Python
6种非常炫酷的CSS3按钮边框动画特效
2016/03/16 HTML / CSS
HTML5 Canvas实现平移/放缩/旋转deom示例(附截图)
2013/07/04 HTML / CSS
Lulu Guinness露露·吉尼斯官网:红唇包
2019/02/03 全球购物
迪奥美国官网:Dior美国
2019/12/07 全球购物
小加工厂管理制度
2014/01/21 职场文书
法学专业大学生实习自我鉴定
2014/10/05 职场文书
党员个人年度总结
2015/02/14 职场文书
商务英语邮件开头问候语
2015/11/10 职场文书
pandas DataFrame.shift()函数的具体使用
2021/05/24 Python
JPA如何使用entityManager执行SQL并指定返回类型
2021/06/15 Java/Android
MongoDB数据库的安装步骤
2021/06/18 MongoDB