基于jQuery的計算文本框字數(shù)的代碼
更新時間:2012年06月06日 00:00:14 作者:
用戶邊輸入計算同時進行,告訴用戶還剩余多少可輸入的字數(shù),當超過規(guī)定的字數(shù)后,點擊確定,會讓輸入框閃動
一、功能:
1.用戶邊輸入計算同時進行,告訴用戶還剩余多少可輸入的字數(shù);
2.當超過規(guī)定的字數(shù)后,點擊確定,會讓輸入框閃動
二、功能分析
1.重點是用什么事件?
標準瀏覽器用oninput,而IE則使用onpropertychange ,這兩個事件的發(fā)生條件,是文本框的值發(fā)生改變。
2.字數(shù)的計算。
2.1一個中文算兩個,一個符號或數(shù)字,英文,算一個。(如果是規(guī)定140個字,乘以2,那么就是280個)
2.2需要用到Math.ceil方法,因為最后還是要除以2來還原顯示給用戶的字數(shù);
3.閃動背景色
這里用到了模運算,因為是重復(fù)的動作,第一次有顏色,第二次沒有顏色,這樣重復(fù)的動作,就有閃動效果.
因為肉眼要看到這二次有顏色和無顏色的效果,所以需要用到延時,setTimeout和setInterval. 這里用到的是setInterval,因為要重復(fù)動作。
$(function(){
var $tex = $(".tex");
var $but = $(".but");
var ie = jQuery.support.htmlSerialize;
var str = 0;
var abcnum = 0;
var maxNum = 280;
var texts= 0;
var num = 0;
var sets = null;
$tex.val("");
//頂部的提示文字
$tex.focus(function(){
if($tex.val()==""){
$("p").html("您還可以輸入的字數(shù)<span>140</span>");
}
})
$tex.blur(function(){
if($tex.val() == ""){
$("p").html("請在下面輸入您的文字:");
}
})
//文本框字數(shù)計算和提示改變
if(ie){
$tex[0].oninput = changeNum;
}else{
$tex[0].onpropertychange = changeNum;
}
function changeNum(){
//漢字的個數(shù)
str = ($tex.val().replace(/\w/g,"")).length;
//非漢字的個數(shù)
abcnum = $tex.val().length-str;
total = str*2+abcnum;
if(str*2+abcnum<maxNum || str*2+abcnum == maxNum){
$but.removeClass()
$but.addClass("but");
texts =Math.ceil((maxNum - (str*2+abcnum))/2);
$("p").html("您還可以輸入的字數(shù)<span>"+texts+"</span>").children().css({"color":"blue"});
}else if(str*2+abcnum>maxNum){
$but.removeClass("")
$but.addClass("grey");
texts =Math.ceil(((str*2+abcnum)-maxNum)/2);
$("p").html("您輸入的字數(shù)超過了<span>"+texts+"</span>").children("span").css({"color":"red"});
}
}
//按鈕點擊
$but.click(function(){
if($(this).is(".grey")){
sets = setInterval(flash,100);
$tex.addClass("textColor")
}
function flash(){
num++;
if(num == 4){
clearInterval(sets);
}
if(num%2 == 1){
$tex.addClass("textColor")
}else{
$tex.removeClass("textColor")
}
}
})
})
1.用戶邊輸入計算同時進行,告訴用戶還剩余多少可輸入的字數(shù);
2.當超過規(guī)定的字數(shù)后,點擊確定,會讓輸入框閃動
二、功能分析
1.重點是用什么事件?
標準瀏覽器用oninput,而IE則使用onpropertychange ,這兩個事件的發(fā)生條件,是文本框的值發(fā)生改變。
2.字數(shù)的計算。
2.1一個中文算兩個,一個符號或數(shù)字,英文,算一個。(如果是規(guī)定140個字,乘以2,那么就是280個)
2.2需要用到Math.ceil方法,因為最后還是要除以2來還原顯示給用戶的字數(shù);
3.閃動背景色
這里用到了模運算,因為是重復(fù)的動作,第一次有顏色,第二次沒有顏色,這樣重復(fù)的動作,就有閃動效果.
因為肉眼要看到這二次有顏色和無顏色的效果,所以需要用到延時,setTimeout和setInterval. 這里用到的是setInterval,因為要重復(fù)動作。
感謝“妙味課堂”的視頻
在線演示:http://demo.jb51.net/js/2012/myinputCount/
打包下載:http://www.dbjr.com.cn/jiaoben/55149.html
復(fù)制代碼 代碼如下:
$(function(){
var $tex = $(".tex");
var $but = $(".but");
var ie = jQuery.support.htmlSerialize;
var str = 0;
var abcnum = 0;
var maxNum = 280;
var texts= 0;
var num = 0;
var sets = null;
$tex.val("");
//頂部的提示文字
$tex.focus(function(){
if($tex.val()==""){
$("p").html("您還可以輸入的字數(shù)<span>140</span>");
}
})
$tex.blur(function(){
if($tex.val() == ""){
$("p").html("請在下面輸入您的文字:");
}
})
//文本框字數(shù)計算和提示改變
if(ie){
$tex[0].oninput = changeNum;
}else{
$tex[0].onpropertychange = changeNum;
}
function changeNum(){
//漢字的個數(shù)
str = ($tex.val().replace(/\w/g,"")).length;
//非漢字的個數(shù)
abcnum = $tex.val().length-str;
total = str*2+abcnum;
if(str*2+abcnum<maxNum || str*2+abcnum == maxNum){
$but.removeClass()
$but.addClass("but");
texts =Math.ceil((maxNum - (str*2+abcnum))/2);
$("p").html("您還可以輸入的字數(shù)<span>"+texts+"</span>").children().css({"color":"blue"});
}else if(str*2+abcnum>maxNum){
$but.removeClass("")
$but.addClass("grey");
texts =Math.ceil(((str*2+abcnum)-maxNum)/2);
$("p").html("您輸入的字數(shù)超過了<span>"+texts+"</span>").children("span").css({"color":"red"});
}
}
//按鈕點擊
$but.click(function(){
if($(this).is(".grey")){
sets = setInterval(flash,100);
$tex.addClass("textColor")
}
function flash(){
num++;
if(num == 4){
clearInterval(sets);
}
if(num%2 == 1){
$tex.addClass("textColor")
}else{
$tex.removeClass("textColor")
}
}
})
})
您可能感興趣的文章:
- 基于HTML+CSS,jQuery編寫的簡易計算器后續(xù)(添加了鍵盤監(jiān)聽)
- 一個簡單的jQuery計算器實現(xiàn)了連續(xù)計算功能
- jquery精度計算代碼 jquery指定精確小數(shù)位
- jQuery實現(xiàn)根據(jù)生日計算年齡 星座 生肖
- jQuery實現(xiàn)購物車計算價格功能的方法
- jQuery實現(xiàn)購物車多物品數(shù)量的加減+總價計算
- jQuery計算textarea中文字數(shù)(剩余個數(shù))的小程序
- Jquery AJAX 用于計算點擊率(統(tǒng)計)
- js數(shù)值計算時使用parseInt進行數(shù)據(jù)類型轉(zhuǎn)換(jquery)
- jQuery實現(xiàn)的簡單在線計算器功能
相關(guān)文章
jQuery實現(xiàn)模擬flash頭像裁切上傳功能示例
這篇文章主要介紹了jQuery實現(xiàn)模擬flash頭像裁切上傳功能,結(jié)合實例形式分析了jQuery圖像剪切與文件傳輸相關(guān)操作技巧,需要的朋友可以參考下2016-12-12jQuery插件FusionCharts繪制的2D雙柱狀圖效果示例【附demo源碼】
這篇文章主要介紹了jQuery插件FusionCharts繪制的2D雙柱狀圖效果,結(jié)合實例形式分析了jQuery使用FusionCharts插件繪制2D雙柱狀圖的具體步驟與相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-05-05jQuery+.net實現(xiàn)瀏覽更多內(nèi)容(改編php版本)
改編自php版本這里記錄.net 下的實現(xiàn);首先創(chuàng)建數(shù)據(jù)庫表test,并插入一些測試數(shù)據(jù)接下來建立一個html文件,感興趣的朋友可以參考下哈,希望您可以幫助到你2013-03-03