100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > jquery插件——仿新浪微博限制输入字数的textarea

jquery插件——仿新浪微博限制输入字数的textarea

时间:2019-06-08 17:01:56

相关推荐

jquery插件——仿新浪微博限制输入字数的textarea

【前言】

记录一款特效,以后讲课讲解下

【主体】

<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>jquery插件——仿新浪微博限制输入字数的textarea</title><script src="/libs/jquery/1.10.1/jquery.min.js"></script><style>*{padding: 0;margin: 0;}.box{width: 800px;margin: 0 auto;}#test{border:1px solid #d9d9d9; padding:0 1%;line-height: 1.8;font-family: "microsoft yahei";font-size: 14px;display: block; width: 98%; height: 80px;;}#info{padding: 3px 0;font-family: "microsoft yahei";font-size: 14px;}</style></head><body><div class="box"><textarea id="test" width="100%"></textarea></div><script>(function($) {$.fn.limitTextarea = function(opts) {var defaults = {maxNumber: 140, //允许输入的最大字数position: 'top', //提示文字的位置,top:文本框上方,bottom:文本框下方onOk: function() {}, //输入后,字数未超出时调用的函数onOver: function() {} //输入后,字数超出时调用的函数 }var option = $.extend(defaults, opts);this.each(function() {var _this = $(this);var info = '<div id="info"><b>' + (option.maxNumber - _this.val().length) + '</b>/'+option.maxNumber+'</div>';var fn = function() {var $info = $('#info');var extraNumber = option.maxNumber - _this.val().length;if (extraNumber >= 0) {$info.html('<b>' + extraNumber + '</b>/'+option.maxNumber);option.onOk();} else {$info.html('已经超出<b style="color:red;">' + (-extraNumber) + '</b>个字');option.onOver();}};switch (option.position) {case 'top':_this.before(info);break;case 'bottom':default:_this.after(info);}//绑定输入事件监听器if (window.addEventListener) { //先执行W3C_this.get(0).addEventListener("input", fn, false);} else {_this.get(0).attachEvent("onpropertychange", fn);}if (window.VBArray && window.addEventListener) { //IE9_this.get(0).attachEvent("onkeydown", function() {var key = window.event.keyCode;(key == 8 || key == 46) && fn(); //处理回退与删除});_this.get(0).attachEvent("oncut", fn); //处理粘贴}});}})(jQuery)//插件调用;$(function() {$('#test').limitTextarea({maxNumber: 140, //最大字数position: 'bottom', //提示文字的位置,top:文本框上方,bottom:文本框下方onOk: function() {$('#test').css('background-color', 'white');}, //输入后,字数未超出时调用的函数onOver: function() {$('#test').css('background-color', 'lightpink');} //输入后,字数超出时调用的函数,这里把文本区域的背景变为粉红色 });});</script></body></html>

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。