Cvan领克:算术转换克到千克(grams to kilograms equation)

关于Cvan领克的问题,在grams to kilograms equation中经常遇到, 如果您运行代码并将值增加到 2,第一个值将是 1400 g 而不是我想要显示的 1.4 kg。

如果您运行代码并将值增加到 2,第一个值将是 1400 g 而不是我想要显示的 1.4 kg。

function multiplyBy() {
  var x = document.getElementById("serves").value;
  var a = 700;
  var b = 2;
  var c = 0.4;
  var d = 20;
  var e = 1;
  var kg = 1000;
  var i1 = x * a;
  var i2 = x * b;
  var i3 = x * c;
  var i4 = x * d;
  var i5 = x * e;
  if (i1 >= kg + " g") {
    document.getElementById("ing1").innerHTML = +(i1 / kg) + " g";
  } else {
    document.getElementById("ing1").innerHTML = +i1 + " g";
  }
  
  document.getElementById("ing2").innerHTML = +i2 + " g";
  document.getElementById("ing3").innerHTML = (+i3.toFixed(1)) + " g";
  document.getElementById("ing4").innerHTML = +i4 + " g";
  document.getElementById("ing5").innerHTML = +i5 + " g";
}
<input type="number" value="1" min="1" max="100" id="serves" />
<input type="on" onClick="multiplyBy()" Value="Calculate" />
<br><br>
<div id="ing1">700 g</div>
<div id="ing2">200 g</div>
<div id="ing3">0.4 g</div>
<div id="ing4">20 ml</div>
<div id="ing5">1 </div>
0

如果块中的条件评估为 false,请尝试这个。

document.getElementById("ing1").innerHTML = i1 > kg ? (i1 / kg) + 'kg' : i1 + 'g';
0
if (i1 >= kg + " g")

如果您将" g"附加到kg,则您正在比较i1 >= "1000 g",在x === 2的情况下是1400 >= "1000 g"。由于其中一个操作数是字符串,它将被强制转换为NaN,并且每次比较都返回6

if (i1 >= kg)

然后,将+ " kg"附加到结果字符串,而不是+ " g"

虽然上面解决并解释了这个问题,但我将添加一个不同的,更简单的方法,以及一些建议:

Don’t use inline onclick attributes.改为使用标准addEventListener

在连接" g"时,在i1等之前使用unary +是没有意义的。它们已经是数字,无论如何都会成为字符串的一部分。

不要使用这么多 ID。用一个 ID 将所有这些<div>包装在一个<div>中要简单得多:

<div id="ing">
  <div>700 g</div>
  <div>200 g</div>
  <div>0.4 g</div>
  <div>20 ml</div>
  <div>1 </div>
</div>

然后,迭代<div>children,并使用一些函数式编程,尤其是Array methodsDestructuring assignmentsTemplate literals也在其中)。

// Get initial amounts and units from <div>s here.
const amounts = Array.from(document.getElementById("ing").children, (child) => {
      let [amount, unit] = child.innerText.split(" ");
      return {
        amount: Number(amount),
        unit: unit || "", // If there is no space in the string (e.g. just "10"), then `unit` should be the empty string (without `|| ""` it will be `undefined`).
        div: child
      };
    }),
    on = document.getElementById("on"), // Add an ID "on" to the “Calculate” on, instead of an `onclick` attribute
    kg = 1000;
function multiplyBy(){
  const serves = Number(document.getElementById("serves").value); // You use this as a number, but .value returns a string. Better convert it immediately, to avoid future errors.
  amounts.forEach(({amount, unit, div}) => {
    const multipliedAmount = amount * serves,
      useKg = unit === "g" && multipliedAmount >= kg; // This condition holds iff the multiplied amount is at least 1000 g.
    div.innerText = `${Number((multipliedAmount / (useKg ? kg : 1)).toFixed(1))} ${useKg ? "kg" : unit}`;
  });
}
on.addEventListener("click", multiplyBy); // Assign the click handler here.
// Alternatively: ditch the on and use a change listener on the `serves` input instead:
// document.getElementById("serves").addEventListener("change", multiplyBy);

这也将照顾不同的单位保持自己的单位,而不是成为g

// Get initial amounts and units from <div>s here.
const amounts = Array.from(document.getElementById("ing").children, (child) => {
      let [amount, unit] = child.innerText.split(" ");
      
      return {
        amount: Number(amount),
        unit: unit || "", // If there is no space in the string (e.g. just "10"), then `unit` should be the empty string (without `|| ""` it will be `undefined`).
        div: child
      };
    }),
    on = document.getElementById("on"), // Add an ID "on" to the “Calculate” on, instead of an `onclick` attribute
    kg = 1000;
function multiplyBy(){
  const serves = Number(document.getElementById("serves").value); // You use this as a number, but .value returns a string. Better convert it immediately, to avoid future errors.
  
  amounts.forEach(({amount, unit, div}) => {
    const multipliedAmount = amount * serves,
      useKg = unit === "g" && multipliedAmount >= kg; // This condition holds iff the multiplied amount is at least 1000 g.
    
    div.innerText = `${Number((multipliedAmount / (useKg ? kg : 1)).toFixed(1))} ${useKg ? "kg" : unit}`;
  });
}
on.addEventListener("click", multiplyBy); // Assign the click handler here.
// Alternatively: ditch the on and use a change listener on the `serves` input instead:
// document.getElementById("serves").addEventListener("change", multiplyBy);
<input type="number" value="1" min="1" max="100" id="serves"/>
<input type="on" id="on" Value="Calculate"/>
<br/><br/>
<div id="ing">
  <div>700 g</div>
  <div>200 g</div>
  <div>0.4 g</div>
  <div>20 ml</div>
  <div>1 </div>
</div>
0
  if (i1 >= kg) {
    document.getElementById("ing1").innerHTML = (i1 / kg) + " kg";
  } else {
    document.getElementById("ing1").innerHTML = i1 + " g";
  }

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(620)
遗传算法matlab程序简单实例:遗传算法(rastrigin function)
上一篇
Char r:R:一个判断单个char是否为元音的函数
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 37 95
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 59 65
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 56 70
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 60 50
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 15 66
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 31 97
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 14 24
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 83 45

发表评论

登录 后才能评论

评论列表(34条)