摘要:全局對象中一個對象,該對象為全局對象。在客戶端中,該對象為,由進行指向中的全局對象為,所有的全局變量,除了自己以外都是對象的屬性全局對象和全局變量全局變量是全局對象的宿主表示當前正在執行的腳本名,將會輸出文件位置所在的絕對路徑。
node全局對象
js中一個對象,該對象為全局對象。
在客戶端中,該對象為whindow,由this進行指向
node中的全局對象為global,所有的全局變量,除了自己以外都是global對象的屬性
全局變量是全局對象的宿主
_filename表示當前正在執行的腳本名,將會輸出文件位置所在的絕對路徑。
如果在模塊中,返回的是模塊文件的路徑。
PS C:UsersmingmDesktop est> node main.js C:UsersmingmDesktop estmain.js PS C:UsersmingmDesktop est>
// 輸出全局變量 __filename的值 console.log(__filename);__dirname
表示當前執行腳本所在的目錄
PS C:UsersmingmDesktop est> node main.js C:UsersmingmDesktop est PS C:UsersmingmDesktop est>
console.log(__dirname);setTimeout
function printHello() { console.log("hello word"); }; // 兩秒后執行以上函數 setTimeout(printHello, 2000); // 該函數返回一個代表定時器的句柄值
function printHello() { console.log("hello word"); }; // 兩秒后執行以上函數 setTimeout(printHello, 2000); // 該函數返回一個代表定時器的句柄值clearTimeout
停止一個計時器
settlnterval一個計時器會不斷的調用,返回的是一個代表定時器的句柄值
function printHello() { console.log("hello word!"); }; // 每兩秒后循環執行以上函數 setInterval(printHello, 2000);
PS C:UsersmingmDesktop est> node main.js hello word! hello word! hello word! hello word! hello word! hello word! hello word! hello word! hello word!process
一個全局變量,即global對象的屬性
用于描述當前node進程狀態的對象。
process.on("exit", (code) => { // 下方代碼不會執行 setTimeout(() => {console.log("該代碼不會執行");}, 0); console.log("退出碼為", code); }); console.log("程序執行結束");
PS C:UsersmingmDesktop est> node main.js 程序執行結束 退出碼為 0 PS C:UsersmingmDesktop est>一個示例文件
// 輸出到終端 process.stdout.write("hello world!" + " "); // 創建一個寫入流,通過寫入流,輸出到終端 // 通過參數讀取 process.argv.forEach((val, index, array) => {console.log(val + index + array)}); // 獲取執行路徑 console.log(process.execPath); // 平臺信息 console.log(process.platform);
PS C:UsersmingmDesktop est> node main.js hello world! C:Program Files odejs ode.exe0C:Program Files odejs ode.exe,C:UsersmingmDesktop estmain.js C:UsersmingmDesktop estmain.js1C:Program Files odejs ode.exe,C:UsersmingmDesktop estmain.js C:Program Files odejs ode.exe win32 PS C:UsersmingmDesktop est>
PS C:UsersmingmDesktop est> node main.js { rss: 18874368, heapTotal: 6066176, heapUsed: 3677376, external: 8272 } PS C:UsersmingmDesktop est>
// 輸出內存使用情況 console.log(process.memoryUsage());node文件系統
node提供一組類似unix的標準文件操作api
異步和同步異步的方法后面會有一個回調函數
貌似回調多了以后會產生回調地獄
var fs = require("fs"); // 異步讀取 fs.readFile("input.txt", (err, data) => { err?console.error(err):true; console.log("異步讀取" + data.toString()); });
PS C:UsersmingmDesktop est> node main.js 異步讀取33333333333333333333333333333333333333333 PS C:UsersmingmDesktop est>
ps 減少異步,讓世界更美好一點(^o^)/打開文件
建議回調使用箭頭函數,要不然很容易產生回調地獄,讓人抓狂
// 打開input.txt文件進行讀寫 var fs = require("fs"); // 異步打開文件 console.log("準備打開文件!"); fs.open("input.txt", "r+", (err, fd) => {err?console.log(err):console.log("文件打開成功!");});
PS C:UsersmingmDesktop est> node main.js 準備打開文件! 文件打開成功!獲取文件信息
fs模塊下的stat方法
判斷是否是文件
var fs = require("fs"); fs.stat("input.txt", (err, stats) => {console.log(stats.isFile());});
PS C:UsersmingmDesktop est> node main.js true PS C:UsersmingmDesktop est>
var fs = require("fs"); console.log("準備打開文件!"); fs.stat("input.txt", (err, stats) => {err?console.log(err):console.log(stats); console.log("讀取文件信息成功!"); // 檢測文件類型 console.log(stats.ifFile()); console.log(stats.isDirectory()); });
PS C:UsersmingmDesktop est> node main.js 準備打開文件! Stats { dev: 982976588, mode: 33206, nlink: 1, uid: 0, gid: 0, rdev: 0, blksize: undefined, ino: 12103423998567884, size: 41, blocks: undefined, atimeMs: 1532607165034.9072, mtimeMs: 1532606924599.2798, ctimeMs: 1532606924599.2798, birthtimeMs: 1532606914067.3428, atime: 2018-07-26T12:12:45.035Z, mtime: 2018-07-26T12:08:44.599Z, ctime: 2018-07-26T12:08:44.599Z, birthtime: 2018-07-26T12:08:34.067Z } 讀取文件信息成功! C:UsersmingmDesktop estmain.js:7 console.log(stats.ifFile()); ^ TypeError: stats.ifFile is not a function at fs.stat (C:UsersmingmDesktop estmain.js:7:20) at FSReqWrap.oncomplete (fs.js:159:5) PS C:UsersmingmDesktop est>寫入文件
var fs = require("fs"); console.log("準備寫入文件"); fs.writeFile("input.txt", "我是異步寫入的內容", (err) => { err?console.log(err):false; console.log("數據寫入成功!"); console.log("----我是分割線----"); console.log("開始讀取寫入的數據"); fs.readFile("input.txt", (err, data) => { err?console.log(err):false; console.log("異步讀取數據為" + data.toString()); }); });
PS C:UsersmingmDesktop est> node main.js 準備寫入文件 數據寫入成功! ----我是分割線---- 開始讀取寫入的數據 異步讀取數據為我是異步寫入的內容 PS C:UsersmingmDesktop est>讀取文件
在異步的情況下讀取文件
參數 http://nodejs.cn/api/fs.html#...
使用的fs.read http://nodejs.cn/api/fs.html#...
var fs = require("fs"); var buf = new Buffer.alloc(1024); // 創建一個緩沖區 console.log("準備打開已存在的文件"); fs.open("input.txt", "r+", (err, fd) => { if (err) { console.log(err); }; console.log("文件打開成功"); console.log("準備讀取文件"); fs.read(fd, buf, 0, buf.length, 0, (err, bytes) => { if (err) { console.log(err); }; console.log(bytes + "字節被讀取"); // 輸出讀取的字節 if (buyes > 0) { console.log(buf.slice(0, bytes).toString()); } }); });
PS C:UsersmingmDesktop est> node main.js 準備寫入文件 數據寫入成功! ----我是分割線---- 開始讀取寫入的數據 異步讀取數據為我是異步寫入的內容 PS C:UsersmingmDesktop est>
Buffer.slice http://nodejs.cn/api/buffer.html
返回一個指向相同原始內存的新建的 Buffer
PS C:UsersmingmDesktop est> node main.js 準備打開已存在的文件 文件打開成功 準備讀取文件 27字節被讀取 我是異步寫入的內容 PS C:UsersmingmDesktop est>
var fs = require("fs"); var buf = new Buffer.alloc(1024); // 創建一個緩沖區 console.log("準備打開已存在的文件"); fs.open("input.txt", "r+", (err, fd) => { if (err) { return console.log(err); }; console.log("文件打開成功"); console.log("準備讀取文件"); fs.read(fd, buf, 0, buf.length, 0, (err, bytes) => { if (err) { console.log(err); }; console.log(bytes + "字節被讀取"); // 輸出讀取的字節 if (bytes > 0) { console.log(buf.slice(0, bytes).toString()); } }); });關閉文件
在異步的模式下關閉文件
PS C:UsersmingmDesktop est> node main.js 準備打開文件! 文件打開成功! 準備讀取文件! 我是異步寫入的內容 文件關閉成功 PS C:UsersmingmDesktop est>
var fs = require("fs"); var buf = new Buffer.alloc(1024); console.log("準備打開文件!"); fs.open("input.txt", "r+", (err, fd) => { if (err) { return console.log(err); }; console.log("文件打開成功!"); console.log("準備讀取文件!"); fs.read(fd, buf, 0, buf.length, 0, (err, bytes) => { if (err) { console.log(err); }; // 輸出能讀取的字節 if(bytes > 0) { console.log(buf.slice(0,bytes).toString()); }; // 關閉文件 fs.close(fd, (err) => { if(err) { console.log(err); }; console.log("文件關閉成功"); }); }); });截取文件
在異步的模式下截取文件
fs.ftruncate(fd[, len], callback)
http://nodejs.cn/api/fs.html#...
var fs = require("fs"); var buf = new Buffer.alloc(1024); console.log("準備打開文件!"); fs.open("input.txt", "r+", (err, fd) => { if (err) { return console.error(err); }; console.log("文件打開成功!"); console.log("截取了10字節后的文件內容。"); // 截取文件 fs.ftruncate(fd, 10, (err) => { if (err) { console.log(err); }; console.log("文件截取成功"); console.log("讀取相同的文件"); fs.read(fd, buf, 0, buf.length, 0, (err, bytes) => { if (err) { console.log(err); }; // 僅輸出讀取的字節 if (bytes > 0) { console.log(buf.slice(0, bytes).toString()); } // 關閉文件 fs.close(fd, (err) => { console.log(err); }); console.log("文件關閉成功!"); }); }); });
PS C:UsersmingmDesktop est> node main.js 準備打開文件! 文件打開成功! 截取了10字節后的文件內容。 文件截取成功 讀取相同的文件 我是異? 文件關閉成功! null PS C:UsersmingmDesktop est>刪除文件
PS C:UsersmingmDesktop est> node main.js 準備刪除文件! 文件刪除成功! PS C:UsersmingmDesktop est>
var fs = require("fs"); console.log("準備刪除文件!") fs.unlink("input.txt", (err) => { if (err) { return console.log(err); }; console.log("文件刪除成功!"); });創建目錄
PS C:UsersmingmDesktop est> node main.js 創建目錄 ./tmp/test { [Error: ENOENT: no such file or directory, mkdir "C:UsersmingmDesktop est mp est"] errno: -4058, code: "ENOENT", syscall: "mkdir", path: "C:UsersmingmDesktop est mp est" } PS C:UsersmingmDesktop est>
var fs = require("fs"); console.log("創建目錄 ./tmp/test"); fs.mkdir("./tmp/test", (err) => { if (err) { return console.log(err); }; console.log("目錄創建成功!"); });讀取目錄
forEach方法沒有找到一個 官方文檔,貌似目前找不到
PS C:UsersmingmDesktop est> node main.js 查看 /tmp 目錄 { [Error: ENOENT: no such file or directory, scandir "C:UsersmingmDesktop est mp"] errno: -4058, code: "ENOENT", syscall: "scandir", path: "C:UsersmingmDesktop est mp" } PS C:UsersmingmDesktop est>
var fs = require("fs"); console.log("查看 /tmp 目錄"); fs.readdir("./tmp/", (err, files) => { if (err) { return console.log(err); }; files.forEach((file) => { // 這個方法目前沒有找到,聯系到客戶端的方法,貌似是合并的意思 console.log( file ); }); });博客
www.iming.info
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/96306.html
摘要:深入淺出一直想致力于寫一篇關于廣義講解系統的文章,苦于時間有限,資源有限。事件驅動機制是通過內部單線程高效率地維護事件循環隊列來實現的,沒有多線程的資源占用和上下文的切換。 深入淺出Node.js 一直想致力于寫一篇關于廣義講解Node.js系統的文章,苦于時間有限,資源有限。這篇文章是在結合自己的學習心得以及與行業大佬共同探討下爭對于熟練掌握JS語言后的廣義Node.js.至于為什么...
摘要:深入淺出一直想致力于寫一篇關于廣義講解系統的文章,苦于時間有限,資源有限。事件驅動機制是通過內部單線程高效率地維護事件循環隊列來實現的,沒有多線程的資源占用和上下文的切換。 深入淺出Node.js 一直想致力于寫一篇關于廣義講解Node.js系統的文章,苦于時間有限,資源有限。這篇文章是在結合自己的學習心得以及與行業大佬共同探討下爭對于熟練掌握JS語言后的廣義Node.js.至于為什么...
摘要:深入淺出一直想致力于寫一篇關于廣義講解系統的文章,苦于時間有限,資源有限。事件驅動機制是通過內部單線程高效率地維護事件循環隊列來實現的,沒有多線程的資源占用和上下文的切換。 深入淺出Node.js 一直想致力于寫一篇關于廣義講解Node.js系統的文章,苦于時間有限,資源有限。這篇文章是在結合自己的學習心得以及與行業大佬共同探討下爭對于熟練掌握JS語言后的廣義Node.js.至于為什么...
摘要:基礎篇整合最近有朋友也想學習相關方面的知識,如果你是后端想接近前端,作為一門跑在服務端的語言從這里入門再好不過了。事件驅動機制是通過內部單線程高效率地維護事件循環隊列來實現的,沒有多線程的資源占用和上下文的切換。 nodeJs 基礎篇整合 最近有朋友也想學習nodeJs相關方面的知識,如果你是后端想接近前端,node作為一門跑在服務端的JS語言從這里入門再好不過了。如果你正好喜歡前端,...
閱讀 3618·2021-11-24 10:25
閱讀 2539·2021-11-24 09:38
閱讀 1230·2021-09-08 10:41
閱讀 2914·2021-09-01 10:42
閱讀 2586·2021-07-25 21:37
閱讀 1991·2019-08-30 15:56
閱讀 922·2019-08-30 15:55
閱讀 2759·2019-08-30 15:54