如何将字符串拆分为几个html文本字段

时间:2013-08-03 05:10:42

标签: javascript string-split

我在html文件中有2个输入字段,text1和text2。然后我复制一个长字符串并将其粘贴到text1中。我希望字符串自动分为text1和text2。因此字符串中必须有一个分隔符,例如TAB(ASCII 9)。我一直在尝试很多次,但没有幸运。在我的实验中,有一个按钮调用javascript函数如下:

<script>
function Chr(AsciiNum)
{
return String.fromCharCode(AsciiNum)

}

function test()
{ 
  c = "ABC"+Chr(9)+"DEF";
  document.getElementById("text1").value=c;
}

</script>

<input type="button" value="Paste it" onClick="test()">

我想要的是text1填充ABC和text2填充“DEF”

感谢您的帮助......

2 个答案:

答案 0 :(得分:1)

分裂很简单:

function test(pastedText) { 
  var parts = pastedText.split(Chr(9));

  document.getElementById("text1").value = parts[0];
  document.getElementById("text2").value =
                                        (parts[1] === undefined ? "" : parts[1]);
}

棘手的部分,实际上是粘贴,请查看下面的完整代码。

See a online DEMO for code here

Text1: <input type="text" id="text1"><br />
Text2: <input type="text" id="text2"><br />
<br />
<div>Sample string (copy the red text and paste it on Text1):</div>
<div style="color:red">ABC  DEF</div>

<script>
    function Chr(AsciiNum) {
      return String.fromCharCode(AsciiNum)
    }

    function test(pastedText) { 
      var parts = pastedText.split(Chr(9));

      document.getElementById("text1").value = parts[0];
      document.getElementById("text2").value = (parts[1] === undefined ?
                                                              "" : parts[1]);
    }

    /** HANDLING PASTE EVENT
     *  Credits to: http://stackoverflow.com/a/6035265/1850609 */
    function handlePaste(e) { 
      var pastedText = undefined;
      if (window.clipboardData && window.clipboardData.getData) { // IE
        pastedText = window.clipboardData.getData('Text');
      } else if (e.clipboardData && e.clipboardData.getData) {
        pastedText = e.clipboardData.getData('text/plain');
      }
      test(pastedText); // Process and handle text...
      return false; // Prevent the default handler from running.
    };
    document.getElementById("text1").onpaste = handlePaste;
</script>

我还建议您将test()函数重命名为对您更有意义的内容。

答案 1 :(得分:0)

为什么你不这样做:

 c = "ABC "+Chr(9);
 document.getElementById("text1").value=c;
 document.getElementById("text2").value= "DEF";

这应该在test()

希望这有帮助。