我已经构建了一个函数,通过SerialPort
包提供的数组检查端口是否存在。
端口已连接。当我在函数外部运行代码时它工作(true
当端口被插入时)。
当我试图在函数中运行它时,我会重新undefined
function exists(portName) {
SerialPort.list(function (err, ports) {
ports.forEach(function (port) {
console.log(port.comName);
if (port.comName == portName) {
return true
}
});
});
}
console.log(exists('COM7'));
结果:
NodeJS service has started.
undefined
COM1
COM7
Port is connected.
完整代码:https://github.com/eshk12/SerialPort-HTTP-Server/blob/master/routes/index.js
谢谢!
答案 0 :(得分:2)
由于端口检查是异步,您可能需要一个有前途的功能:
function exists(portName) {
return new Promise(res => {
SerialPort.list((err, ports)=>{
res(ports.some(port => port.comName === portName));
});
});
}
或者@skirtle指出它可以更短:
const exists = portName => SerialPort.list().then(ports => ports.some(port => port.comName === portName ));
所以你可以这样做:
exists("CM7").then(res => console.log(res?"exists":"doesnt exist"));
或者:
(async function(){
console.log(await exists("CM7"));
})();
答案 1 :(得分:0)
行return true
从您传递给forEach
的匿名函数返回,而不是从您的exist
方法返回。
SerialPort.list
似乎是异步的,因此您将不得不使用回调,承诺等,而不是依赖于直接从exist
返回值。