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

发布时间 - 2026-01-11 02:09:43    点击率:

最近在做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全角与半角转化实例(分享)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# 全角半角转化  # JS验证全角与半角及相互转化的介绍  # 半角全角相互转换的js函数  # javascript实现全角与半角字符的转换  # javascript实现全角半角检测的方法  # JavaScript 全角转半角部分  # 全角  # 半角  # 给大家  # 西文  # 都是  # 日语  # 希望能  # 英语  # 一个字  # 这篇  # 两个字  # 表单  # 编辑器  # 两倍  # 小编  # 大家多多  # 只占  # 转化成  # 也由  # 英文字母 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  如何获取上海专业网站定制建站电话?  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  使用C语言编写圣诞表白程序  详解Android图表 MPAndroidChart折线图  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  Laravel如何实现文件上传和存储?(本地与S3配置)  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  如何在IIS中新建站点并配置端口与物理路径?  如何用虚拟主机快速搭建网站?详细步骤解析  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】  如何正确选择百度移动适配建站域名?  在centOS 7安装mysql 5.7的详细教程  如何快速选择适合个人网站的云服务器配置?  Laravel如何使用Sanctum进行API认证?(SPA实战)  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  js实现点击每个li节点,都弹出其文本值及修改  Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】  UC浏览器如何设置启动页 UC浏览器启动页设置方法  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  海南网站制作公司有哪些,海口网是哪家的?  浅谈Javascript中的Label语句  教学论文网站制作软件有哪些,写论文用什么软件 ?  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  浅谈javascript alert和confirm的美化  Android Socket接口实现即时通讯实例代码  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  如何在建站之星网店版论坛获取技术支持?  HTML 中如何正确使用模板变量为元素的 name 属性赋值  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  如何在IIS7上新建站点并设置安全权限?  如何快速建站并高效导出源代码?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何在阿里云通过域名搭建网站?  Laravel如何自定义错误页面(404, 500)?(代码示例)  Laravel如何处理和验证JSON类型的数据库字段  Laravel如何实现模型的全局作用域?(Global Scope示例)  Windows Hello人脸识别突然无法使用  jquery插件bootstrapValidator表单验证详解  Laravel如何记录自定义日志?(Log频道配置)  简历没回改:利用AI润色让你的文字更专业  JavaScript常见的五种数组去重的方式  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?