限制字符输入数功能(jQ版和原生JS版)

比较常用的限制字符输入数功能(比如热火超天的微博输入框),用jQuery和原生JavaScript分别写了一个.原生JavaScript注释中有区分中英文字符的函数, 但个人并不建议这么做.
已知BUG:
Ubuntu系统下, onkeyup事件失效,详见: Ubuntu系统下onkeyup/onkeydown对中文输入失效bug.
查看演示: 点此查看DEMO
核心代码:

//原生JavaScript版本
window.onload=function(){
    var js=document.getElementById('js');//获取文本域
    var info=document.getElementsByTagName('p')[0];//获取要插入提示信息的元素
    var submit=info.getElementsByTagName('input')[0];//获取提交按钮
    var max=js.getAttribute('maxlength');//获取限制输入的最大长度
    var tips=document.createElement('span');//新建一个提示span
    var val,cur,count,warn;
    submit.disabled=true;//默认不可提交
    tips.innerHTML='你还可以输入<em>'+max+'</em>个字符<font>[不区分中英文字符数]</font>';
    if(max){
        js.onkeyup=js.onchange=function(){
            submit.disabled=false;
            if(info.lastChild.nodeName!='SPAN') info.appendChild(tips);//避免每次弹起都会插入一条提示信息
            count=info.getElementsByTagName('em')[0];//根据输入数字变换区
            warn=info.getElementsByTagName('font')[0];//副标题
            val=this.value;
            cur=val.length;
//            for(var i=0;i<val.length; i++){//此循环是用来判断中英文字符的,但并不建议那样做
//                if(val.charCodeAt(i)>255) cur+=1;
//            }
            if(cur==0){ //当默认值长度为0时,可输入数为默认maxlength值,此时不可提交
                count.innerHTML = max;
                submit.disabled=true;
                warn.innerHTML='不区分中英文字符数';
            }else if (cur < max) {//当默认值小于限制数时,可输入数为max-cur
                count.innerHTML = max - cur;
                warn.innerHTML='不区分中英文字符数';
            }else{
                count.innerHTML = 0;//当默认值大于等于限制数时,插入一条提示信息并截取限制数内的值
                warn.innerHTML='不可再输入!';
                this.value=val.substring(0,max);//此处前面的this.value不能用变量val,它们不再是同一个值
            }
        }
    }
}
//基于jQuery版本
$(function(){
    var _area=$('textarea#jq');
    var _info=_area.next();
    var _submit=_info.find(':submit');
    var _max=_area.attr('maxlength');
    var _val,_cur,_count,_warn;
    _submit.attr('disabled',true);
    _area.bind('keyup change',function(){ //绑定keyup和change事件
        _submit.attr('disabled',false);
        if(_info.find('span').size()<1){//避免每次弹起都会插入一条提示信息
            _info.append('<span>你还可以输入<em>'+ _max +'</em>个字符<font>[不区分中英文字符数]</font></span>');
        }
        _val=$(this).val();
        _cur=_val.length;
        _count=_info.find('em');
        _warn=_info.find('font');
        
        if(_cur==0){//当默认值长度为0时,可输入数为默认maxlength值,此时不可提交
            _count.text(_max);
            _submit.attr('disabled',true);
        }else if(_cur<_max){//当默认值小于限制数时,可输入数为max-cur
            _count.text(_max-_cur);
            _warn.text('不区分中英文字符数');
        }else{//当默认值大于等于限制数时,插入一条提示信息并截取限制数内的值
            _count.text(0);
            _warn.text('不可再输入!');
            $(this).val(_val.substring(0,_max));
        }
    });
});

原文发布于Mr.Think的博客:  http://mrthink.net/js-jq-input-limit/

Tag标签: JavaScript,jQuery,表单限制,限制字数输入

转载于:https://www.cnblogs.com/philzhou/articles/1823164.html

限制字符输入数功能(jQ版和原生JS版)相关推荐

  1. php前台限制输入text字符,限制字符输入数功能(jquery版和原生JS版)

    比较常用的限制字符输入数功能(比如热火超天的微博输入框),用jquery和原生JavaScript分别写了一个.原生JavaScript注释中有区分中英文字符的函数, 但个人并不建议这么做. 已知BU ...

  2. Mars3D功能示例原生JS版下载运行

    首先建议您学习浏览一遍我们功能示例的源码(源码中会有大量注释),阅读源码时可以结合查阅API文档来理解类及方法的作用和参数说明等. #项目介绍 这是一个基于 原生JS 开发的 mars3d 示例项目. ...

  3. Mars3D项目模板:基础项目 原生JS版 (widget方式)介绍

    项目介绍 Mars3D基础项目 是基于Mars3D平台 做的一个应用系统,提供的一个基础项目模版,包含常用基础地图功能,可在该基础项目上快速开发搭建新项目.方便快速搭建三维地图产品,敏捷开发,可复用, ...

  4. html 写字版插件,原生JS+HTML5实现的可调节写字板功能示例

    本文实例讲述了原生JS+HTML5实现的可调节写字板功能.分享给大家供大家参考,具体如下: 本文实例讲述了原生JS+HTML5实现的可调节写字板功能.分享给大家供大家参考,具体如下: 前面一篇介绍了& ...

  5. AJAX初识(原生JS版AJAX和Jquery版AJAX)

    一.什么是JSON 1.介绍JSON独立于语言,是一种与语言无关的数据格式.JSON指的是JavaScript对象表示法(JavaScript Object Notation)JSON是轻量级的文本数 ...

  6. 原生JS和jQuery操作DOM的区别小结

    一.Js原生对象和jQuery实例对象的相互转化: (1).原生JS对象转JQ对象: $(DOM对象); (2). JQ对象转原生JS对象: $(DOM对象).get(index); //注意区分eq ...

  7. java循环购物车结算系统_原生JS实现购物车结算功能代码

    html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD ...

  8. jq实现跳转404跳转,原生js实现跳转404跳转

    2019独角兽企业重金招聘Python工程师标准>>> //jq实现跳转404跳转     <script>      function timeGo() {       ...

  9. js html转盘点名,原生JS实现简易随机点名功能

    定时器的工作原理,这里将用引用How JavaScript Timers Work中的例子来解释定时器的工作原理,该图为一个简单版的原理图.· 上图中,左侧数字代表时间,单位毫秒:左侧文字代表某一个操 ...

最新文章

  1. 可复现的图像降噪算法总结——超赞整理
  2. input 正则验证(摘)
  3. #ifndef 与 #program once 的区别
  4. 《Python程序设计(第3版)》[美] 约翰·策勒(John Zelle) 第 4 章 答案
  5. Python教程分享:Python Cookie HTTP获取cookie并处理
  6. c++STL(标准模板库)理论基础
  7. elasticsearch中文分词器ik-analyzer安装
  8. 小论文期刊投稿相关整理资料
  9. code point,code unit
  10. Java9都快发布了,Java8的十大新特性你了解多少呢?
  11. rails再体验(第一个程序)
  12. Reporting Services 2016中不推荐使用的5大功能
  13. int与string互转
  14. HA集群--corosync+pacemaker
  15. unity调用php,unity访问php
  16. Protues构建最小系统
  17. APP日志的抓取方法——转载
  18. VMware虚拟机ubuntu ros安装摄像头驱动
  19. Mongoose操作mongoDB的详细步骤
  20. React初尝试-仿写CNode社区

热门文章

  1. 1325208-25-0,Mal-PEG4-NHS马来酰亚胺基团和NHS酯基团交联剂
  2. 斯德哥尔摩的照片七:城市漫步(中)
  3. win10系统由于服务器出错翻译失败,win10系统下谷歌浏览器翻译失败怎么办
  4. 超图对接伟景行osg数据使用说明
  5. 微信小程序实现Tab选项卡(极简单版)
  6. 计算机程序漏洞用英语怎么说,漏洞用英语怎么说
  7. A NOVEL DEEP FEATURE FUSION NETWORK FOR REMOTE SENSING SCENE CLASSIFICATION(论文翻译)
  8. Vulkan的基本概念:如何使用Vulkan绘制三角形?
  9. 基于以太坊的区块链浏览器搭建
  10. maven 如何查询依赖 jar 包版本号