- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个数量数组,我想在这个数组中找到一个数字。因此,如果用户输入 16,该函数将在索引 6 和 7 之间返回,因为 16 大于 15 但小于 20。
从更广泛的 Angular 来看,该索引将用于查找所需数量的价格范围。
编辑
HTML 标记
<table cellpadding="0" cellspacing="0" border="0">
<tbody><tr>
<th scope="row">Quantity</th>
<th id="js-QuantityID-0" scope="col">0</th>
<th id="js-QuantityID-1" scope="col">1</th>
<th id="js-QuantityID-2" scope="col">2</th>
<th id="js-QuantityID-3" scope="col">3</th>
<th id="js-QuantityID-4" scope="col">4</th>
<th id="js-QuantityID-5" scope="col">5</th>
<th id="js-QuantityID-6" scope="col">10</th>
<th id="js-QuantityID-7" scope="col">15</th>
<th id="js-QuantityID-8" scope="col">20</th>
<th id="js-QuantityID-9" scope="col">30</th>
<th id="js-QuantityID-10" scope="col">40</th>
<th id="js-QuantityID-11" scope="col">50</th>
<th id="js-QuantityID-12" scope="col">60</th>
</tr>
<tr>
<th scope="row">Price (inc. VAT)</th>
<td id="js-PriceID-0">0.00</td>
<td id="js-PriceID-1">45.60</td>
<td id="js-PriceID-2">38.40</td>
<td id="js-PriceID-3">32.40</td>
<td id="js-PriceID-4">34.56</td>
<td id="js-PriceID-5">30.72</td>
<td id="js-PriceID-6">26.80</td>
<td id="js-PriceID-7">21.60</td>
<td id="js-PriceID-8">20.60</td>
<td id="js-PriceID-9">17.60</td>
<td id="js-PriceID-10">16.60</td>
<td id="js-PriceID-11">15.60</td>
<td id="js-PriceID-12">14.00</td>
</tr>
</tbody>
</table>
工作脚本
function getTableContents() {
var productArray = [];
jQuery("th[id^='js-QuantityID-']").each(function () {
var n = jQuery(this).attr("id").replace('js-QuantityID-', ''); // get the number from the id
productArray.push({
qty: parseInt(jQuery(this).text()),
price: parseFloat(jQuery('#js-PriceID-' + n).text().replace('£',''))
});
});
return productArray = cleanArray(productArray);
}
回答
问题是由于将数量作为字符串获取,在解析为整数时这解决了我的问题@Michael Geary
最佳答案
在您的示例中设置具有匹配元素的并行数组(例如 price
和 quantity
数组)通常不是一个好主意。这很容易出错,并且很难直观地匹配价格与数量。
相反,您应该使用单个数组,其中每个数组元素都是一个组合了数量级别和价格的对象:
var priceBands = [
{ qty: 1, price: '£45.60' },
{ qty: 2, price: '£38.40' },
{ qty: 3, price: '£32.40' },
{ qty: 4, price: '£32.10' },
{ qty: 5, price: '£34.56' },
{ qty: 10, price: '£30.72' },
{ qty: 15, price: '£26.80' },
{ qty: 20, price: '£21.60' },
{ qty: 30, price: '£21.00' },
{ qty: 40, price: '£21.00' }
];
现在很容易看出哪个价格对应哪个数量,并且两个数组中的元素数量相同是毫无疑问的。
(顺便说一句,我很好奇为什么 5 件商品的价格上涨!)
如果该符号看起来太乏味,您可以轻松地简化它:
var priceBands = makePriceBands([
' 1: £45.60',
' 2: £38.40',
' 3: £32.40',
' 4: £32.10',
' 5: £34.56',
'10: £30.72',
'15: £26.80',
'20: £21.60',
'30: £21.00',
'40: £21.00',
]);
这会生成与前面列出的对象相同的数组,使用此函数转换更简洁的表示法:
function makePriceBands( bandsIn ) {
var bands = [];
for( var i = 0; i < bandsIn.length; ++i ) {
var band = bandsIn[i].split(/: */));
bands.push({ qty: +band[0], price: band[1] });
}
return bands;
}
对于现代浏览器,你可以写得更简单一点:
function makePriceBands( bands ) {
return bands.map( function( b ) {
var band = b.split(/: */));
return { qty: +band[0], price: band[1] };
});
}
但第一个版本可以在任何旧浏览器上运行。
无论哪种方式,找到合适价格的代码都很简单。向后遍历数组,直到到达输入数量大于或等于数组元素中数量的元素。
我们将使它成为一个需要 prices
数组作为参数的函数,因此您可以通过传入不同的数组来将它用于不同的产品。
此外,您没有在问题中指定当输入数量等于其中一个价格水平数量时要做什么,所以我假设,例如,如果您有10 个或更多,您获得数量 10 的价格水平。(换句话说,您不必购买 11 个以获得数量 10 的价格。)
function priceForQuantity( prices, n ) {
for( var i = prices.length - 1; i >= 0; --i ) {
if( n >= prices[i].qty ) {
return prices[i].price;
}
}
return '£0.00';
}
或者您可以向前走遍数组,但我发现向后走更容易思考这个特定问题。
您可以使用一些示例数量来测试此代码,确保测试比特定数量水平大一和小一的边界条件:
function test( n ) {
console.log( n, priceForQuantity( priceBands, n ) );
}
test( 0 );
test( 1 );
test( 3 );
test( 5 );
test( 6 );
test( 9 );
test( 10 );
test( 39 );
test( 40 );
test( 41 );
这将记录:
0 "£0.00"
1 "£45.60"
3 "£32.40"
5 "£34.56"
6 "£34.56"
9 "£34.56"
10 "£30.72"
39 "£21.00"
40 "£21.00"
41 "£21.00"
关于javascript - 在数组范围内查找索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31119416/
我有三个 td,并且正在尝试将每个内部的函数限制为仅该 td。我该怎么做呢?使用此代码,它会获取所有 3 个图像并将它们全部插入到 h2 之前: jQuery("td.frontpage_news")
这是所需的通用公式:if((b2-b1)=c1,True,False但是,我需要 b2-b1约等于 c1 , 在 5 内大约单位(在本例中为秒)。有没有可以处理这个的函数? 最佳答案 你也可以试试这个
我有三个整数,作为命令行参数传入后赋值给变量。我想验证每个整数都在 1-5 范围内。有没有一种方法可以在不使用如下所示的 if 语句的情况下在 Java 中完成此操作?我想避免这样做(注意伪代码):
检查某个变量 X 是否在某个变量 Z 的 n 个数字之内的最简洁方法是什么。n 是任意定义的数字(即 3)。 所以我想要 if (z {something} x){ // run code i
我的顶级 build.gradle (Gradle 2.2) 中有类似的东西 ext.repo = "https://my-artifactory-repo" buildscript { re
我只是在我的 jsp 页面中进行随机技巧和测试。我想使用 Attributes 将 request 范围对象存储在 session 范围对象中。存储后,当尝试从请求属性中提取值(存储在 session
我正在使用 Spring 。我有一个外部化属性文件。我正在按如下方式加载它。 现在我如何将 session 中的属性作为键值对保存? 我尝试编写一个扩展 ServletContextListene
我有以下范围: scope :billable, -> (range_start = nil, range_end = nil) { joins(:bids) .where("au
请看我的示例代码: var testObject = new SomeClass(); using (testObject) { //At this point how can the te
我目前在保持在 vector 范围内时遇到一些问题。 在下面的代码中,我试图检查正在检查的数字是否小于或等于它后面的数字 #include #include #include bool fun(
有人可以帮我解决下面的(简化的)代码吗?我试图从幻灯片事件函数中调用 doTheSlide() 函数。我对 JS 范围的理解仍然有点可疑。 实现这一目标的正确方法是什么?我收到此错误: Uncaugh
如何在 Swift 中检查时间是否在下午 6 点到晚上 11 点之间?我在使用 NSDateFormatter 时遇到了困难,我觉得一定有更简单的方法。 最佳答案 使用NSCalendar: let
我目前正在尝试创建一个 2D 横向滚动条,并且我目前有我的“世界”绘图(暂时是一个大白框),但我无法弄清楚世界地图的边缘与边缘之间的任何关系确保视口(viewport)始终完全被 map 覆盖。 我的
我正在学习李普曼,而且我只是在学习。我在这里尝试编写一个代码,该代码将返回 vector 中的最小元素。当我在 Codeblocks 中编译我的代码时,它说:“模板声明不能出现在 block 范围内”
我有三个日期对象。我该如何比较它们才能确定它们之间的相对差异。 oldDate = newDate() - 5; midDate = newDate() - 2.5; newDate = newDat
我需要检查对象“objCR”是否存在于当前范围内。我尝试使用以下代码。 if(objCR == null) alert("object is not defined"); 让我知道哪里错了。 最佳答案
如何检查 IP 地址是否属于私有(private)类别? if(isPrivateIPAddress(ipAddress)) { //do something } 如有
我正在开发一个 Firefox 插件,它可以转换用户通过用户选择突出显示的屏幕温度。转换后,用户选择将替换为 ID 为 alreadyconverted 的 span HTML 元素,其中包含原始温度
我正在开发一个邮资应用程序,该应用程序需要根据多个邮政编码范围检查整数邮政编码,并根据邮政编码匹配的范围返回不同的代码。 每个代码都有多个邮政编码范围。例如,如果邮政编码在 1000-2429、254
我正在使用 excel 范围进行连接:Set rng = Range("A1:A8")如果范围内的单元格之一为空,则会添加一个空格。 你如何阻止这个空间被添加? 最佳答案 假设您在那些非空单元格中有常
我是一名优秀的程序员,十分优秀!