5

問題:だから私は次のように値を警告しtextareaました:

var source = document.getElementById('source').value;
            alert(source);

ただし、の値はtextarea、ページの読み込み時と同じように警告されます。そして、の現在の値を警告したいと思いますtextarea。私も試してみました

$("form").submit(function(){

しかし、それも私を助けていません。では、どうすればこれを行うことができますか?

これは私のコードです。

<html>
    <head>
    <title>Perl WEB</title>
    <script type="text/javascript" src="http://code.guru99.com/Perl1/codemirror.js"></script>
    <link rel="stylesheet" href="http://code.guru99.com/Perl1/codemirror.css" type="text/css" media="screen" />
    <script src="http://code.jquery.com/jquery-1.10.2.min.js"></script>
    <script type="text/javascript" src="http://code.guru99.com/perl/perl.js"></script>
    <style>
    .CodeMirror {
    border: 1px solid #eee;
    }   
    .CodeMirror-scroll {
    height: auto;
    overflow-y: hidden;
    overflow-x: auto;
    }
</style>
<script>
$(document).ready(function(){
  $("form").submit(function(){
    alert("Submitted");
  });
});
</script>
<script type="text/javascript">

    function execute() {
            p5pkg.CORE.print = function(List__) {
                var i;
                for (i = 0; i < List__.length; i++) {
                  document.getElementById('print-result').value += p5str(List__[i])
                }
                return true;
            };
            p5pkg.CORE.warn = function(List__) {
                var i;
                List__.push("\n");
                for (i = 0; i < List__.length; i++) {
                    document.getElementById('log-result').value += p5str(List__[i]);
                }
                return true;
            };
            p5pkg["main"]["v_^O"] = "browser";
            p5pkg["main"]["Hash_INC"]["Perlito5/strict.pm"] = "Perlito5/strict.pm";
            p5pkg["main"]["Hash_INC"]["Perlito5/warnings.pm"] = "Perlito5/warnings.pm";

            var source = document.getElementById('source').value;
            alert(source);
            var pos = 0;
            var ast;
            var match;
            document.getElementById('log-result').value   = "";
        //  document.getElementById('js-result').value    = "";
            document.getElementById('print-result').value = "";
            try {
                // compile
                document.getElementById('log-result').value += "Compiling.\n";
                var start = new Date().getTime();
                var js_source = p5pkg["Perlito5"].compile_p5_to_js([source]);
                var end = new Date().getTime();
                var time = end - start;
                document.getElementById('log-result').value +=  "Compilation time: " + time + "ms\n";
        //      document.getElementById('js-result').value  += js_source + ";\n";

                // run
                start = new Date().getTime();
                eval(js_source);
                end = new Date().getTime();
                time = end - start;
                document.getElementById('log-result').value += "Running time: " + time + "ms\n";

                p5pkg.CORE.print(["\nDone.\n"]);
            }
            catch(err) {
                document.getElementById('log-result').value += "Error:\n";
                document.getElementById('log-result').value += err + "\n";
                document.getElementById('log-result').value += "Compilation aborted.\n";
                  }
        }
    </script>
    </head>
    <body>
    <form>
<textarea id="source" cols="70" rows="10">
say 'h';
</textarea>
    <div class="hint">This code is editable. Click Run to execute.</div>
    <input type="button" value="Run" onclick="execute()"/></br>
Output:</br>
    <textarea id="print-result" disabled="true" rows="10" cols="70"></textarea></br>
Log:</br>
    <textarea  id="log-result" disabled="true" cols="70"></textarea>
    <script>
      var editor = CodeMirror.fromTextArea(document.getElementById("source"), {
        lineNumbers: true,
        indentUnit: 4,
        indentWithTabs: true,
        enterMode: "keep",
        tabMode: "shift"
      });
    </script>
</form>
    </body>
</html>

では、の現在の値を取得するにはどうすればよいtextareaですか? みんな助けてください。

4

5 に答える 5

1

私は CodeMirror には詳しくありませんが、画面に正確に表示されているものは、#sourceもはやあなたのオリジナルではありません。代わりに、CodeMirror によって作成されたいくつかの要素があり、オリジナルtextareaは隠されています。

ドキュメントを見てみると、こんなのがありました。

var source = editor.doc.getValue();
alert(source);

editorまたは、メソッドを使用してオブジェクトを構築したため、読み取る前にfromTextArea()の値を更新できます。textarea

editor.save();
var source = document.getElementById('source').value;           
alert(source);

フォームの送信について Adam が言ったことにも注目してください。HTML に無効な</br>タグがあります。正しい形式は<br />です。

詳細については、 CodeMirror ユーザー マニュアルを参照してください。

于 2013-07-08T11:26:06.513 に答える
1

jQuery をロードしたら、次のように実行できます。

var content = $('#source').val();
alert(content);

もちろん、ページの読み込み時にそれを行うと、テキストエリアは空になります (または作成されません)。あなたが示唆しているように、フォーム送信時にそのコンテンツを抽出できます。

このコードは、クリックされたときにテキストエリアの内容を警告するボタンを作成します:

<button onclick="alert($('#source').val())">Click me</button>
于 2013-07-08T10:06:15.353 に答える
0

マウスがテキストエリアを離れたときに値を警告したい場合は、次のような入力に onblur="myFunction()" を追加してみてください: ")

<textarea id="source" cols="70" rows="10" onblur="myFunction()">
    say 'h';
</textarea>


<script type="text/javascript">
    function myFunction() {
        var source = document.getElementById('source').value;
        alert(source);
    }
</script>
于 2013-07-08T10:09:12.130 に答える
0

submit() 内で次のことを試してください

var textAreaVal = $("#print-result").val();
alert(textAreaVal);
于 2013-07-08T10:07:40.460 に答える
0

これは送信ボタンではないため、ボタンが押されてもフォームは送信されません。

これはフォームを送信せず、その内容を警告しません。

<input type="button" value="Run" onclick="execute()"/></br>

次のようなものをフォームに追加します。

<input type="submit" value="Submit">
于 2013-07-08T10:10:05.380 に答える