• 技术文章 >web前端 >js教程

    JS如何判断文字是全角还是半角

    Y2JY2J2017-05-20 13:21:04原创4032
    全角:是一种电脑字符,是指一个全角字符占用两个标准字符(或两个半角字符)的位置。全角占两个字节。半角:是指一个字符占用一个标准的字符位置。半角占一个字节。接下来通过本文给大家介绍JS验证全角与半角及相互转化的知识,需要的朋友参考下吧

    1.什么是全角和半角?

    全角:是一种电脑字符,是指一个全角字符占用两个标准字符(或两个半角字符)的位置。全角占两个字节。

    汉字字符和规定了全角的英文字符及国标GB2312-80中的图形符号和特殊字符都是全角字符。在全角中,字母和数字等与汉字一样占据着等宽的位置。

    半角:是指一个字符占用一个标准的字符位置。半角占一个字节。

    半角就是 ASCII 方式的字符,在没有汉字输入法起作用的时候,输入的字母、数字和字符都是半角的。

    每个半角字符只占用一字节的空间(一字节有8位,共256个编码空间)。汉语、日语、及朝鲜文等象形字语言的字库量远大于256个编码空间,所以改用两个字节来储存。同时,由于中日韩等象形文字的书写习惯,如果统一使用全角字符的话,排列起来也显得整齐。

    为了排列整齐,英文和其它拉丁文的字符和标点也提供了全角格式。

    2.全角和半角的区别

    全角和半角主要是针对标点符号来说的,全角标点占两个字节,半角占一个字节。不管是半角还是全角,汉字都要占两个字节。

    3.js判断输入的文字是全角还是半角?

    str="中文;;a"   
    alert(str.match(/[\u0000-\u00ff]/g))   //半角  
    alert(str.match(/[\u4e00-\u9fa5]/g))   //中文  
    alert(str.match(/[\uff00-\uffff]/g))   //全角

    4.js对全角与半角的相互转化

    首先,先得明确以下信息:

    a.全角空格为12288,半角空格为32

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

    半角转化为全角

    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的charCodeAt() 方法与fromCharCode() 方法。

    charCodeAt() 方法可返回指定位置的字符的 Unicode 编码。这个返回值是 0 - 65535 之间的整数

    fromCharCode() 可接受一个指定的 Unicode 值,然后返回一个字符串

    想详细的了解charCodeAt() 方法与fromCharCode()方法,可以点击《JavaScript charCodeAt() 方法》与《JavaScript fromCharCode() 方法》。

    全角转换为半角

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

    【相关推荐】

    1. Javascript免费视频教程

    2. nodejs+websocket完成一个聊天系统功能

    3. Js完成倒计时时差效果

    4. 关于JS中递归删除数组中元素的方法详解

    5. JS完成星级评分功能的实例详解

    以上就是JS如何判断文字是全角还是半角的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    上一篇:nodejs+websocket完成一个聊天系统功能 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 浅析Angular中的Change Detection机制• 实战学习:聊聊Node.js怎么操作数据库• 一文聊聊node中的path模块• 浅析Angular变更检测中的订阅异步事件• 聊聊如何选择一个最好的Node.js Docker镜像?
    1/1

    PHP中文网