停止光标,直到在javascript中的textarea中更改文本
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了停止光标,直到在javascript中的textarea中更改文本相关的知识,希望对你有一定的参考价值。
试图允许用户键入textarea,但如果看到某个单词,我希望光标停止,直到该单词被删除。
我找到了这个词,但我找不到让光标停止的方法。
关于如何在javascript中执行此操作的任何想法
$(function() {
$('#ideacomment').bind('keyup', function(e){
var characterLimit = 300;
charactersUsed = $(this).val().length;
if(charactersUsed > characterLimit){
charactersUsed = characterLimit;
$(this).val($(this).val().substr(0, characterLimit));
$(this).scrollTop($(this)[0].scrollHeight);
}
var charactersRemaining = characterLimit - charactersUsed;
$('#remainingCharacters').html(charactersRemaining);
var words = $('#ideacomment').val().split(/[s,.-:;]*/);
var wordcount = words.length;
var nonewords = new Array("f**k", "you");
var nonewordcount = nonewords.length;
//console.log(nonewordcount + ' is the count');
for(var i = 0; i < wordcount; i++) {
for(var t = 0; t < nonewordcount; t++) {
if(words[i] == nonewords[t]) {
message('No swearing please! <br><br> This post will not succeed!<br><br> Please remove it before you continue!', '430');
}
}
}
});
});
上面的代码计算字符数并检查每个字。我是否愿意并且我尝试过没有成功就好像它已经用完了空间。但我一直无法使用限制器相同的代码实现它?
这是新代码。仍然没有工作:
$(function() {
$('#ideacomment').bind('keyup', function(e){
var characterLimit = 300;
charactersUsed = $(this).val().length;
if(charactersUsed > characterLimit){
charactersUsed = characterLimit;
$(this).val($(this).val().substr(0, characterLimit));
$(this).scrollTop($(this)[0].scrollHeight);
}
var charactersRemaining = characterLimit - charactersUsed;
$('#remainingCharacters').html(charactersRemaining);
var nonewords = new Array("hey", "you");
var nonewordcount = nonewords.length;
for(var t = 0; t < nonewordcount; t++) {
if ($(this).val().indexOf(nonewords[t]) != -1) {
message('No swearing please! <br><br> This post will not succeed!<br><br> Please remove it before you continue!', '430');
var keycode = e.charCode || e.keyCode;
console.log(keycode);
if (keycode !== 8 && keycode !== 46)
return false;
}
}
});
});
答案
您可以检查正在按下哪个键,如果它不是Backspace或Delete,则阻止它。这是一个简化的例子:
$(function() {
$('#textbox').keydown(function(e) {
if ($(this).val().indexOf('test') != -1) {
var keycode = e.charCode || e.keyCode;
if (keycode !== 8 && keycode !== 46)
return false;
}
});
});
由于您似乎已经有了文本检查和通知部分,所以您真正缺少的只是按键阻塞部分。
以上是关于停止光标,直到在javascript中的textarea中更改文本的主要内容,如果未能解决你的问题,请参考以下文章
使用jQuery动画远离光标时,停止“:悬停”元素保持其状态?
使用javascript按下开始按钮时,我应该如何突出显示textarea中的文本?
当光标位于屏幕的顶部或底部边缘时,如何使用 JQuery/Javascript 向下滚动页面?