gpt4 book ai didi

javascript - 在javascript中从数组返回一个值

转载 作者:行者123 更新时间:2023-12-04 09:37:15 25 4
gpt4 key购买 nike

希望您能提供帮助,我正在尝试构建一个具有不同加权答案分数的问卷。这个想法是,当按下提交按钮时,会返回一个百分比分数。
我找到了一个在线教程,它为我提供了我需要做的模板,在教程版本中检查数组的每个值并将预定值添加到分数中,在我的场景中,我希望从如果发现为真,则将数组添加到分数。
每个 radio 问答值都存储在一个数组中,

const auditCorrectAnswers = ['1', '20', '20', '20', '20', '20', '20', '20', '20', '20', '5', '5', '5', '10', '5', '5', '20', '20'];
当 if 语句为真时,我试图从 forEach() 相同位置的数组中提取值。循环正在检查。
我认为已经设法做到这一点,使用以下语句
userAuditAnswers.forEach((auditAnswer, index) => {
if(auditAnswer === auditCorrectAnswers[index]){

auditScore += (auditCorrectAnswers, index);

}
});

console.log(auditScore);
但将总索引位置值一起返回,因为它应该给出 256 的答案,但这是我得到的最接近的解决方案。
我试过 valueOf() , values()map()但这些都给出了数组中所有值的重复字符串。
我相信它很简单,但已经坚持了几天并且没有想法,所以任何帮助将不胜感激。
这是我的代码:
const auditCorrectAnswers = ['1', '20', '20', '20', '20', '20', '20', '20', '20', '20', '5', '5', '5', '10', '5', '5', '20', '20'];

const form = document.querySelector('.venueAudit-form');

form.addEventListener('submit', e => {
e.preventDefault();

let auditScore = 0;

//takes the value from each radio button
const userAuditAnswers = [form.a1.value, form.a2.value, form.a3.value, form.a4.value, form.a5.value, form.a6.value, form.a7.value, form.a8.value, form.a9.value, form.a10.value, form.a11.value, form.a12.value, form.a13.value, form.a14.value, form.a15.value, form.a16.value, form.a17.value, form.a18.value];

// checks management audit scores
userAuditAnswers.forEach((auditAnswer, index) => {
if(auditAnswer === auditCorrectAnswers[index]){

auditScore += (auditCorrectAnswers, index);
}
});

console.log(auditScore);
});
html部分
<form>            
<!-- Managers Office -->
<div class="light-blue lighten-5">
<div class="container p-t-2 p-l-2 p-r-2 p-b-20">
<h5>Managers Office</h5>
</div>

<div class="container p-t-2 p-l-2 p-r-2 p-b-5">
<p class="text2">Clean & Tidy</p>
<div>
<label>
<input class="with-gap" type="radio" name="a1" value="1" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a1" value="0"/><span>No</span>
</label>
</div>
<p class="text1">All files up to date</p>
<div>
<label>
<input class="with-gap" type="radio" name="a2" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a2" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Licensing folder complete & up-to-date</p>
<div>
<label>
<input class="with-gap" type="radio" name="a3" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a3" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Fire folder complete & up to date</p>
<div>
<label>
<input class="with-gap" type="radio" name="a4" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a4" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Health & Safety folder complete up to date</p>
<div>
<label>
<input class="with-gap" type="radio" name="a5" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a5" value="0"/><span>No</span>
</label>
</div>

<p class="text2">Security folder complete & up to date</p>
<div>
<label>
<input class="with-gap" type="radio" name="a6" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a6" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Pre-Brief/Debrief</p>
<div>
<label>
<input class="with-gap" type="radio" name="a7" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a7" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Float Check</p>
<div>
<label>
<input class="with-gap" type="radio" name="a8" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a8" value="0"/><span>No</span>
</label>
</div>
<p class="text1">CCTV 31 days recording</p>
<div>
<label>
<input class="with-gap" type="radio" name="a9" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a9" value="0"/><span>No</span>
</label>
</div>
<p class="text1">All cameras working & burning correctly</p>
<div>
<label>
<input class="with-gap" type="radio" name="a10" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a10" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Float Check record</p>
<div>
<label>
<input class="with-gap" type="radio" name="a11" value="5" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a11" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Computers working</p>
<div>
<label>
<input class="with-gap" type="radio" name="a12" value="5" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a12" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Radios Charging</p>
<div>
<label>
<input class="with-gap" type="radio" name="a13" value="0" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a13" value="5"/><span>No</span>
</label>
</div>
<p class="text2">Homebase software completed</p>
<div>
<label>
<input class="with-gap" type="radio" name="a14" value="10" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a14" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Safe protocol</p>
<div>
<label>
<input class="with-gap" type="radio" name="a15" value="5" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a15" value="0"/><span>No</span>
</label>
</div>
<p class="text1">No broken PDQ machines</p>
<div>
<label>
<input class="with-gap" type="radio" name="a16" value="5" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a16" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Body camera footage saved to drive (Incidents)</p>
<div>
<label>
<input class="with-gap" type="radio" name="a17" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a17" value="0"/><span>No</span>
</label>
</div>
<p class="text1">Incident reports completed correctly</p>
<div>
<label>
<input class="with-gap" type="radio" name="a18" value="20" checked/><span>Yes</span>
</label>
</div>
<div>
<label>
<input class="with-gap" type="radio" name="a18" value="0"/><span>No</span>
</label>
</div>
</div>
</div>
<!-- end of section -->
<!-- bottom of coloured background block -->
</div>

<!-- blank column -->
<div class="col s1"></div>
</div>

<div class="row">
<!-- blank column -->
<div class="col s4"></div>
<div class="col s4 center-align">
<button class="btn brand waves-effect waves-light" type="submit" name="submit">Submit<i class="material-icons right">send</i></button>
</div>
<!-- blank column -->
<div class="col s4"></div>

</div>
</form>

最佳答案

如何制作对象数组?

item={correctAnswer:"some answer", points:someNumber}
然后:
var auditScore=0;
for(var answerIndex=0; answerIndex<userAuditAnswers.length; answerIndex++)
if(userAuditAnswers[answerIndex]==auditCorrectAnswers[index].correctAnswer)
auditScore+=auditCorrectAnswers[index].points;```

关于javascript - 在javascript中从数组返回一个值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62513978/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com