我有一个包含两个公式的页面。每个人都有自己的输入等形式。他们都在键盘上调用相同的Javascript函数。
只有第一个有效,我有点理解为什么但是我找不到解决方案,我对Javascript太新了解如何解决这个问题。我无法更改JS文件的结构,因为其他页面上的其他公式依赖于此设置。
有解决方法吗?
缩短HTML:
<div id="formula">
<p>To find ρ<sub>b</sub>:</p>
<form id="formula" name="formula">
<input type="hidden" id="formulaName" name="formulaName" value="porosityRhob"/>
<div>
<label>$\rho_{fl}$:</label>
<input type ="text" name="input" id="input" onkeyup="calculatePEFormula()"/>
</div>
<div>
<label>Result:</label>
<input type="text" id="result" name="result">
</div>
</form>
</div>
<br/>
<div id="formula">
<p>To find Φ:</p>
<form id="formula" name="formula">
<input type="hidden" id="formulaName" name="formulaName" value="porosityPhi"/>
<div>
<label>$\rho_{ma}$:</label>
<input type ="text" name="input" id="input" onkeyup="calculatePEFormula()"/>
</div>
<div>
<label>Result:</label>
<input type="text" id="result" name="result">
</div>
</form>
</div>
THE JS:
function PEFormula(result, formulaName){
this.result = result;
this.formulaName = formulaName;
}
function calculatePEFormula(){
var PEObject = new PEFormula($("#result"), $("#formulaName"));
var formulaName = $("#formulaName").val();
switch(formulaName){
case "porosityRhob" : PEObject.porosityRhoB();
break;
case "porosityPhi" : PEObject.porosityPhi();
break;
}
PEFormula.prototype.porosityPhi = function(){
var input = parseFloat($("#input").val());
//logic
return r;
}
答案 0 :(得分:1)
HTML属性id应该是唯一的
<div id="formula">
<form id="formula" name="formula">
<input type="hidden" id="formulaName" name="formulaName" value="porosityRhob"/>
<input type ="text" name="input" id="input" onkeyup="calculatePEFormula()"/>
<input type="text" id="result" name="result">
尝试更改这些ID而不是使用类
以下是解决方案将所有字段ID更改为类,并且表单ID应该不同,并将表单的参数ID作为参数onkeyup="calculatePEFormula('form#formula1')"
和onkeyup="calculatePEFormula('form#formula2')"
传递给js
function PEFormula(result, formulaName){
this.result = result;
this.formulaName = formulaName;
}
function calculatePEFormula(form_id){
var PEObject = new PEFormula($(form_id+" .result"), $(form_id+" .formulaName"));
var formulaName = $(form_id+" .formulaName").val();
switch(formulaName){
case "porosityRhob" : PEObject.porosityRhoB();
break;
case "porosityPhi" : PEObject.porosityPhi();
break;
}
PEFormula.prototype.porosityPhi = function(){
var input = parseFloat($(form_id+" .input").val()); //provide the form id here
//logic
return r;
}
答案 1 :(得分:0)
当您使用课程时,您正在使用ID。
答案 2 :(得分:0)
您需要避免为多个元素分配相同的id
属性。元素的ID应该是唯一的。
答案 3 :(得分:0)
永远不要对多个元素使用相同的ID。这是HTML中的基本概念。标识应该是唯一且相同的。因此,任何HTML页面内都不能有任何重复的ID。所以请更改第二种形式的ID
<div id="formula2">
<p>To find Φ:</p>
<form id="formula2" name="formula">
<input type="hidden" id="formulaName2" name="formulaName" value="porosityPhi"/>
<div>
<label>$\rho_{ma}$:</label>
<input type ="text" name="input" id="input2" onkeyup="calculatePEFormula()"/>
</div>
<div>
<label>Result:</label>
<input type="text" id="result2" name="result">
</div>
</form>
</div>
调用相同的js函数时,相应地更改ID。
我通过在每个ID的末尾添加2来重命名所有ID。使每个ID都是唯一的。