[英]Javascript wrap text with tags bbcode?
反正有標簽包裝textarea文本嗎? 使用Javascript / jQuery的
B =大膽I =斜體U =下划線S =打擊
例如:
-+-+-+-+-
B I U S
-+-+-+-+-
<textarea>
Some text here
</textarea>
當我突出顯示“這里”,然后單擊粗體時,它將像這樣。
-+-+-+-+-
B I U S
-+-+-+-+-
<textarea>
Some text [b]here[/b]
</textarea>
希望我能找到解決方案,就是這樣。
這是解決方案
function wrapText(elementID, openTag, closeTag) {
var textArea = $('#' + elementID);
var len = textArea.val().length;
var start = textArea[0].selectionStart;
var end = textArea[0].selectionEnd;
var selectedText = textArea.val().substring(start, end);
var replacement = openTag + selectedText + closeTag;
textArea.val(textArea.val().substring(0, start) + replacement + textArea.val().substring(end, len));
}
使用率
console.log(parseBB('[b]hello [/b][u]world[/u]'));
console.log(parseBB(document.getElementById('textareaID').value));
console.log(parseBB($('#textareaID').val()));
測試用例
$('#output-container').html(parseBB($('#textareaID').val()));
..
function parseBB(string){
var _string = string.replace(/\n/g, '<br>'),
parseExp = new RegExp(/^(.*)\[(b|u|i|s)\]([A-Za-z0-9 ._-]+)\[\/[a-z]+\](.*)$/g);
(function run(){
if(parseExp.test(_string)){
_string = _string.replace(parseExp , '$1<$2>$3</$2>$4');
run();
}
})();
return _string;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.