仿得微博字符限制效果


呃。貌似好久沒有寫日志了。。最近忙的天天想發飆。。。今天得空備份一下項目中用到的小技巧等等吧。。看到過的大神請忽略。。我就是個前端小貓而已~~~

公司項目中有個這樣的東西,大家用微博的都明白哈~~

 

這是初始狀態

 

輸入文字變成這樣,這里會區分圓角半角,2個半角的文字算一個。

 

這個是超出的樣子

 

如果超出了點擊提交,會有紅色閃動提示

 

好了,效果就是這樣子,都是js的。。用的話,記得加個jq文件過來。。

這里是超出只有提示,還可以超出以后截掉多余的。。不過公司項目不用,說是體驗不好~~~

var oH2 = $("#spetit_word");//提示文字
var oTextarea = $("#p_qa_content");//輸入框
var oButton = $("#bt-ico");//按鈕
oTextarea.live("keyup", function () {
        Limit(oTextarea, 280, oH2);
})
oButton.live("click", function () {
        if (font_count < 0 || font_count == null || font_count == 140) {
            Error(oTextarea);
        } else {           
            alert('發布成功!');
        }
});
var font_count;

function WordLength(obj) {
        var oVal = obj.val();
        var oValLength = 0;
        oVal.replace(/\n*\s*/, '') == '' ? oValLength = 0 : oValLength = oVal.match(/[^ -~]/g) == null ? oVal.length : oVal.length + oVal.match(/[^ -~]/g).length;
        return oValLength
}
function Error(obj) {
        var oTimer = null;
        var i = 0;
        oTimer = setInterval(function () {
            i++;
            i == 5 ? clearInterval(oTimer) : (i % 2 == 0 ? obj.css("background-color", "#ffffff") : obj.css("background-color", "#ffd4d4"));
        }, 100);
}
//obj-要檢查的輸入框, iNow-多少字, tit-提示框
function Limit(obj, iNow, tit) {
        var oValLength = WordLength(obj);
        font_count = Math.floor((iNow - oValLength) / 2);
        if (font_count >= 0) {
            tit.html("你還可以輸入<strong>" + font_count + "</strong>字");
            return true;
        } else {
            tit.html("已超出<strong style='color:red'>" + Math.abs(font_count) + "</strong>字");
            return false;
        }
        return font_count;
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM