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

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

441 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验证手机是否11位的做法
JS验证手机是否11位的做法

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

1 448
怎样点击清除ul里的全部li信息?
怎样点击清除ul里的全部li信息?

在通过jQuery做数据交互时我们可能存在这样的需求:通过点击按钮清空ul里的li...

1 529
JS获取当前时间、日期、星期并每秒更新一次
JS获取当前时间、日期、星期并每秒更新一次

很多网站上会有当前年月日、星期、时间的展示。这个展示用php做未免浪费性...

0 439
JS点击复制data-*属性(支持多个元素)
JS点击复制data-*属性(支持多个元素)

分享一段js原生点击复制data-*属性的源码,根据onclick事件触发,复制当前元素...

0 423
js点击追加信息到textarea
js点击追加信息到textarea

通过灵活运用js,我们可以轻松实现点击追加相关信息到textarea的功能。这个功...

0 603
js网站视频播放器ckplayer和dplayer优缺点分析
js网站视频播放器ckplayer和dplayer优缺点分析

dplayer和ckplayer都是非常流行的web视频播放器,二者都占有相当大的用户市场...

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

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

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

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

0 483
推荐插件
帝国cms在线考试系统模板插件
帝国cms在线考试系统模板插件

一直没看到好用的帝国cms在线考试插件,所以自己开发了一款。在线考试插件用...

0 1346
帝国cms联想词搜索高级搜索插件下载
帝国cms联想词搜索高级搜索插件下载

帝国CMS自带的搜索功能虽然强大,但也有很强的局限性 -- 必须关键词完全匹配...

0 801
帝国cms访问统计ip地址链接与封禁插件下载
帝国cms访问统计ip地址链接与封禁插件下载

下载鸥开发了这款帝国cms封禁ip插件,自动记录访问情况,让我们可以更快的识别...

0 1112
帝国cms百度AI图像去雾api接口对接插件
帝国cms百度AI图像去雾api接口对接插件

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

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

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

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

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

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

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

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

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

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