gpt4 book ai didi

javascript - "object HTMLTextAreaElement"与表单输出一起出现

转载 作者:搜寻专家 更新时间:2023-10-31 08:51:07 28 4
gpt4 key购买 nike

我正在处理一个表单,我在其中添加了第二个输出字段,在第二个字段中,它具有不同的格式,我已经在我的代码中放置了一个示例。现在我已经部分工作了,但是突然出现了两个问题。

  1. 首先,它首先在输出字段中返回 [object HTMLTextAreaElement] 响应,然后放置我想要的输出。我不明白为什么它总是先添加 [object HTMLTextAreaElement]。

  2. 其次,我第一次使用表单时,除了 [object HTMLTextAreaElement],它确实有效。然而,当我使用我的“重置”按钮时,它实际上似乎并没有“清除”第一个字段的输出,因为它似乎记住了上一次输入的任何内容,尽管它被重置了。我确实需要第二个输出字段按其编码执行,除非不返回在重置之前输入的信息。我希望这是有道理的。

  3. 最后,有没有什么办法可以让一个按钮将结果输出到两个输出框?如果我必须使用两个按钮,那还不算世界末日,但如果我能将它们合二为一,那就太好了。正如我目前设置的那样,我知道我先从第一个输出中获取输入的文本,然后再将其转换为第二个输出。所以也许这不是一个 super 简单的修复。

另外,请不要修复 JQuery,只修复 javascript 和 HTML。我想要单个页面上的所有代码。请有人帮忙,我已经坚持了几个小时,但我尝试修复它的任何方法都没有奏效。

这是我的 HTML

<table width="100%" height="700" border=0>
<tr>
<td width=550 valign=top>

<form name="Form1" onsubmit="return false;" action="">
Name:
<br>
<input type="text" name="Name" id="name" placeholder="Name"><br>
Number:
<br>
<input type="text" name="Number" id="number" placeholder="Number"><br>
Question:
<br>
<input type="text" name="Question1" id="questionOne" placeholder="Answer">
<br>
Question:
<br>
<select type="drop" name="Question2" id="questionTwo">
<option value="Select Yes or No">...</option>
<option value="Yes">Yes</option>
<option value="No">No</option>
</select><br>
Enter some text?
<br>
<textarea type="textarea" name="Sometext" id="someText" placeholder="Type
something"
cols="70" rows="3"></textarea><br>

Question:
<br>

<select type="drop" name="Question3" id="questionThree">
<option value="Select Yes or No">...</option>
<option value="Yes">Yes</option>
<option value="No">No</option></select>


<br>
Question:
<br>

<select type="drop" name="Question4" id="questionFour">
<option value="Select Yes or No">...</option>
<option value="Yes">Yes</option>
<option value="No">No</option></select>
<br>

Enter more text:<br>
<textarea type="textarea" name="Story" id="story" placeholder="Type me a
story"
cols="70" rows="10"></textarea>
<br>

</td>
<td valign="top">

<table border=0 height=100% ><tr><td valign="top" height=410>

<textarea type="textarea" name="output" onclick="this.focus();this.select()"
id="output" cols="70" rows="25" placeholder="Name:
Number:
Answer:
Answer:&#x0a;
Some text:&#x0a;
Answer:&#x0a;
Answer:&#x0a
A little story:"></textarea>
<br>

</td>
</tr>
<tr>
<td valign=top>

<div class="btn-group">
<button value="Combine" onclick="convert()" id="combine1">
Combine
</button><br><br>
</div>




<textarea type="textarea" id="secondOutput" name="output"
onclick="this.focus();this.select()" cols="70" rows="15" placeholder="Three
Lines
Down
Name:
Number:
Answer:
Answer:
Some text:
Answer:
Answer:
A little story:"></textarea>


<div class="btn-group">
<button value="Combine" onclick="NoteStart()" id="combine1">
Second copy
</button><br><br>
</div>

</td>
</tr>
<tr>
<td align="right">

<table width=25% height=100% border=0>
<tr>
<td valign="bottom">

<div class="btn-group">
<button type="reset" value="Reset form">
Reset form
</button> <br><br>
</div>

</form></div>

</td>
</tr>
</table>
</td>
</tr>
</table>
</td>
</tr>
</table>

是的,我知道,表格,抱歉...

和脚本

<script>
function wordwrap(str, width, brk, cut) {
brk = brk || '\n';
width = width || 60;
cut = cut || false;

if (!str)
return str;

var regex = '.{1,' +width+ '}(\\s|$)' + (cut ? '|.{' +width+ '}|.+$' :
'|\\S+?(\\s|$)');
return str.match( RegExp(regex, 'g') ).join(brk);
}



function convert() {
var name = document.getElementById("name").value;
var number = document.getElementById("number").value;
var questionOne = document.getElementById("questionOne").value;
var questionTwo = document.getElementById("questionTwo").value;
var someText = document.getElementById("someText").value;
var questionThree = document.getElementById("questionThree").value;
var questionFour = document.getElementById("questionFour").value;
var story = document.getElementById("story").value;


var output = "";
output += "Name: " + name + "\n";
output += "Number: " + number + "\n";
output += "Answer: " + questionOne + "\n";
output += "Answer: " + questionTwo + "\n\n";
output += "Some text: " + someText + "\n\n";
output += "Answer: " + questionThree + "\n\n";
output += "Answer: " + questionFour + "\n\n";
output += "A little story: " + story + "";


document.getElementById("output").value = output;
}

</script>

<script>

function NoteStart() {
var input = document.getElementById("output").value;
input = input.replace(/\r/g, '').replace(/\n\n+/g, '\n');
input = wordwrap(input, 60, '\n', true);

var data = input.replace(/[ \n\t\r]+$/g, '').split(/\n+/);

var StartNS = "";

for (var i=0; i<data.length; i++) {
if (i%10==0) {
if (i>0)
output += "\n";

output += "Three\nLines\nDown\n";
}

output += data[i]+"\n";
}

output += (data.length%10>0) ? "\n\n" : "\n";

document.getElementById("secondOutput").value = output;
}
</script>

正如我所说,一段时间以来我一直在尝试自己解决这个问题,但在这里遇到了困难。感谢任何帮助。在这里,我在这里做了一个 jsfiddle https://jsfiddle.net/s8qhezmx/这样任何人都可以看到什么有效

最佳答案

在你的function NoteStart()var output = "";

function NoteStart() {
var output = "";

// stuff
}

output您在此声明之前引用的变量是 output包含 <textarea id="output"> 的 HTMLElement 对象的全局对象这就是为什么你得到 [object HTMLTextAreaElement]做的时候 output += //stuff在导致您出现问题的循环中。

希望对你有帮助

更新:

the reason why there are global variables that are named with an elements ID and contains the JavaScript object reference of the element

关于javascript - "object HTMLTextAreaElement"与表单输出一起出现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46020341/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com