Vue框架在项目开发中如何实现组件的复用?
- 内容介绍
- 文章标签
- 相关推荐
本文共计711个文字,预计阅读时间需要3分钟。
目录:
一、主要实现原理
二、获取本机局域网IP
三、启动服务器
四、关闭服务器
五、简单演示
六、整体代码
七、展望
一、主要实现原理:使用Electron框架,集成Node.js,实现原理
二、获取本机局域网IP:直接输出
三、启动服务器:直接输出
四、关闭服务器:直接输出
五、简单演示:直接输出
六、整体代码:直接输出
七、展望:直接输出
目录
- 一、主要实现原理
- 二、获取本机局域网IP
- 三、开启服务器
- 四、关闭服务器
- 五、简单演示
- 六、整体代码
- 七、展望
一、主要实现原理
electron本身就集成了Nodejs,简直是不要太舒服。直接用最基本的${SERVER_IP}:${SERVER_PORT}`)
})
server.on('error', (err: any) => {
if (err.code === 'EADDRINUSE') {
// 服务器端口已经被使用
reject(`端口:${SERVER_PORT}被占用,请更换占用端口`)
}
})
})
}
四、关闭服务器
这里有个小坑,如果单纯通过 server.close() 关闭服务,重复开关10次后会出警告。大致意思是监听端口过多,解决办法是关闭服务器时将监听也移除。
// 关闭server function closeServer(): void { server && server.removeAllListeners(); server && server.close(() => { console.log("服务接口关闭"); }); }
五、简单演示
局域网内设备都可以访问接口,已测试手机APP访问接口成功,要注意跨域问题。
六、整体代码
server.ts
const os = require('os'); const ${SERVER_IP}:${SERVER_PORT}`) }) server.on('error', (err: any) => { if (err.code === 'EADDRINUSE') { // 服务器端口已经被使用 reject(`端口:${SERVER_PORT}被占用,请更换占用端口`) } }) }) } // 关闭server function closeServer(): void { server && server.removeAllListeners(); server && server.close(() => { console.log("服务接口关闭"); }); } // 获取本机的局域网IP function getServerIp() { let interfaces = os.networkInterfaces(); for (let devName in interfaces) { let iface = interfaces[devName]; for (let i = 0; i < iface.length; i++) { let alias = iface[i]; if (alias.family === 'IPv4' && alias.address !== '127.0.0.1' && !alias.internal) { return alias.address; } } } } export { openServer, closeServer }
七、展望
如果想把接口开放到外网,我目前只知道用路由器本机地址内网穿透。不过挺麻烦,小软件不需要这么多需求。还有,我想问下uniapp能否像这个一样在前端开启接口?
到此这篇关于Vue electron前端开启局域网接口实现流程详细介绍的文章就介绍到这了,更多相关Vue electron内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!
本文共计711个文字,预计阅读时间需要3分钟。
目录:
一、主要实现原理
二、获取本机局域网IP
三、启动服务器
四、关闭服务器
五、简单演示
六、整体代码
七、展望
一、主要实现原理:使用Electron框架,集成Node.js,实现原理
二、获取本机局域网IP:直接输出
三、启动服务器:直接输出
四、关闭服务器:直接输出
五、简单演示:直接输出
六、整体代码:直接输出
七、展望:直接输出
目录
- 一、主要实现原理
- 二、获取本机局域网IP
- 三、开启服务器
- 四、关闭服务器
- 五、简单演示
- 六、整体代码
- 七、展望
一、主要实现原理
electron本身就集成了Nodejs,简直是不要太舒服。直接用最基本的${SERVER_IP}:${SERVER_PORT}`)
})
server.on('error', (err: any) => {
if (err.code === 'EADDRINUSE') {
// 服务器端口已经被使用
reject(`端口:${SERVER_PORT}被占用,请更换占用端口`)
}
})
})
}
四、关闭服务器
这里有个小坑,如果单纯通过 server.close() 关闭服务,重复开关10次后会出警告。大致意思是监听端口过多,解决办法是关闭服务器时将监听也移除。
// 关闭server function closeServer(): void { server && server.removeAllListeners(); server && server.close(() => { console.log("服务接口关闭"); }); }
五、简单演示
局域网内设备都可以访问接口,已测试手机APP访问接口成功,要注意跨域问题。
六、整体代码
server.ts
const os = require('os'); const ${SERVER_IP}:${SERVER_PORT}`) }) server.on('error', (err: any) => { if (err.code === 'EADDRINUSE') { // 服务器端口已经被使用 reject(`端口:${SERVER_PORT}被占用,请更换占用端口`) } }) }) } // 关闭server function closeServer(): void { server && server.removeAllListeners(); server && server.close(() => { console.log("服务接口关闭"); }); } // 获取本机的局域网IP function getServerIp() { let interfaces = os.networkInterfaces(); for (let devName in interfaces) { let iface = interfaces[devName]; for (let i = 0; i < iface.length; i++) { let alias = iface[i]; if (alias.family === 'IPv4' && alias.address !== '127.0.0.1' && !alias.internal) { return alias.address; } } } } export { openServer, closeServer }
七、展望
如果想把接口开放到外网,我目前只知道用路由器本机地址内网穿透。不过挺麻烦,小软件不需要这么多需求。还有,我想问下uniapp能否像这个一样在前端开启接口?
到此这篇关于Vue electron前端开启局域网接口实现流程详细介绍的文章就介绍到这了,更多相关Vue electron内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

