下载鸥 > 网站下载 > 开发教程 > JS/JQuery

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

346 2021-05-08 20:00:03

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

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版教程
发表评论 共有条评论
关于JS/JQuery


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

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

推荐JS/JQuery开发教程
JS验证手机是否11位的做法
JS验证手机是否11位的做法

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

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

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

0 502
怎样点击清除ul里的全部li信息?
怎样点击清除ul里的全部li信息?

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

1 447
Superslide响应式页面直接应用手机端技巧介绍
Superslide响应式页面直接应用手机端技巧介绍

如果是响应式网站,那么用superslide做轮播图需要做两个,这无疑是非常不方便的...

1 423
swiper轮播图空白案例记录
swiper轮播图空白案例记录

今天鸥哥在用swiper做轮播图时,轮播效果虽然没问题,但只显示第一张,后面的图片...

0 336
jQuery监听点击事件弹出关注二维码教程
jQuery监听点击事件弹出关注二维码教程

通过jQuery实现点击关注按钮弹出二维码是一个比较常用的功能,今天鸥哥讲讲这...

0 417
js判断windows操作系统还是mac os系统
js判断windows操作系统还是mac os系统

网站日常访客主要是windows和mac os两种操作系统,如果网站提供资源下载,则需...

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

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

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

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

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

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

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

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

0 460
帝国cms智能自动审核按星期几审核指定栏目带推送插件
帝国cms智能自动审核按星期几审核指定栏目带推送插件

采集站的必备资源是自动审核,要做到日收录也离不开定时发布。而本插件的自动...

0 1147
帝国cms在线考试系统模板插件
帝国cms在线考试系统模板插件

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

0 1179
帝国cms批量添加后台用户插件
帝国cms批量添加后台用户插件

使用帝国cms的企业用户、新闻资讯类站点的用户很多,此类站点很多时候需要有...

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

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

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

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

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