要编写同步的socket.io JavaScript,可以使用Promises或Async/Await来实现。下面是使用Promises和Async/Await两种方法的代码示例:
使用Promises:
const io = require('socket.io-client');
const socket = io('http://example.com');
function emitEvent(eventName, data) {
return new Promise((resolve, reject) => {
socket.emit(eventName, data, (response) => {
if (response.error) {
reject(response.error);
} else {
resolve(response.data);
}
});
});
}
async function exampleUsage() {
try {
const result = await emitEvent('exampleEvent', { message: 'Hello' });
console.log(result);
} catch (error) {
console.error(error);
}
}
exampleUsage();
使用Async/Await:
const io = require('socket.io-client');
const socket = io('http://example.com');
function emitEvent(eventName, data) {
return new Promise((resolve, reject) => {
socket.emit(eventName, data, (response) => {
if (response.error) {
reject(response.error);
} else {
resolve(response.data);
}
});
});
}
async function exampleUsage() {
try {
const result = await emitEvent('exampleEvent', { message: 'Hello' });
console.log(result);
} catch (error) {
console.error(error);
}
}
exampleUsage();
以上示例中,emitEvent函数通过返回Promise对象来实现异步操作。exampleUsage函数使用await关键字来等待emitEvent函数的结果。使用try-catch块来处理可能的错误。