我在页面上有一个textarea。并决定验证此元素。我插入简单的文本,在js我检查这个元素的长度。但是当我删除所有文本时,我可以毫无问题地保存。我在firebug和textarea看到了
<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;
}
答案 0 :(得分:1)
如果您不希望人们输入html,您可以使用正则表达式替换并删除textarea中的所有“标记符号”标记。
答案 1 :(得分:1)
var txtarea = document.getElementById('txtarea');
if(escape(txtarea.value) === '')
// textarea is empty
不包括空格:
if(escape(txtarea.value.trim()) === '')
// textarea is empty (not including whitespaces)
答案 2 :(得分:0)
我用下一个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;
}