下载鸥 > 网站下载 > 开发教程 > 前端开发

JS控制输入字数的两个方案

425 2021-05-08 20:00:03

收藏
我们在文章输入框中经常有用到字数控制,但字数控制有两种方案,一种是字母/空格/汉字均占两个字节,一种是字母占一个字节、汉字占两个字节,下面我们对两种方案都做一个简单的演示。

JS控制输入字数的两个方案

方案一

字母/空格/汉字均占两个字节
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <style type="text/css">
    textarea{
      width: 400px;
      height:400px;
      resize: none;
    }
    .limit{
      width: 400px;
      text-align: right;
    }
    #d1{
      margin: 100px;
    }
  </style>
</head>
<body>
  <div id = "d1">
    <div>事件描述</div>
    <div>
      <textarea></textarea>
    </div>
    <div class="limit">
      最大可输入
      <span>0</span>/20
    </div>
  </div>
  <script type="text/javascript">
    //先定义计算字符串字数
    function getStrleng(str,max) { 
        myLen = 0;
        i = 0;
        for (; (i < str.length) && (myLen <= max * 2); i++) {
            if (str.charCodeAt(i) > 0 && str.charCodeAt(i) < 128)           //根据Unicode编码值判断是否汉字
                myLen++;
            else
                myLen += 2;
        }
        return myLen;
    }
    //定义函数获得DOM元素
    function Q(s){
      return document.querySelector(s);
    }
    //定义函数显示写了几个字
    function checkWord(c) {
        var maxstrlen = 20;    
        var str = c.value;              //对象的内容
        myLen = getStrleng(str,maxstrlen);   //计算str的字符个数
        var wck = Q(".limit span");
        console.log(wck)
        if(myLen > maxstrlen * 2){
          c.value = str.substring(0, i - 1);
        }else{
          wck.innerHTML = Math.floor(myLen / 2);
        } 
    }
    Q('textarea').onkeyup =function(){
      checkWord(this);
    }
  </script>
</body>
</html>
 

方案二

字母占一个字节,汉字占两个字节
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <style type="text/css">
    textarea{
      width: 400px;
      height:400px;
      resize: none;
    }
    .limit{
      width: 400px;
      text-align: right;
    }
    #d1{
      margin: 100px;
    }
  </style>
</head>
<body>
  <div id = "d1">
    <div>事件描述</div>
    <div>
      <textarea></textarea>
    </div>
    <div class="limit">
      最大可输入
      <span>0</span>/20
    </div>
  </div>
  <script type="text/javascript">
    //先定义计算字符串字数
    //定义函数获得DOM元素
    function Q(s){
      return document.querySelector(s);
    }
    function check(c){
      var max = 20;
      var span = Q('.limit span');
      var length = c.value.length;
      if(length <= max){
        span.innerHTML = c.value.length;
      }else{
        c.value = c.value.slice(0,max);
      }
    }
    Q('textarea').onkeyup =function(){
      check(this);
    }
  </script>
</body>
</html>

以上两个方案,就是我们常用的js控制输入字数的方式。

本文地址:https://xzo.com.cn/develop/js/922.html

有帮助,很赞!

信息来源:下载鸥
导出教程 下载word版教程
发表评论 共有条评论
关于前端开发


JavaScript(简称“JS”) 是一种具有函数优先的轻量级,解释型或即时编译型的编程语言。JavaScript 基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式(如函数式编程)风格。

JavaScript十分强大,不管是前端页面开发、视觉动态渲染、数据交互还是后端逻辑处理,都可以通过JS实现。虽然它是作为开发Web页面的脚本语言而出名,但是它也被用到了很多非浏览器环境中。

推荐前端开发开发教程
JS怎样做倒计时效果?
JS怎样做倒计时效果?

在各种盛大的节日、活动前,网站制作倒计时特效可有效给活动页引流。那么,怎样...

1 461
JavaScript过滤XSS攻击方法
JavaScript过滤XSS攻击方法

什么是XSS?XSS(Cross Site Scripting),跨站脚本攻击,是一种允许攻击者在另外一个...

1 406
通过原生的JS实现点击复制效果
通过原生的JS实现点击复制效果

对于网站、app开发等工作而言,复制是一个非常常见的功能。很多人到处找插件...

1 470
JS验证手机是否11位的做法
JS验证手机是否11位的做法

在网站表单提交前,我们往往需要验证一下信息避免错误数据,那么,怎样验证手机号...

1 432
jQuery怎样监听鼠标滚动是向上还是向下的状态?
jQuery怎样监听鼠标滚动是向上还是向下的状态?

知乎鼠标向下滚动显示文章标题,向上滚动显示栏目;又或者向下滚动到底部时异步...

0 586
$(window).height() 和 $(document).height()有什么不同?
$(window).height() 和 $(document).height()有什么不同?

我们常用$(window).height() 和 $(document).height()来监听当前高度,但这个...

1 433
JS判断苹果iPhone与iPad、安卓设备类型适配
JS判断苹果iPhone与iPad、安卓设备类型适配

在网站开发的过程中,一些涉及到资源下载的网站会通过判断不同系统手机来展示...

3 713
jQuery怎样给图片添加默认域名?
jQuery怎样给图片添加默认域名?

在很多网站中,图片的默认路径是相对于根目录的绝对路径,如果是其他站点引用,则...

0 464
推荐插件
帝国cms百度AI图像清晰度增强api接口对接插件
帝国cms百度AI图像清晰度增强api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像清晰度增强的功能。经...

0 543
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 579
帝国cms百度AI黑白图像上色api接口对接插件
帝国cms百度AI黑白图像上色api接口对接插件

百度开放了系列AI功能api如图像上色、图像去雾、图像修复、无损放大、清晰...

0 451
帝国cms百度文字识别ocr接口对接插件
帝国cms百度文字识别ocr接口对接插件

许多网站会做一些小功能小插件给客户使用以增强用户黏性,比如图片转文字,这种...

0 487
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

0 452
帝国cms百度AI图像无损放大api接口对接插件
帝国cms百度AI图像无损放大api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像无损放大的功能。经过...

0 467
帝国cms自动给正文关键词添加tag内链
帝国cms自动给正文关键词添加tag内链

帝国cms有自带的给关键词添加内链功能,但需要手动添加关键词,容易出现疏漏和...

0 858
帝国cms网站会员登录与退出历史记录日志插件
帝国cms网站会员登录与退出历史记录日志插件

帝国cms默认只有上次登录时间与ip,没有一个记录清单,所以今天,我们分享这个帝...

0 424
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入