【发布时间】:2020-03-23 14:29:04
【问题描述】:
我已经构建了一个订单查询表单,其中包含一些 Javascript 驱动的功能。我可以在所有可以测试的浏览器上使用此表单,包括 Win 10 和一些 Mac 操作系统。我的客户仍在使用 Windows XP,他说这两个功能不起作用:
使用单选按钮选项提高商品价格
收集完所有内容后计算页面底部的小计 各种商品的价格和数量。
在我告诉他我不支持 XP 之前,我想知道我的脚本中是否存在已知在 Windows XP 上的 Firefox 中会失败的内容(希望有解决方法)。我在网上查了方法文档,没有看到。这是我正在使用的各种脚本。这些都是纯Javascript,只是看看我能不能做到。
每次商品数量变化时都会触发小计重新计算。
/************************************************
* Wide Option
************************************************/
function subtractWideOption() { // below traverse DOM from radio button to price
var priceSpan = event.target.parentNode.parentNode.nextElementSibling.firstElementChild;
if (priceSpan.className.indexOf("wider") !== -1) { // test if option is already set
var currentPrice = parseInt(priceSpan.innerHTML.slice(1), 10); // remove $ sign and parse
var newPrice = currentPrice - 25; // remove cost for option
priceSpan.innerHTML = "$" + newPrice; // add $ sign
priceSpan.className = priceSpan.className.replace(" wider",""); // remove option class
priceSpan.className += " std"; // add standard class
} else {
return;
}
}
function addWideOption() {
var priceSpan = event.target.parentNode.parentNode.nextElementSibling.firstElementChild;
if (priceSpan.className.indexOf("std") !== -1) {
var currentPrice = parseInt(priceSpan.innerHTML.slice(1), 10);
var newPrice = currentPrice + 25;
priceSpan.innerHTML = "$" + newPrice;
priceSpan.className = priceSpan.className.replace(" std","");
priceSpan.className += " wider";
} else {
return;
}
}
/************************************************
* Order Subtotal
************************************************/
var qtyBtns = document.getElementsByClassName("qty"); // collect all qty inputs
var subTotal = document.getElementById("oi_subt");
function recalcSubtotal() {
var subT = 0;
for (var i = 0; i < qtyBtns.length; i++) { // below traverse DOM from input to price
var priceHTML = qtyBtns[i].parentNode.previousElementSibling.firstElementChild.innerHTML;
if (priceHTML == "TBD") { // one custom item with TBD price is ignored
price = "0"
} else {
priceHTML = priceHTML.replace(",",""); // remove comma from price
var price = parseInt(priceHTML.slice(1), 10); // remove $ sign and parse
};
var qty = parseInt(qtyBtns[i].value, 10);
subT += (price * qty); // add up all items ordered
subTotal.innerHTML = "$" + subT;
}
}
【问题讨论】:
-
那里的脚本到底是什么失败了?错误是什么?
-
很遗憾,我对客户视图的访问权限有限。我不想过多地打扰他。他只是说他们不工作。我假设他没有收到错误消息。如果您有 XP 和 Firefox,这是我正在处理的表单的链接...greatgraphicdesign.com/work/bsp/order-inquiry.html
-
您检查过您在 caniuse 上的方法吗?喜欢:caniuse.com/#search=slice
-
许多不同版本的 Firefox 在 Windows XP(一个五年多来一直没有安全或任何其他更新的操作系统)上运行。准确找出所涉及的 Firefox 版本将是一个非常好的主意。
标签: javascript browser operating-system compatibility backwards-compatibility