2017-08-30 54 views
0

我之前問過,但我得到的答案沒有解決問題。我正在嘗試在輸出textarea上顯示至少有兩個輸入文本的頁面。我希望他們互相獨立運作。我試圖給每個人一個單獨的ID以及給輸出測試區域分開的ID。但仍然沒有工作。請幫忙。2種形式的頁面,單獨的輸出衝突

<form name="Form1" onsubmit="return false;" action=""> 
<b><font color="#2C3E60">Name:</font></b><br> 
<input type="text" name="name" id="name" placeholder="Name"><br> 
<b><font color="#2C3E60">Phone number:</font></b><br> 
<input type="text" name="phone" id="phone" placeholder="Phone number"><br> 
<b><font color="#2C3E60">Yes/No?:</font></b> <br> 
<select type="drop" name="Question1" id="question1"> 
<option value="Select Yes or No">...</option> 
<option value="Yes">Yes</option> 
<option value="No">No</option> 
</select> 
<br> 
<b><font color="#2C3E60">Yes/No 2?:</font></b><br> 
<select type="drop" name="Question2" id="question2"> 
<option value="Select Yes, No or n/a">...</option> 
<option value="Yes">Yes</option> 
<option value="No">No</option> 
<option value="n/a">n/a</option> 
</select> 
<br> 
<b><font color="#2C3E60">Notes:</font></b><br> 
<textarea type="textarea" name="Notes" id="notes" placeholder="Problem" cols="70" rows="3"></textarea> 
<br> 
<b><font color="#2C3E60">Issue:</font></b><br> 
<textarea type="textarea" name="Issue" id="issue" placeholder="Issue" cols="70" rows="6"></textarea>  
<br> 
<b><font color="#2C3E60">Action:</font></b><br> 
<textarea type="textarea" name="Action" id="action" placeholder="Action" cols="70" rows="10"></textarea> 
<br> 
<textarea type="textarea" name="form1output" onclick="this.focus();this.select()" id="output" cols="70"  rows="25" placeholder="Output"></textarea> 
<br> 
<div class="btn-group"> 
<button value="Combine" onclick="convert()">Combine</button> <br><br> 
</div>  
<div class="btn-group"> 
<button type="reset" value="Reset form">Reset form</button> <br><br> 
</div> 

</form> 

<hr> 

<form name="Form2" onsubmit="return false;" action=""> 
<b><font color="#2C3E60">Name:</font></b><br> 
<input type="text" name="Name2" id="name2" placeholder="Name"><br> 
<b><font color="#2C3E60">Phone Number:</font></b><br> 
<input type="text" name="Currentnumber" id="currentnumber" placeholder="Corrent phone number"><br> 
<b><font color="#2C3E60">Y or N:</font></b> <br> 
<select type="drop" name="YESNO" id="yesno"> 
<option value="Select Yes or No">...</option> 
<option value="Yes">Yes</option> 
<option value="No">No</option> 
</select> 
<br> 
<b><font color="#2C3E60">Did you offer self serve?:</font></b><br> 
<select type="drop" name="Selfserve" id="SSO"> 
<option value="Select Yes, No or n/a">...</option> 
<option value="Yes">Yes</option> 
<option value="No">No</option> 
<option value="n/a">n/a</option> 
</select> 
<br> 
<b><font color="#2C3E60">Problem:</font></b><br> 
<textarea type="textarea" name="Problem" id="problem" placeholder="Problem" 
cols="70" rows="3">    </textarea> 
<br> 
<b><font color="#2C3E60">Issue:</font></b><br> 
<textarea type="textarea" name="Issue" id="issue2" placeholder="Issue" 
cols="70" rows="6">     </textarea>  
<br> 
<b><font color="#2C3E60">Action:</font></b><br> 
<textarea type="textarea" name="Action" id="action2" placeholder="Action" 
cols="70" rows="10">  </textarea> 
<br> 
<textarea type="textarea" name="form2output" id="output2" 
onclick="this.focus();this.select()"     cols="70" rows="25" 
placeholder="Output"></textarea> 
<br> 
<div class="btn-group"> 
<button value="Combine" onclick="convert()">Combine</button> <br><br> 
</div> 
<div class="btn-group"> 
<button type="reset" value="Reset form">Reset form</button> <br><br> 
</div> 
</form> 

第一個腳本:

<script> 
/*Reset command*/ 
$(document).ready(function(){ 
$(":reset").css("background-color", ""); 
}); 
</script> 
<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 phone = document.getElementById("phone").value; 
var question1 = document.getElementById("question1").value; 
var question2 = document.getElementById("question2").value; 
var notes = document.getElementById("notes").value; 
var issue = document.getElementById("issue").value; 
var action = document.getElementById("action").value; 
//input = wordwrap(input, 70, true); 

var output = ""; 

output += "Name: " + name + "\n"; 
output += "Number: " + phone + "\n"; 
output += "Question 1?: " + question1 + "\n"; 
output += "Question 2?: " + question2 + "\n\n"; 
output += "Notes: " + notes + "\n\n"; 
output += "Issue: " + issue + "\n\n"; 
output += "Action: " + action + " "; 


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


function myFunction(x) { 
x.classList.toggle("change"); 
} 
</script> 

而第二個腳本:

<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 Name2 = document.getElementById(name2").value; 
var Currentnumber = document.getElementById("currentnumber").value; 
var YESNO = document.getElementById("yesno").value; 
var selfserve = document.getElementById("SSO").value; 
var problem = document.getElementById("problem").value; 
var issue2 = document.getElementById("issue2").value; 
var action2 = document.getElementById("action2").value; 
//input = wordwrap(input, 70, true); 

var output = ""; 

output += "Name2: " + name2 + "\n"; 
output += "Current number: " + currentnumber + "\n"; 
output += "Yes No?: " + yesno + "\n"; 
output += "Self Serve?: " + selfserve + "\n\n"; 
output += "Problem: " + problem + "\n\n"; 
output += "Issue: " + issue2 + "\n\n"; 
output += "Action: " + action2 + " "; 


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

function myFunction(x) { 
x.classList.toggle("change"); 
} 

</script> 

我缺少什麼?

回答

0

最終,問題是您有兩個腳本共享具有相同名稱的功能。但是充分發揮jQuery的潛力,你可以簡化你的邏輯。

(1)爲方便起見,添加一個idtype="button"到您的按鈕:id是在短期內差異化的按鈕和type="button"是爲了防止從表單默認提交。

<button type="button" id="combine1">Combine</button> 

<button type="button" id="combine2">Combine</button> 

(2)附加一個onclick事件處理程序到您的按鈕

$('#combine1').click(function() { 
    // get current form 
    var button = $(this), 
     form = button.closest('form'); 
    // get field values within current form 
    var name = form.find("[name=name]").val(), 
     phone = form.find("[name=phone]").val(), 
     question1 = form.find("[name=question1]").val(), 
     question2 = form.find("[name=question2]").val(), 
     notes = form.find("[name=notes]").val(), 
     issue = form.find("[name=issue]").val(), 
     action = form.find("[name=action]").val(); 

    var output = ""; 
     output += "Name: " + name + "\n"; 
     output += "Number: " + phone + "\n"; 
     output += "Question 1?: " + question1 + "\n"; 
     output += "Question 2?: " + question2 + "\n\n"; 
     output += "Notes: " + notes + "\n\n"; 
     output += "Issue: " + issue + "\n\n"; 
     output += "Action: " + action + " "; 

    form.find("[name=output]").val(output); 
}); 

// same idea as previous one 
$('#combine2').click(function() { 
    var button = $(this), 
     form = button.closest('form'); 

    var name = form.find("[name=name]").val(), 
     phone = form.find("[name=phone]").val(), 
     yesno = form.find("[name=yesno]").val(), 
     selfserve = form.find("[name=selfserve]").val(), 
     problem = form.find("[name=problem]").val(), 
     issue = form.find("[name=issue]").val(), 
     action = form.find("[name=action]").val(); 

    var output = ""; 
     output += "Name: " + name + "\n"; 
     output += "Phone: " + phone + "\n"; 
     output += "Yes No?: " + yesno + "\n"; 
     output += "Self Serve?: " + selfserve + "\n\n"; 
     output += "Problem: " + problem + "\n\n"; 
     output += "Issue: " + issue + "\n\n"; 
     output += "Action: " + action + " "; 

    form.find("[name=output]").val(output); 
}); 

其他說明

document.getElementById()是使用jQuery已經過時了,只需使用$(selector)selector例如有許多變化。 #id.class[name=name]

此外,還可以添加selector context找到一個元件即$("[name=name]", form).val()其是相同form.find("[name=name]").val()內的元件。

爲了便於說明,我刪除了表單中的ID,並且有些字段在這兩種表單中共享相同的名稱。我不同的領域是通過使用選擇器上下文。

演示

$(function() { 
 
    $('#combine1').click(function() { 
 
    console.clear(); 
 
    console.log(this.id); 
 
    
 
    var button = $(this), 
 
     form = button.closest('form'); 
 
     
 
    var name = form.find("[name=name]").val(), 
 
     phone = form.find("[name=phone]").val(), 
 
     question1 = form.find("[name=question1]").val(), 
 
     question2 = form.find("[name=question2]").val(), 
 
     notes = form.find("[name=notes]").val(), 
 
     issue = form.find("[name=issue]").val(), 
 
     action = form.find("[name=action]").val(); 
 

 
    var output = ""; 
 
    output += "Name: " + name + "\n"; 
 
    output += "Number: " + phone + "\n"; 
 
    output += "Question 1?: " + question1 + "\n"; 
 
    output += "Question 2?: " + question2 + "\n\n"; 
 
    output += "Notes: " + notes + "\n\n"; 
 
    output += "Issue: " + issue + "\n\n"; 
 
    output += "Action: " + action + " "; 
 

 
    form.find("[name=output]").val(output); 
 
    }); 
 

 

 
    $('#combine2').click(function() { 
 
    console.clear(); 
 
    console.log(this.id); 
 
    
 
    var button = $(this), 
 
     form = button.closest('form'); 
 

 
    var name = form.find("[name=name]").val(), 
 
     phone = form.find("[name=phone]").val(), 
 
     yesno = form.find("[name=yesno]").val(), 
 
     selfserve = form.find("[name=selfserve]").val(), 
 
     problem = form.find("[name=problem]").val(), 
 
     issue = form.find("[name=issue]").val(), 
 
     action = form.find("[name=action]").val(); 
 

 
    var output = ""; 
 
    output += "Name: " + name + "\n"; 
 
    output += "Phone: " + phone + "\n"; 
 
    output += "Yes No?: " + yesno + "\n"; 
 
    output += "Self Serve?: " + selfserve + "\n\n"; 
 
    output += "Problem: " + problem + "\n\n"; 
 
    output += "Issue: " + issue + "\n\n"; 
 
    output += "Action: " + action + " "; 
 

 
    form.find("[name=output]").val(output); 
 
    }); 
 

 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<!-- FORM 1 --> 
 
<form name="Form1" action=""> 
 
    <b><font color="#2C3E60">Name:</font></b><br> 
 
    <input type="text" name="name" placeholder="Name"><br> 
 
    <b><font color="#2C3E60">Phone number:</font></b><br> 
 
    <input type="text" name="phone" placeholder="Phone number"><br> 
 
    <b><font color="#2C3E60">Yes/No?:</font></b> <br> 
 
    <select type="drop" name="question1"> 
 
     <option value="Select Yes or No">...</option> 
 
     <option value="Yes">Yes</option> 
 
     <option value="No">No</option> 
 
    </select> 
 
    <br> 
 
    <b><font color="#2C3E60">Yes/No 2?:</font></b><br> 
 
    <select type="drop" name="question2"> 
 
     <option value="Select Yes, No or n/a">...</option> 
 
     <option value="Yes">Yes</option> 
 
     <option value="No">No</option> 
 
     <option value="n/a">n/a</option> 
 
    </select> 
 
    <br> 
 
    <b><font color="#2C3E60">Notes:</font></b><br> 
 
    <textarea type="textarea" name="notes" placeholder="Problem" cols="70" rows="3"></textarea> 
 
    <br> 
 
    <b><font color="#2C3E60">Issue:</font></b><br> 
 
    <textarea type="textarea" name="issue" placeholder="Issue" cols="70" rows="6"></textarea> 
 
    <br> 
 
    <b><font color="#2C3E60">Action:</font></b><br> 
 
    <textarea type="textarea" name="action" placeholder="Action" cols="70" rows="10"></textarea> 
 
    <br> 
 
    <textarea type="textarea" name="output" onclick="this.focus();this.select()" cols="70" rows="25" placeholder="Output"></textarea> 
 
    <br> 
 
    <div class="btn-group"> 
 
    <button type="button" id="combine1">Combine</button> <br><br> 
 
    </div> 
 
    <div class="btn-group"> 
 
    <button type="reset" value="Reset form">Reset form</button> <br><br> 
 
    </div> 
 
</form> 
 

 
<hr> 
 

 
<!-- FORM 2 --> 
 
<form name="Form2" action=""> 
 
    <b><font color="#2C3E60">Name:</font></b><br> 
 
    <input type="text" name="name" placeholder="Name"><br> 
 
    <b><font color="#2C3E60">Phone Number:</font></b><br> 
 
    <input type="text" name="phone" placeholder="Corrent phone number"><br> 
 
    <b><font color="#2C3E60">Y or N:</font></b> <br> 
 
    <select name="yesno"> 
 
     <option value="Select Yes or No">...</option> 
 
     <option value="Yes">Yes</option> 
 
     <option value="No">No</option> 
 
    </select> 
 
    <br> 
 
    <b><font color="#2C3E60">Did you offer self serve?:</font></b><br> 
 
    <select name="selfserve"> 
 
     <option value="Select Yes, No or n/a">...</option> 
 
     <option value="Yes">Yes</option> 
 
     <option value="No">No</option> 
 
     <option value="n/a">n/a</option> 
 
    </select> 
 
    <br> 
 
    <b><font color="#2C3E60">Problem:</font></b><br> 
 
    <textarea type="textarea" name="problem" placeholder="Problem" cols="70" rows="3">    </textarea> 
 
    <br> 
 
    <b><font color="#2C3E60">Issue:</font></b><br> 
 
    <textarea type="textarea" name="issue" placeholder="Issue" cols="70" rows="6">     </textarea> 
 
    <br> 
 
    <b><font color="#2C3E60">Action:</font></b><br> 
 
    <textarea type="textarea" name="action" placeholder="Action" cols="70" rows="10">  </textarea> 
 
    <br> 
 
    <textarea type="textarea" name="output" onclick="this.focus();this.select()" cols="70" rows="25" placeholder="Output"></textarea> 
 
    <br> 
 
    <div class="btn-group"> 
 
    <button type="button" id="combine2">Combine</button> <br><br> 
 
    </div> 
 
    <div class="btn-group"> 
 
    <button type="reset" value="Reset form">Reset form</button> <br><br> 
 
    </div> 
 
</form>

+0

哇,真棒。我承認我不明白這一切。這樣的JQuery。但我有興趣瞭解更多。你的例子完美無缺。謝謝。 –

+0

@TyH你會很快得到它的訣竅。請標記爲已回答。 – Mikey

+0

此外,我應該說,我需要這一切從一個頁面內工作,沒有提到另一個頁面,這似乎。有沒有可以在同一頁面內使用的解決方案? –