您实际上不能“保护”文本区域的一部分。当光标位于{...}
模式内时,您可以天真地尝试阻止输入按键,但是还有很多其他方法可以编辑它,例如。选择范围然后删除/替换、剪切/复制/粘贴、拖放...
最好简单地监视 textarea 的值,并在值出现错误时在其下方显示警告,例如:
<textarea id="mail_text">...</textarea>
<div id="mail_text_warning"></div>
<script type="text/javascript">
function checkMailText() {
var tokens= ['username', 'recipient', 'salutation'];
var value= $('#mail_text').val();
var problems= [];
$.each(tokens, function() {
if (value.split('{'+this+'}').length!==2)
problems.push('Please ensure there is one and only one {'+this+'} token present in the text');
});
matches= value.match(/\{[^\}]*\}/g);
if (matches!==null) {
$.each(matches, function() {
for (var i= tokens.length; i-->0;)
if ('{'+tokens[i]+'}'===this)
return;
problems.push('Token '+this+' is not known');
});
}
$('#mail_text_warning').text(problems.join('. '));
}
setInterval(checkMailText, 500);
</script>