Intro#前端
最近須要用 nodejs 作一個爬蟲,Google 有一個 Puppeteer 的項目,能夠用它來作爬蟲,有關 Puppeteer 的介紹網上也有不少,在這裏就不作詳細介紹了。 node 小白,開始的時候有點懵逼,模塊導出也不會。node
官方文檔上說支持 *.mjs 可是還要改文件擴展名,感受有點怪怪的,就沒用,主要是基於js的模塊使用。npm
模塊導出的兩種方式#async
由於對 C# 比較熟悉,從我對 C# 的理解中,將 nodejs 中模塊導出分紅兩種形式:學習
1.一個要實例化才能調用的模塊 2.一個不須要實例化就能夠調用的靜態類,提供一些靜態方法ui
•導出一個要實例化的類this
module.exports = exports = function (){ }; module.exports = exports = function() { this.syncCompanyList = async function(developerName){ await syncCompanyInfo(developerName); }; async function syncCompanyInfo(developerName){ // ... } }
前端全棧學習交流圈:866109386,面向1-3經驗年前端開發人員,幫助突破技術瓶頸,提高思惟能力,羣內有大量PDF可供自取,更有乾貨實戰項目視頻進羣免費領取。code
•導出一個靜態類orm
exports.funcName = function (){}; var getDistrictCode = function (districtName) { if (districtName) { for (let i= 0; i< DistrictInfo.length; i++) { let district = DistrictInfo[i]; if (district["name"] == districtName || district["aliasName"] == districtName) { return district["code"]; } } } return ""; }; var getNormalDistrictName = function (districtName) { if (districtName) { if (districtName.indexOf('區') > 0) { return districtName; } for (let i= 0; i< DistrictInfo.length; i++) { let district = DistrictInfo[i]; if (district["name"] == districtName || district["aliasName"] == districtName) { return district["name"]; } } } return ""; } // 設置導出的方法及屬性 exports.getDistrictCode = getDistrictCode; exports.getNormalDistrictName = getNormalDistrictName;
前端全棧學習交流圈:866109386,面向1-3經驗年前端開發人員,幫助突破技術瓶頸,提高思惟能力,羣內有大量PDF可供自取,更有乾貨實戰項目視頻進羣免費領取。視頻
引用導出的模塊方法#
在 node 裏使用 require 來引用模塊
•引用 npm 包
const log4js = require("log4js");
•引用本身編寫的模塊
const districtUtil = require("./utils/districtUtil");
使用導出的模塊#
要使用某一模塊,須要先引用某一模塊,引用模塊能夠參考上一步
•實例類
const company = require("./company"); // ... // 實例化一個 company 對象 var comp = new company(); // 調用 company 裏的 syncCompanyList comp.syncCompanyList ();
•靜態類
const districtUtil = require("./utils/districtUtil"); // ... // 調用 districtUtil 裏的 getDistrictCode let districtNme = districtUtil.getDistrictCode('districtName');