首頁 > web前端 > js教程 > 怎麼利用Node.js查看作業系統及其版本號

怎麼利用Node.js查看作業系統及其版本號

青灯夜游
發布: 2021-09-13 09:25:28
轉載
4755 人瀏覽過

怎麼利用Node.js檢視作業系統及其版本號碼?以下這篇文章跟大家介紹一下Node.js中判斷作業系統、取得Windows和Mac系統的Node.js版本號的方法。

怎麼利用Node.js查看作業系統及其版本號

取得作業系統

在Node.js 中判斷作業系統是很簡單的,用# process.platform 即可傳回標識作業系統平台的字串,可能的值為:

  • aix
  • darwin
  • freebsd
  • linux
  • openbsd
sunos

win32

除了這個方法,還可以使用

os 模組的os. platform()

方法獲取,得到的結果是一樣的。 【推薦學習:《

nodejs 教學》】取得Windows 系統版本號

知道作業系統之後,我們也希望取得其版本號,例如如果使用者是windows,我想知道他是用的win7 還是win10 呀,這時候該怎麼辦呢?還是要用到os

模組的

os.release() 方法獲取,得到的格式如下:

10.0.18363
登入後複製

格式是

major.minor.build,各版本的對應關係如下:
 Version                                    major.minor   
------------------------------------------ ------------- 
 Windows 10, Windows Server 2016            10.0
 Windows 8.1, Windows Server 2012 R2        6.3
 Windows 8, Windows Server 2012             6.2
 Windows 7, Windows Server 2008 R2          6.1
 Windows Vista, Windows Server 2008         6.0
 Windows XP Professional x64 Edition,       5.2
 Windows Server 2003, Windows Home Server
 Windows XP                                 5.1
 Windows 2000                               5.0
登入後複製

更詳細的介紹,可參考

官方文件。這裡給出一個如何判斷win7 或win7 及以下的程式碼:

const os = require('os')
const semver = require('semver')
const platform = os.platform()
const isWindows = platform === 'win32'
const release = os.release()
const isWin7 = isWindows && release.startsWith('6.1')
const win7orOlder = isWindows && semver.lte('6.1')
登入後複製
取得Mac 系統版本號但在Mac 上,os.release( )

得到的結果就不準了,例如我Mac 版本是11.1,但是

os.release()

回傳的是

20.2.0

,如果Mac 版本是11.5,回傳的卻是

20.5.0,所以不能用這個方法取得了。不過Mac 上有一個命令sw_vers,我們在終端運行結果如下:

$ sw_vers
ProductName:	macOS
ProductVersion:	11.4
BuildVersion:	20F71
登入後複製

可以看到ProductVersion 那一行展示了精確的版本號,可以用下面的命令提取出來:

$ sw_vers -productVersion
11.4
登入後複製
到這裡,程式碼就出來了:
const { execSync } = require('child_process')
const macVersion = execSync('sw_vers -productVersion', { encoding: 'utf-8' })
登入後複製

Mac 上的版本號對應關係可參考###官方文件###。 ######更多程式相關知識,請造訪:###程式設計入門###! ! ###

以上是怎麼利用Node.js查看作業系統及其版本號的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:juejin.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板