【问题标题】:how can i retrieve a current value of textarea?如何检索 textarea 的当前值?
【发布时间】:2013-07-08 09:59:29
【问题描述】:

问题:所以我已经通过以下方式提醒了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 的当前值呢?请帮帮我。

【问题讨论】:

  • 将文本区域的值存储在一个变量中,然后提醒它。
  • 那么,您希望在什么时候显示该值?
  • 您必须稍后执行。例如作为对用户交互的响应,在用户更改值之后。 “如何”做到这一点取决于你到底想要什么。

标签: javascript html codemirror


【解决方案1】:

我不熟悉 CodeMirror,但您在屏幕上看到的完全不是您原来的 #source。取而代之的是CodeMirror创建了几个元素,原来的textarea被隐藏了。

当我查看文档时,我发现:

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

或者,由于您已经使用fromTextArea() 方法构造了editor 对象,您可以在阅读之前更新textarea 的值:

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

还请注意 Adam 所说的关于提交表单的内容。并且您的 HTML 中有无效的&lt;/br&gt; 标签,正确的格式是&lt;br /&gt;

请访问CodeMirror User Manual了解更多信息。

【讨论】:

    【解决方案2】:

    当您加载了 jQuery 后,您可以执行以下操作:

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

    当然,如果您在页面加载时执行此操作,则 textarea 将为空(甚至未创建)。您可以按照您的建议在表单提交时提取其内容。

    此代码将创建一个按钮,当您点击该按钮时会提醒您的文本区域的内容:

    <button onclick="alert($('#source').val())">Click me</button>
    

    【讨论】:

    • 这并不能真正回答问题。
    • 谁是赞成这个答案的小丑?警报的内容仍然是原始值,而不是用户输入的那个。
    • 我没有正确理解这个问题。 @Teemu 我赞成您的回答以使其上升,请随意反对我的回答。
    • @thibauts 好吧,这个问题措辞很糟糕......感谢您的支持。尽管菲利克斯的评论仍然有效,但我也不会拒绝您的回答:)。
    【解决方案3】:

    在 submit() 中尝试以下操作

    var textAreaVal = $("#print-result").val();
    alert(textAreaVal);
    

    【讨论】:

      【解决方案4】:

      当您按下其中的按钮时,您的表单不会被提交,因为这不是提交按钮。

      这不会提交表单,也不会提醒其内容。

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

      在表单中添加类似这样的内容:

      <input type="submit" value="Submit">
      

      【讨论】:

      • 虽然你是对的,但单击按钮会执行execute(),其中alert() 显示出意外的值。
      【解决方案5】:

      如果您希望在鼠标离开文本区域时提醒该值,您可以尝试将 onblur="myFunction()" 添加到输入中,例如:(实际上,如果您希望鼠标离开时,您可以添加 onmouseout=" 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>
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2013-07-05
        • 1970-01-01
        • 1970-01-01
        • 2012-02-20
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2013-12-11
        相关资源
        最近更新 更多