2016-06-28 66 views
1

Noobish here。重复调用嵌入在init函数中的函数

我正在建设覆盆子pi项目,每5分钟测量一个水箱的深度。我已经在坦克中放置了一个超声波距离测量仪,并且已经使用节点和r-pi-usonic库运行了所有的程序。我可以对超声波设备进行初始调用,以创建平均10个单独的度量(因为各个度量的变化)并将其记录到控制台。

但我想要做的是每5分钟重复一次。我最初尝试通过设置setInterval()来完成此操作,并尝试使用cron。但是,随着查询循环在init函数捆绑起来,它引发以下错误......

timers.js:274 
callback.apply(this, args); 
     ^
TypeError: Cannot read property 'apply' of undefined 
at wrapper [as _onTimeout] (timers.js:274:13) 
at Timer.listOnTimeout (timers.js:119:15) 

所以我的问题是真的是什么让这个运行查询每5分钟的最佳方式?答案无疑会帮助我理解回调等。对不起,这样的傻瓜!

我的代码在这里,为它的废话道歉!

//Import required modules 

var usonic = require('r-pi-usonic'); 
console.log('starting water tank monitor'); 
var min_tank = 30 
var max_tank = 90 
var tank_percent = 0 

usonic.init(function (error) { 
    if (error) { 
     console.log('Error') 
    } else { 
     var sensor = usonic.createSensor(13, 21, 1000); 
     var i = 0 
     var values = 0 
     function myLoop(){ 
      setTimeout(function() {  
       var v = sensor().toFixed(2) ; 
       values = values+parseFloat(v); 
       i++;      
       if (i < 10) {    
        myLoop();    
       } else { 
        value = (values/10).toFixed(2)     
        tank_percent = 100 -((value - min_tank)/ (max_tank - min_tank) * 100) 
        console.log(tank_percent); 
        i = 0; 
        values = 0; 
       }      
      }, 500) 
     }; 
    setInterval (myLoop(), 30000);  
    } 
}); 

回答

1

我的眼睛流血时,我看到(开个玩笑):

setInterval (myLoop(), 30000); 

请注意,您在setInterval中打电话给myLoop。以目前的方式,您立即致电myLoop(),只需一次。您应该提供对您的myLoop函数的参考。

setInterval (myLoop, 30000); 

一旦你正确使用setInterval,你会不会用你setTimeout内的myLoop因为setInterval是异步..

+1

谢谢 - 我的字面意思是要在一块石头下爬行,永远不会再出来 – user2870492

0

你不应该叫myLoop当你把它作为一个参数setInterval,看到doc

function myLoop(){ 
    setTimeout(function() {  
     var v = sensor().toFixed(2) ; 
     values = values+parseFloat(v); 
     i++;      
     if (i < 10) {    
      myLoop();    
     } else { 
      value = (values/10).toFixed(2)     
      tank_percent = 100 -((value - min_tank)/ (max_tank - min_tank) * 100) 
      console.log(tank_percent); 
      i = 0; 
      values = 0; 
     }      
    }, 500) 
}; 
setInterval (myLoop, 30000);  
0

谢谢!我要爬到一块石头下,永远不会再出来。