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

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

404 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开发教程
JavaScript过滤XSS攻击方法
JavaScript过滤XSS攻击方法

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

1 400
jquery怎样获取textarea用户输入的行数?
jquery怎样获取textarea用户输入的行数?

jQuery是一个相当好用的js插件,通过jquery我们可以实现很多功能,例如今天要介...

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

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

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

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

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

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

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

我们在文章输入框中经常有用到字数控制,但字数控制有两种方案,一种是字母/空...

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

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

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

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

3 717
推荐插件
帝国cms百度AI图像无损放大api接口对接插件
帝国cms百度AI图像无损放大api接口对接插件

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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