- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 JavaScript 和后端编码也很陌生。我需要启动计数器的帮助。我在下面编写的代码执行以下操作。
我想要做的是,当当前值小于或大于前一个值时,它应该更改背景颜色并启动一个名为 counterAlert 的计数器。此计数器应计数最多 10 秒并将背景颜色更改回原始颜色,但是在这 10 秒时间范围内,该函数应继续循环 JSON 文件,如果它再次达到当前值的条件,则更大小于或小于先前的值,计数器应重置。
我必须循环遍历 JSON 文件的 JavaScript 代码如下
var counter = 0; // Trial
var counterAlert = 0
$(document).ready(function () {
$.ajaxSetup({ cache: false });
myJson();
});
// Below is the function to draw data from Json
function myJson() {
$.getJSON("Janus.json", function (response) {
var i = 1380; //start demo at last hour of data.
var looping = setInterval(function () {
var TrialCount = response.length;
var Info = response[counter];
var Checker_Data = Info.WOB;
Checker_Data = Checker_Data.toFixed(2);
CompareChecker();
function CompareChecker() {
if (counter == 0) {
prev_Checker_Data = Checker_Data;
}
if (Checker_Data > prev_Checker_Data) {
if ((Math.abs(Checker_Data - prev_Checker_Data) >= prev_Checker_Data / 2 ))
document.getElementById("Checker_img").src = "img/yeltri.png",
document.getElementById("CheckerValue").style.backgroundColor = '#006699';
else if ((Math.abs(Checker_Data - prev_Checker_Data) <= prev_Checker_Data / 2))
document.getElementById("Checker_img").src = "img/grnsqr.png";
}
else if (Checker_Data < prev_Checker_Data) {
if ((Math.abs(Checker_Data - prev_Checker_Data) >= prev_Checker_Data / 2))
document.getElementById("Checker_img").src = "img/yeltriDn.png";
else if ((Math.abs(Checker_Data - prev_Checker_Data) <= prev_Checker_Data / 2))
document.getElementById("Checker_img").src = "img/grnsqr.png";
}
prev_Checker_Data = Checker_Data;
}
document.getElementById("Checker").innerHTML = Checker_Data
counter++;
if (counter == TrialCount) clearInterval(looping);
}, 10);
});
};
我在想,要做我想做的事,我需要在函数 CompareChecker() 的 If 语句下插入另一个函数,这样
if (Checker_Data > prev_Checker_Data) {
if ((Math.abs(Checker_Data - prev_Checker_Data) >= prev_Checker_Data / 2 ))
document.getElementById("Checker_img").src = "img/yeltri.png",
document.getElementById("CheckerValue").style.backgroundColor = '#006699',
checkerValue_Timer();
function checkerValue_Timer(){
counterAlert++;
if (counterAlert == 10)
document.getElementById("CheckerValue").style.backgroundColor = '#cecece';
}
setInterval(CheckerValue_Timer, 1000);
但我不确定,请帮忙
最佳答案
问题根本不清楚,尤其是逻辑。原始代码使用 10 毫秒的采样率,但需要 10 秒的重置计时器。因此,为了测试这一点,我们需要生成一个包含数千条记录的数据集,并且至少有 1000 条匹配记录来触发重置。
下面的示例尝试将代码分解为数据、计时器和 UI 函数,以使其更易于管理。然而,OP只需要关注作为控制逻辑的计时器部分。根据要求,不匹配的记录会触发 UI 更改。直到有 10 秒的连续匹配记录(+1000 条记录)后,UI 才会重置为原始状态。
要进行测试,请单击“显示代码片段”链接,然后单击蓝色按钮“运行代码片段”
更新:修改代码,以便通过类名切换图像。这比在原始代码中重复设置图像 src 更有效,即它避免了无关的服务器请求。
(function() {
var DEBUG = true, // false = use json data, true = auto generate data
DATA_URL = 'janus.json',
IMAGE_URL = 'https://cdnjs.cloudflare.com/ajax/libs/fatcow-icons/20130425/FatCow_Icons32x32/',
INTERVAL = 10,
TIMEOUT = 10000,
counter, timerId, response, timerAlert;
// initialize
$('#button1').click(function() {
getData(function(data) {
response = data;
startTimer();
});
});
$('#button1').click();
function startTimer() {
// reset
counter = 0;
timerAlert = 0;
if (timerId) clearInterval(timerId);
// start
timerId = setInterval(function() {
counter++;
if (counter >= response.length - 1) clearInterval(timerId);
if (parseFloat(response[counter].WOB) != parseFloat(response[counter - 1].WOB)) {
timerAlert = 0;
updateUI(false);
} else {
timerAlert += INTERVAL;
if (timerAlert > TIMEOUT) timerAlert = TIMEOUT;
updateUI(timerAlert >= TIMEOUT);
}
}, INTERVAL);
};
function updateUI(bOriginal) {
$('#CheckerValue').css('background-color', (bOriginal ? 'LightGray' : 'SeaGreen'));
// $('#Checker_img').attr('src', IMAGE_URL + (bOriginal ? 'status_offline.png' : 'status_online.png'));
$('#Checker_img').attr('class', 'icon ' + (bOriginal ? 'offline' : 'online'));
$('#Checker').html(parseFloat(response[counter].WOB).toFixed(2));
$('#counter').html(counter);
$('#timerAlert').html((timerAlert / 1000).toFixed(2) + ' seconds');
$('#Time').html((new Date()).toLocaleTimeString());
}
// get data from server or generate test data when debug true
function getData(callback) {
if (!DEBUG) {
$.ajaxSetup({
cache: false
});
$.getJSON(DATA_URL, callback);
} else {
var i, data = [];
for (i = 0; i < 2500; i++) data.push({
WOB: (i < 20 ? 100 : i == 1200 ? 100 : 200)
});
callback(data);
}
}
})();
table {
border-collapse: collapse;
width: 400px;
font-family: sans-serif;
font-size: 14px;
}
td {
white-space: nowrap;
padding: 2px;
border: 1px steelblue solid;
}
.icon {
background-repeat: no-repeat;
width: 32px;
height: 32px;
}
.icon.online {
background-image: url(https://cdnjs.cloudflare.com/ajax/libs/fatcow-icons/20130425/FatCow_Icons32x32/status_online.png);
}
.icon.offline {
background-image: url(https://cdnjs.cloudflare.com/ajax/libs/fatcow-icons/20130425/FatCow_Icons32x32/status_offline.png);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.10.0/jquery.min.js"></script>
<div>
<button id="button1">Start</button>
<table>
<tr>
<td>Checker_Img</td>
<td id="Checker_img" class="icon offline">
</td>
</tr>
<tr>
<td>CheckerValue</td>
<td id="CheckerValue"></td>
</tr>
<tr>
<td>Checker</td>
<td id="Checker">0</td>
</tr>
<tr>
<td>counter</td>
<td id="counter">0</td>
</tr>
<tr>
<td>timerAlert</td>
<td id="timerAlert"></td>
</tr>
<tr>
<td>Time</td>
<td id="Time"></td>
</tr>
</table>
计时器逻辑:
function startTimer() {
// reset
counter = 0;
timerAlert = 0;
if (timerId) clearInterval(timerId);
// start
timerId = setInterval(function() {
counter++;
if (counter >= response.length - 1) clearInterval(timerId);
if (parseFloat(response[counter].WOB) != parseFloat(response[counter - 1].WOB)) {
timerAlert = 0;
updateUI(false);
} else {
timerAlert += INTERVAL;
if (timerAlert > TIMEOUT) timerAlert = TIMEOUT;
updateUI(timerAlert >= TIMEOUT);
}
}, INTERVAL);
};
关于JavaScript:计数器和 IF/Else,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35301522/
我在leetcode上看到这段代码,是一道求众数的题,下面是题目描述: 给定一个大小为 n 的数组,找到多数元素。众数元素是出现次数超过 ⌊ n/2 ⌋ 次的元素。 你可以假设数组是非空的并且多数元素
每次在 JavaScript 中执行特定操作时,例如: $(function() { $('#typing').keyup(function () { switch($(this)
我一直在为网页设计一个计数器,但我一直被这个我无法解决的功能所困扰。 我有一个 4 个 div 的计数器,因为其中两个是小数字,另外两个是大数字,所以第一个运行得很快,我看不到它们的功能。 有人知道如
我已经在文档中进行了一些搜索,并在网上花了一段时间,但找不到解决方案!我希望警报告诉我单击 .thumb 时它处于each() 的哪一次迭代。 EG:有六个.thumb,我点击数字3,浏览器弹出3!
在 Handlebars 中,假设我有 names 的集合.我能怎么做 {{#each names}} {{position}} {{name}} {{/each}} 在哪里 {{position}}
这个问题在这里已经有了答案: Numbering rows within groups in a data frame (9 个回答) 4年前关闭。 我们如何在数据帧的每组中生成唯一的 ID 号?以下
我正在努力解决以下问题。我希望为给定的“一”序列创建一个计数器。例如,我有以下内容: 1 1 1 1 0 0 1 1 1 0 0 1 1 1 1 鉴于该序列,我希望为 1 的每个序列设置一个计数器直到
我正在努力解决以下问题。我希望为给定的“一”序列创建一个计数器。例如,我有以下内容: 1 1 1 1 0 0 1 1 1 0 0 1 1 1 1 鉴于该序列,我希望为 1 的每个序列设置一个计数器直到
我有一个jsfiddle here 这是一个简单的 JavaScript 函数,可以计算出设定的数字。 是否可以进行这种计数,但也保留一位小数 所以它算 1.1、1.2、1.3 等。 func
我正在构建一个计数器,当我按下鼠标时,它应该增加到 maxValue 并且减少不超过 0。我还可以选择将计数器重置为其初始值:0。另外,如果 maxValue 是偶数,它应该计数到该数字。但是,如果
所以我成功地为字母和单词构建了其他计数器,但现在我只能用这个来计算句子。我的代码如下,当我运行它时,它会返回很多错误消息: #include #include #include int main
Closed. This question is off-topic。它当前不接受答案。
我需要一个计数器,它会随着某些任务的完成而递增。我们只需要最后一小时的值,即窗口将移动而不是静态时间。 解决此问题的最佳方法是什么?我能想到的一种方法是拥有一个大小为 60 的数组,每分钟一个,并更新
我希望使用计数器来为我提供独特的引用系统。我想单击一个按钮,然后检查一个字段/文件中的最后一个数字,然后简单地向其添加 1,然后将其插入到屏幕上的字段中? 不确定执行此操作的最佳方法或具体如何执行此操
我有一个用 php 制作的表格,在该表格内我显示了数据库中的一些内容。我在每个 td 中创建了一个简单的按钮(类似于 Like),我希望每次点击它都会增加 1。这是带有按钮的行: echo "
如何将数据库中的值转换为可用于 if else 函数的 int 值? 例如:在我的数据库“armnumber = 3”中,如何在 if else 函数中使用它? 代码 string myConnect
我需要生成唯一的“ids”,问题是,它只能在 1 - 99999 之间。 “好”的是,它仅在与另一列组合时必须是唯一的。 我们有组,每个组都有自己的“group_id”,每个组都需要类似 unique
有这个简单的代码: UPDATE counter SET c= c +1 where id = 1; 并且它在开头的 c 字段中为 null 的情况下不起作用。它只有在已经输入了一些数字时才有效,也就
我正在尝试在 python 中构建一个具有闭包属性的计数器。以下工作中的代码: def generate_counter(): CNT = [0] def add_one():
我使用 CSS 来计算 HTML 文档中的部分: body {counter-reset: sect;} section:before { counter-increment: sect;
我是一名优秀的程序员,十分优秀!