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

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

330 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怎样做倒计时效果?
JS怎样做倒计时效果?

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

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

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

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

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

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

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

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

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

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

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

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

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

0 1585
jQuery怎样给图片添加默认域名?
jQuery怎样给图片添加默认域名?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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