Nodejs、浏览器 的兼容性问题及解决方案
Nodejs、浏览器 的兼容性问题及解决方案
在浏览器中的 js 引用 nodejs 模块,引用 mysql 模块报错
Uncaught TypeError: Net.createConnection is not a function at Connection.connect
为什么我没有听懂你想干什么,你想在浏览器里面直接连接 mysql ?
连接 mysql 至少需要能调用 tcp 的能力吧,ssh 也行,这两个浏览器都不支持。你的运行环境是基于浏览器的 js,api 都是浏览器提供的,不是单独的 nodejs 运行环境。
浏览器中一般不能使用 Node 模块
Browserify 这个工具不是能够打包 nodejs 工具包吗,引用 nodejs 模块
用 MySQL HTTP Plugin
https://labs.mysql.com/
要什么自行车。
部分模块可以,像是文件模块之类就不行
很奇怪为什么会有这种需求?
为什么不直接写 SSR,让后端去渲染前端,而不是前端带上后端
#3 理解下什么是环境,环境都不提供那个功能,你安装啥都没用。nodejs 的 server 可以 mysql 是因为 nodejs 的环境是 linux,或者他的环境就直接提供 tcp,浏览器不提供 tcp。只提供 http 和 websocket。
浏览器都能直连 mysql 还要后端干啥?
javascript 一般分浏览器端 js 和后端 js (一般是 Node.js )的,浏览器端 js 一般由于浏览器沙箱(可以理解为一种安全措施)的缘故,没办法拿到诸如文件、进程等权限,或者也可以说在浏览器的 js 执行环境不提供这些 API 接口,所以才会有诸如 IE 的 ActiveX 之类的东西,通过浏览器插件的方式才可以拿到一些高级权限。而你直接运行肯定是没戏的,所以需要开个后端服务。本地跑的话装个 Node.js 然后搞个框架(比如 Express 之类的)把服务搭起来,然后前端就能访问了。
不过不太清楚你想存什么东西,前端也有页面级别的存储。当然既然是存到浏览器(客户端)上,肯定会丧失一些保密性。懒得折腾的话可以直接看下 localForage ( https://github.com/localForage/localForage )这个库( Mozilla 家的),中文文档可以看 docschina 的( https://localforage.docschina.org/ ),它给了个通用接口(存储类型是 key-value 的),这样就不用关心底层具体的技术细节了。
谢谢
做接口,基于 restful 协议,后端用 node 查数据库,提供数据,通过接口传递给前端的请求。
要在浏览器里用 node 模块 你可以考虑用 nwjs 这些集成 nodejs 的定制浏览器 也可以认为是 app 可以做成桌面应用
如果楼主用 electron,这个问题是成立的,
渲染进程算浏览器的话,是可以调用 mysql 模块,
分清楚环境啊.
比如 fs 模块,它要调用系统文件系统,你觉得到了浏览器它能工作吗?
有一些包是同时支持 node/浏览器端,比如 axios,mockjs,但人家是特殊处理过的,打包都得打 UMD 格式.用包之前看清楚是什么环境的
针对Node.js和浏览器的兼容性问题及解决方案,以下是一些专业建议:
Node.js兼容性问题及解决方案
-
版本不匹配:
- 问题:前端模块依赖特定版本的Node.js,版本不匹配会导致构建失败或运行时错误。
- 解决方案:使用
npx check-node-version
检查当前Node.js版本是否满足模块要求,使用nvm(Node Version Manager)管理多个Node.js版本,根据需求切换版本。
-
API变更:
- 问题:Node.js新版本引入新API,旧版本不支持。
- 解决方案:阅读Node.js官方文档,了解API变更,确保代码使用兼容的API。
浏览器兼容性问题及解决方案
-
JavaScript兼容问题:
- 示例:
addEventListener
与attachEvent
在不同浏览器中的兼容性问题。 - 解决方案:编写兼容函数,如:
function addEvent(elm, evType, fn, useCapture) { if (elm.addEventListener) { elm.addEventListener(evType, fn, useCapture); } else if (elm.attachEvent) { elm.attachEvent('on' + evType, fn); } else { elm['on' + evType] = fn; } }
- 示例:
-
CSS兼容问题:
- 问题:不同浏览器对CSS解释存在差异。
- 解决方案:使用CSS前缀、CSS Hack等技术,确保样式在不同浏览器中一致。
综上所述,解决Node.js和浏览器的兼容性问题需要开发者对技术和工具有一定的了解,并根据实际情况选择适当的解决方案。