我在 WordPress 自定义 HTML 上遇到 NaN 错误

I am facing he NaN error on WordPress Custom HTML

提问人:Umer Rashid 提问时间:11/17/2023 最后编辑:tacoshyUmer Rashid 更新时间:11/17/2023 访问量:37

问:

当我在代码编辑器中执行代码时,我的代码有问题,它工作正常,但是当在 WordPress 中执行代码时,代码运行不佳,它给出了 NaN 错误。

代码在 W3School 代码编辑器上工作正常

code is working fine on w3school code editor

当它在WordPress上运行代码时,它会给出以下错误:

when it is run code on WordPress is gives the following error I'm pasting the code as Custom HTML

function calculateBill() {
  const units = parseFloat(document.getElementById('units').value);
  const lessThan200 = document.getElementById('lessThan200').checked;

  // Rates
  const perUnit = 50;
  const fcSurcharge = 0.43;
  const electricityDuty = 0.20;
  const tvFee = 35;
  const gst = 2.40;
  const njSurcharge = 0.1;

  let totalBill = (perUnit + fcSurcharge + electricityDuty + gst + njSurcharge) * units + tvFee;
  if (lessThan200 && units <= 200) {
    totalBill *= 0.5; // Assuming 50% discount if less than 200 units for the last 6 months
  }

  const tableBody = document.getElementById('tableBody');
  tableBody.innerHTML = `
                <tr>
                    <td>Cost of electricity (${units} x ${perUnit})</td>
                    <td>${(units * perUnit).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>F.C Surcharge</td>
                    <td>${(fcSurcharge * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>Electricity Duty</td>
                    <td>${(electricityDuty * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>TV Fee</td>
                    <td>${tvFee.toFixed(2)}</td>
                </tr>
                <tr>
                    <td>GST</td>
                    <td>${(gst * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>N.J Surcharge</td>
                    <td>${(njSurcharge * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <th>Total Estimated Bill</th>
                    <th>${totalBill.toFixed(2)}</th>
                </tr>
            `;
}
body {
  font-family: Arial, sans-serif;
  padding: 20px;
  background-color: #f2f2f2;
}

.calculator {
  background-color: #fff;
  max-width: 100%;
  width: 450px;
  padding: 20px;
  border-radius: 8px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
  margin: 50px auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
}

th,
td {
  border: 1px solid #ddd;
  padding: 8px;
  text-align: left;
}

th {
  background-color: #f2f2f2;
}

button {
  padding: 10px 15px;
  background-color: #4CAF50;
  color: #fff;
  border: none;
  cursor: pointer;
  border-radius: 5px;
  width: 100%;
}
<div>
  <label for="units">Enter Units:</label>
  <input type="number" id="units" placeholder="E.g. 200">
  <br>
  <label>
            <input type="checkbox" id="lessThan200"> I am consuming 200 or less units for the last 6 months?
        </label>
  <br><br>
  <button onclick="calculateBill()">Calculate</button>

  <table>
    <tbody id="tableBody">
      <!-- Rows will be added here dynamically -->
    </tbody>
  </table>
</div>

javascript html css nan

评论

0赞 Chris G 11/17/2023
出于某种原因,您的输入正在接受字母,即使 tho 是一个输入数字e
2赞 tacoshy 11/17/2023
@ChrisG 是数字的有效字母:下面的等值将告诉后面有多少个数字,这在处理大数字时很有帮助。e1e31,000e
2赞 Charlie Schliesser 11/17/2023
您的代码有效。如果您没有在“输入单位”字段中输入值,然后单击按钮运行 ,您将获得“NaN”输出。您确定在计算之前输入了一个值吗?calculateBill()
0赞 Chris G 11/17/2023
是的,但是与任何其他数字一起插入或仅插入 e,您将在结果中只得到 NaNe

答:

0赞 tacoshy 11/17/2023 #1

正如@CharlieSchliesser在评论中指出的那样,如果输入为空,则可能会发生错误。解决此问题的最简单方法是检查输入的数字实际上是数字还是 NaN。您可以使用该函数来执行此操作。然后,如果值是数字,则只需将逻辑反转为true:isNAN(units)!isNaN()

function calculateBill() {
  const units = parseFloat(document.getElementById('units').value);
  if (!isNaN(units)) {
    const lessThan200 = document.getElementById('lessThan200').checked;

    // Rates
    const perUnit = 50;
    const fcSurcharge = 0.43;
    const electricityDuty = 0.20;
    const tvFee = 35;
    const gst = 2.40;
    const njSurcharge = 0.1;

    let totalBill = (perUnit + fcSurcharge + electricityDuty + gst + njSurcharge) * units + tvFee;
    if (lessThan200 && units <= 200) {
      totalBill *= 0.5; // Assuming 50% discount if less than 200 units for the last 6 months
    }

    const tableBody = document.getElementById('tableBody');
    tableBody.innerHTML = `
                <tr>
                    <td>Cost of electricity (${units} x ${perUnit})</td>
                    <td>${(units * perUnit).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>F.C Surcharge</td>
                    <td>${(fcSurcharge * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>Electricity Duty</td>
                    <td>${(electricityDuty * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>TV Fee</td>
                    <td>${tvFee.toFixed(2)}</td>
                </tr>
                <tr>
                    <td>GST</td>
                    <td>${(gst * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <td>N.J Surcharge</td>
                    <td>${(njSurcharge * units).toFixed(2)}</td>
                </tr>
                <tr>
                    <th>Total Estimated Bill</th>
                    <th>${totalBill.toFixed(2)}</th>
                </tr>
            `;
  } else {
    // an error message logic should be included here
  }
}
body {
  font-family: Arial, sans-serif;
  padding: 20px;
  background-color: #f2f2f2;
}

.calculator {
  background-color: #fff;
  max-width: 100%;
  width: 450px;
  padding: 20px;
  border-radius: 8px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
  margin: 50px auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
}

th,
td {
  border: 1px solid #ddd;
  padding: 8px;
  text-align: left;
}

th {
  background-color: #f2f2f2;
}

button {
  padding: 10px 15px;
  background-color: #4CAF50;
  color: #fff;
  border: none;
  cursor: pointer;
  border-radius: 5px;
  width: 100%;
}
<div>
  <label for="units">Enter Units:</label>
  <input type="number" id="units" placeholder="E.g. 200">
  <br>
  <label>
            <input type="checkbox" id="lessThan200"> I am consuming 200 or less units for the last 6 months?
        </label>
  <br><br>
  <button onclick="calculateBill()">Calculate</button>

  <table>
    <tbody id="tableBody">
      <!-- Rows will be added here dynamically -->
    </tbody>
  </table>
</div>