0

textarea値をサニタイズするようにpasteイベントを設定しました。すべての行の最初と最後の空白を削除することを除いて、必要なことはすべて実行されています。何か案は?

$('#q').bind('paste',function(e) {
    $.doTimeout(100,function(){
        $('#q').val($('#q').val().replace(/[@#$%\^&*=_+"'\/<>\\\|{}\[\]]/g,function(str){return '';})); //remove unwanted characters
        $('#q').val($('#q').val().replace(/[\t ]+/g,' ')); //remove extra spaces and tabs between letters 
        $('#q').val($('#q').val().replace(/\n{1,}/g,'\n\n')); //remove extra lines
        //here i need to remove white spaces at the beginning or end of each line
    });
});

ps:テキストが利用可能になる前にpasteイベントが発生するため、 benalmanのdoTimeoutプラグインを使用しています。

4

1 に答える 1

1

このようなもの?http://jsfiddle.net/Tentonaxe/ptGS5/

$('#q').bind('paste',function(e) {
    setTimeout(function(){
        var baseStr = $('#q').val();
        baseStr = baseStr.replace(/[@#$%\^&*=_+"'\/<>\\\|{}\[\]]/g,"");
        baseStr = baseStr.replace(/[\t ]+/g,' ');
        baseStr = baseStr.replace(/\n{1,}/g,'\n\n');
        lineArr = baseStr.split(/\n/);
        for (var i=0;i<lineArr.length;i++) {
            lineArr[i] = lineArr[i].replace(/(^ +| +$)/g,"");   
        }
        baseStr = lineArr.join("\n")
        $("#q").val(baseStr);
    },100);
});

doTimeoutプラグインをjsfiddleにコピーするよりも、setTimeoutを使用する方が簡単でした。

于 2011-12-13T19:15:04.653 に答える