一个实用的小功能:输入字数限制【升级版】

    在我们写表单功能的时候,往往都会遇到一个输入字数问题,一般都是针对textarea标签所设置,这里就先上一张效果图:

技苑

这是本人原创的脚本写的,所以比较简单,还望勿怪!下面上代码:

首先,你要加载一个jQuery库,然后。。。

HTML:

<p>字数限制:</p>
<div style="...">
    <textarea name="" id="content" style="..."></textarea>
    <span id="limit" style="...">最多能输入<b id="num">10/10</b>字</span>
</div>

刚发现用jQuery实现有俩种方法。。。

方法一:超出字数自动删减

/**
 * 字数限制,针对页面中所有的textarea输入框
 */
$('textarea').keyup(function(){
    inputLimit($(this));
});
$('textarea').keydown(function(){
    inputLimit($(this));
});
inputLimit($('textarea'));//初始化
function inputLimit(obj){
    var limit = 10;
    var num = obj.val().length;
    var rest = limit-num;
    if (rest>=0) obj.parent().find('span').text(rest+'/'+limit);
    if (rest<-1) obj.val(obj.val().substr(0,limit));
}

方法二:达到指定字数不可输入(注:此方法对中文输入无效)

$('textarea').keypress(function(){
	var limit = 10;
	var flag = $(this).val().length;
	rest = limit-flag-1;
	if(rest<0){
		return false;
	}
	$('#num').text(rest);
});

OK,代码分享完毕!效果就是上面那张图,当达到指定字数后,再输入任何内容就都会自动消失。 如果有什么不足之处,还请留言指出!3Q~

你可以通过 JavaScript 监听输入框的输入事件,然后获取输入框中的文本内容,再通过字符串的 `length` 属性获取当前输入的字符数,以此判断是否超出限制。如果超出限制,可以通过 `substring()` 方法截取字符串并更新输入框的内容,或者给出提示信息。以下是一个简单的示例代码: ```html <div contenteditable="true" id="input-box"></div> <div id="counter"></div> <script> const maxLength = 10; // 最大字符数 const inputBox = document.getElementById('input-box'); const counter = document.getElementById('counter'); inputBox.addEventListener('input', function() { const text = inputBox.innerText; const length = text.length; if (length > maxLength) { inputBox.innerText = text.substring(0, maxLength); counter.innerText = `已输入 ${maxLength} / ${maxLength} 个字符`; } else { counter.innerText = `已输入 ${length} / ${maxLength} 个字符`; } }); </script> ``` 在上面的示例中,我们首先定义了一个 `maxLength` 变量表示最大字符数,然后通过 `document.getElementById()` 方法获取输入框和计数器的元素对象。接着,我们给输入框添加了一个 `input` 事件监听器,每次输入框的内容发生变化时,就会触发该事件。在事件处理函数中,我们首先获取输入框中的文本内容,然后计算字符数并进行判断。如果超出了最大字符数,就使用 `substring()` 方法截取字符串并更新输入框的内容,同时显示计数器的文本为已输入的字符数与最大字符数。否则,就只显示已输入的字符数与最大字符数。 这只是一个简单的实现方式,你可以根据实际需求进行修改和优化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值