1

ページにテキストエリアがあります。そして、この要素を検証することを決定します。単純なテキストを挿入し、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("(&lt;+[\w]+&gt;+)*", "g");
                var matches_array_tags = str.replace(regexp, '');

                if(matches_array_tags.length == 0){
                    return true;
                }
                return false;
            }
4

3 に答える 3

1
var txtarea = document.getElementById('txtarea');
if(escape(txtarea.value) === '')
     // textarea is empty

空白を含まない:

if(escape(txtarea.value.trim()) === '')
     // textarea is empty (not including whitespaces)
于 2013-03-06T07:28:42.777 に答える
1

ユーザーがHTMLを入力できないようにする場合は、正規表現を使用して、テキストエリアからすべての「マークアップ記号」タグを置き換えて削除できます。

于 2013-03-06T07:28:28.950 に答える
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;
}
于 2013-03-06T13:49:00.423 に答える