我已设置粘贴事件以清理textarea值。它已经完成了我需要的一切,除了一件事:在所有线的开头和结尾修剪空白。有什么想法吗?
$('#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:我使用ben alman的doTimeout plugin因为粘贴事件在文本可用之前被触发。
答案 0 :(得分: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);
});
使用setTimeout比将doTimeout插件复制到jsfiddle更容易。