检测文本区域内的标记符号
Detect markup symbols inside textarea
我在页面上有一个文本区域。并决定验证此元素。我插入简单的文本,并在js中检查这个元素的长度。但当我删除所有文本时,我可以毫无问题地保存。我在firebug和文本区看到
<ul></ul><br/>
}
//js
for(var i=0; length > i; i++){
value = textElements[i].value;
if(value == "" ||(value == "<br/>" && element.tagName == "TEXTAREA")){
full = false;
emptyElements.push(elements[i]);
} else {
empty = false;
elements[i].style.borderColor = "";
elements[i].style.border = "";
}
}
广告HTML
<br /><div id="edit-contentFrame-form:editor" style="visibility:hidden"><textarea id="edit-contentFrame-form:editor_input" name="edit-contentFrame-form:editor_input"><h3></h3><h3></h3><h3><br/></h3><ul>
</ul></textarea></div>
我试图找到现有的方法来解决这个问题。但什么也找不到。
///EDITED
function isEmptyTextArea(){
var str = document.getElementById('edit-contentFrame-form:editor_input').value;
var regexp = new RegExp("(<+['w]+>+)*", "g");
var matches_array_tags = str.replace(regexp, '');
if(matches_array_tags.length == 0){
return true;
}
return false;
}
如果您不希望人们能够输入html,那么您可以使用regex来替换并删除文本区域中的所有"标记符号"标记。
var txtarea = document.getElementById('txtarea');
if(escape(txtarea.value) === '')
// textarea is empty
不包括空白:
if(escape(txtarea.value.trim()) === '')
// textarea is empty (not including whitespaces)
我用下一个js函数解决了问题
function isCompleteTagContent(str){
var re= /<'S[^><]*>/g;
var matches_array_tags = str.replace(re, "");
if(matches_array_tags.trim().length == 0){
return true;
}
return false;
}
相关文章:
- jquery仅限<并且>文本框中的符号
- Javascript:Unicode符号选择器(用于将数学符号添加到文本区域)
- 链接内的内容可编辑块,如何防止重定向,但让文本选择插入符号位置更改
- 如何更改文本区域中闪烁的光标/插入符号
- 如何使用RegEx转换文本中的表情符号
- 单击时获取文本区域中插入符号的位置
- Javascript:在所见即所得编辑器中的插入符号处粘贴文本
- 使用功能更改文本并包含项目符号图像
- 写任何文本后无法插入表情符号
- 使用省略号截断文本,使插入符号始终位于末尾
- 具有搜索文本的功能,不能很好地处理标点符号/符号.Jquery/Jquery mobile.
- 将插入符号移动到焦点上文本区域的末尾
- 如何在我的php注释框中实时替换带有表情符号的文本
- 如何在用户写入文本和按空格后替换表情符号
- 根据插入符号的位置从文本区域中提取整个单词
- 正则表达式 - 从文本输入中删除美元符号
- 如何格式化 html 结构中特定符号内换行的文本并设置其格式
- 如何在文本区域中模拟人工插入符号
- ASP.NET 如果文本在“大于”和“小于”符号之间给出,则无法保存文本框
- 是否可以在不轮询的情况下观看文本区域中的插入符号位置