这篇文章发布于 2024年12月23日,星期一,00:31,归类于 JS API。 阅读 3846 次, 今日 22 次 6 条评论
by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=11498
本文可全文转载,独立域名个人网站无需授权,但需要保留原作者、出处以及文中链接,任何网站均可摘要聚合,商用请联系授权。
目前,浏览器是有能力获取系统的一些信息的,包括内存大小,CPU/GPU、电量等。
一、JS获取内存大小
很简单,下面一行代码即可:
navigator.deviceMemory
例如在我的Chrome浏览器控制台的输出结果就是:
deviceMemory
的兼容性如下截图所示,目前仅Chrome浏览器支持。
二、JavaScript get cpu信息
目前Web没法获取CPU具体的参数信息,但是可以获取CPU的核数。
同样是navigator对象,不过属性值看不到CPU三个字母的影子,名为hardwareConcurrency,表示可以并行运行的硬件数量。
代码示意:
navigator.hardwareConcurrency
运行结果示意:
没想到,我的破电脑CPU是12核的,应该与去年换主板有关,不过没看出性能有多少提升。
不过Mac下貌似可以看出芯片的品牌,例如我的Mac办公电脑运行navigator.platform
返回的是'MacIntel'
。
hardwareConcurrency
值的兼容性比deviceMemory
好多了,参见下图,可以看到所有标准浏览器都是支持的:
三、GPU也是可以获取的
也是一行语法:
navigator.gpu
不过navigator.gpu
返回的并不是具体的数值,而是GPU对象,这个对象和WebGPU API关联密切。
支持一个属性和两个方法,属性是wgslLanguageFeatures
,方法为requestAdapter()
和getPreferredCanvasFormat()
。
而navigator.gpu.wgslLanguageFeatures.size
返回的是当前Web环境支持的WGSL语言特征数量,例如我的电脑windows电脑返回的是4,Mac笔记本也是4,有些GPU比较老,数量就不会是4.
不过这个API……怎么说呢,跟想象的有些不一样,检测的其实是浏览器是否支持WebGPU,以及是否可以调用适配器,以使用WebGL等功能。
我看来下兼容性,嘿,最新的Safari和Firefox都已经支持了,还挺巧的。
四、设备的电量识别
电量获取使用getBattery()方法,使用示意:
let batteryIsCharging = false; navigator.getBattery().then((battery) => { // 当前电量水平是...范围0-1 console.log(battery.level); // 是否在充电 batteryIsCharging = battery.charging; // 充电状态变化的时候 battery.addEventListener("chargingchange", () => { batteryIsCharging = battery.charging; }); });
通过上述代码,我们就可以获悉当前设备的电量状态,以及是否是充电状态。
像是PC电脑,接电源的,没电池的,只要设备运行,电量范围就一定是1,但是移动笔记本就会不一样。
我们可以据此,显示自定义的电池进度,充电动画,或者低电量模式的交互提醒(例如,关闭不必要的动画以帮助用户省电)等。
这个API其实和用户体验还是走得蛮近的,兼容性的话,我看看,是这样的:
有些遗憾,仅仅Chrome浏览器支持,怪不得社区很少见到有对此API的讨论。
而且从Chrome开始支持的时间来看,短时间内,看不到Safari浏览器支持的迹象。
这么好的API,目前也只能当做玩具使用了。
五、其他一些硬件与设备的识别
navigator
对象还提供了很多其他的硬件识别,例如蓝牙,虚拟键盘,USB,外置摄像头,是否掉线(navigator.onLine)等。
篇幅原因,我就不一一展示了,有兴趣可以访问对应的文档。
只要遇到类似的场景,知道Web有这样的能力就可以了。
ok,就这样吧,轻轻松松,又水了一篇文章,佛佛佛。
本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=11498
(本篇完)
- 二次元live2d看板娘效果中的web前端技术 (0.390)
- 腾讯开源的酷炫动画播放解决方案Vap初体验 (0.390)
- JS视频解码JSMpeg和Broadway开箱测评 (0.390)
- 隐私相关-了解HTML5 Do Not Track API (0.349)
- 使用navigator.connection.downlink前端测网速 (0.312)
- 借助HTML ping属性实现数据上报 (0.312)
- 今天才知道,Web网页也能阻止息屏了 (0.312)
- ajax与HTML5 history pushState/replaceState实例 (0.260)
- mobilebone.js-mobile移动web APP单页切换骨架 (0.260)
- JS获取上一访问页面URL地址document.referrer实践 (0.260)
- Broadcast Channel API简介,可实现Web页面广播通信 (RANDOM - 0.037)
还是浏览器好….nodejs的话就没现成接口获取gpu信息了…..
内存好像不准,我16g,返回8g;platform,我是m1芯片,返回的也是 MacIntel么
内存确实不准,我的windows系统 16G RAM,查出来也是8g
很可惜的是这些接口目前的主流用法是拿来做指纹识别而不是做一些真正对用户有用的事情。。。
刚刚还在研究,张老师就发文了!
我做的是在浏览器中运行大语言模型(WEBRWKV),正在研究根据显存大小自动加载最合适的模型。但是似乎没找到能获取显存大小的接口,目前的方案是用GPU型号模糊查表(https://www.kaggle.com/datasets/alanjo/graphics-card-full-specs),想问问张老师有更好的方案吗?
难哦,怕是要插件或软件之类的传数据