求教 clearTimeout无法清除定时器问题

Nomad_777 2017-11-04 12:52:56
鼠标移动到up盒子上,图片pic向上滑动,在图片还未滑动到指定位置时,再次触发onmouseover事件。
以下采用setInterval()的方法写的定时器,下一次触发onmouseover事件时,可以清除上次未执行完的动作。
<script type="text/javascript">
window.onload = function(){
var up = document.getElementById("up");
var pic =document.getElementById("pic");
var num = 0;
var speed = 20;
var timer = null;
up.onmouseover = function() {
clearInterval(timer);
timer = setInterval(fnUp,speed);
function fnUp(){
num--;
if(num >= -1070){
pic.style.top = num + "px";
} else {
clearInterval(timer);
}
};
};
</script>

但以下采用setTimeout()方法写的定时器,在下一次触发onmouseover事件时,无法清除上次未执行完的动作。
<script type="text/javascript">
window.onload = function(){
var up = document.getElementById("up");
var pic =document.getElementById("pic");
var num = 0;
var speed = 20;
var timer = null;
up.onmouseover = function(){
clearTimeout(timer);
setTimeout(fnUp,speed);
function fnUp(){
num = num -1;
if(num > -1070){
pic.style.top = num + "px";
setTimeout(fnUp,speed);
}
}
}
}
</script>
...全文
1133 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
2017-11-04
  • 打赏
  • 举报
回复
你setTimeout(fnUp,speed);没赋值 timer = setTimeout(fnUp,speed);
源码下载地址: https://pan.quark.cn/s/48210ff050c9 在生成具备死区间隔的脉冲宽度调制(PWM)信号时,STM32微控制器主要运用高级定时器(例如TIM1、TIM8)或通用定时器(如TIM2、TIM3、TIM4),这些定时器因其丰富的功能特性,能够支持复杂的PWM信号输出。 在当前应用场景下,死区间隔被设定为1微秒,此设置旨在电机驱动场景中防止功率开关器件的直通状态,避免电流尖峰,从而保护整个电路系统。 同时,CH1、CH2、CH3三个通道之间的相位间隔为3微秒,这种相位调制方式可用于三相电机的控制,达成对电机转矩的精准调控。 为了使STM32的定时器能够正常工作在PWM模式,需要进行一系列配置操作。 这些操作通常包括以下环节:1. **定时器初始化**:设定定时器的预分频器(Prescaler)参数,目的是获得期望的计数速率,例如,当系统时钟频率为72MHz,而目标PWM频率为50kHz时,预分频器的值应为72M/50K=1440。 2. **自动重载值(ARR)配置**:自动重载寄存器(ARR)的数值决定了PWM信号的整体周期。 以周期为20μs(对应1/50kHz)为例,ARR的值应设为20-1=19。 3. **比较通道选择**:涉及CH1、CH2、CH3等通道,它们分别与TIMx_CCR1、TIMx_CCR2和TIMx_CCR3寄存器相联系,通过设定这些寄存器的具体数值,可以控制各个通道的PWM占空比。 4. **死区时间设定**:利用TIMx_BDTR寄存器中的DTG字段来设定死区时间。 对于1微秒的死区间隔,必须依据定时器的工作模式与系统时钟速率来计算适宜的DTG参数。 5. **定时器启动**:完成所有配置后,使能定时器,PWM波形将...

87,994

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧