<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                ## 前言 作為前后端分離趨勢的技術支持,nodejs一直扮演著重要的角色,那么在實際的項目中,nodejs究竟可以做哪些,又有什么便利之處呢? ## 基礎 ### 什么是nodejs js語言的運行環境,提供了一系列的內置對象。 ### 用途 比較適合用于:實時,高并發,前后端分離,io密集等基本技術場景前提,不擅長cpu密集類型的。 * Web開發:Express + EJS + Mongoose/MySQL * REST開發:Restify * Web聊天室(IM):Express + Socket.io * Web爬蟲:Cheerio/Request * Web博客:Hexo * Web論壇: nodeclub * Web幻燈片:Cleaver * OAuth認證:Passport,網關 * 定時任務工具: later * 瀏覽器環境工具: browserify * 命令行編程工具:Commander * Web控制臺工具: tty.js * 客戶端應用工具: node-webwit * 操作系統: node-os. * 其他 ### 安裝 NodeJS 提供了一些安裝程序,都可以在[http://nodejs.cn/](http://nodejs.cn/) 這里下載并安裝。 * windows Windows 系統下,選擇和系統版本匹配的 .msi 后綴的安裝文件。 * Mac OS X 選擇 .pkg 后綴的安裝文件。 ### 校驗 win下系統,可以通過node -v 查看node 版本,在win下比較特殊,npm是合并安裝好的。在linux下是需要單獨安裝的。 ### 運行 * win運行 * 打開終端,鍵入 node 進入命令交互模式,可以輸入一條代碼語句后立即執行并顯示結果,例如: ``` bash $ node > console.log('Hello World!'); Hello World! ``` * 如果要運行一大段代碼的話,可以先寫一個JS文件再運行。例如有以下 hello.js。 ``` javascript // js文件內容 function hello(){ console.log("hello world"); } hello(); //寫好后在終端下鍵入 node hello.js 運行,結果如下: $ node helloworld.js ``` ### 模塊 編寫稍大一點的程序時一般都會將代碼模塊化。在 NodeJS 中,一般將代碼合理拆分到不同的 JS 文件中,每一個文件就是一個模塊,而文件路徑就是模塊名。 在編寫每個模塊時,都有 require、exports、module 三個預先定義好的變量可供使用。 1. require 定義需要依賴的模塊 require 函數用于在當前模塊中加載和使用別的模塊,傳入一個模塊名,返回一個模塊導出對象。模塊名可使用相對路徑(以./開頭),或者是絕對路徑(以/或C:之類的盤符開頭)。另外,模塊名中的.js擴展名可以省略。以下是一個例子。 ``` javascript var foo1 = require('./foo'); var foo2 = require('./foo.js'); var foo3 = require('/home/user/foo'); var foo4 = require('/home/user/foo.js'); ``` 2. exports exports 對象是當前模塊的導出對象,用于導出模塊公有方法和屬性。別的模塊通過 require 函數使用當前模塊時得到的就是當前模塊的 exports 對象。以下例子中導出了一個公有方法。 ``` javascript exports.hello = function () { console.log('Hello World!'); }; ``` 3. module 通過 module 對象可以訪問到當前模塊的一些相關信息,但最多的用途是替換當前模塊的導出對象。例如模塊導出對象默認是一個普通對象,如果想改成一個函數的話,可以使用以下方式。 ``` javascript module.exports = function () { console.log('Hello World!'); }; ``` 4. 模塊初始化 一個模塊中的 JS 代碼僅在模塊第一次被使用時執行一次,并在執行過程中初始化模塊的導出對象。之后,緩存起來的導出對象被重復利用。 主模塊 通過命令行參數傳遞給 NodeJS 以啟動程序的模塊被稱為主模塊。主模塊負責調度組成整個程序的其它模塊完成工作。例如通過以下命令啟動程序時,main.js 就是主模塊。 完整示例 例如有以下目錄。 前端項目部署到服務器,需要服務器安裝nodejs環境,下面將帶你在服務器環境下安裝nodejs. 5. require.resolve,解決模塊路徑解析的問題 我們都知道一般情況下require做依賴載入的時候會按照核心模塊還是文件模塊,是js文件還是json文件或者其他做分別的載入,但是當如果有的文件路徑不正確的時候,我們就會載入錯誤,這時候需要require.resolve來解析得到正確的文件路徑,從而載入。 詳細的模塊介紹參考:[require-resolve模塊介紹](https://npm.taobao.org/package/require-resolve);用法如下: ~~~ var module=require.resolve('module'); var module=require(['module'],resolve); ~~~ ## win10系統 * 下載響應的軟件,下一步連續安裝即可。相關鏈接如下 * [32 位安裝包下載地址](https://nodejs.org/dist/v4.4.3/node-v4.4.3-x86.msi) * [64 位安裝包下載地址]( https://nodejs.org/dist/v4.4.3/node-v4.4.3-x64.msi) * [詳細安裝步驟傳送門](http://www.runoob.com/nodejs/nodejs-install-setup.html) ## linux系統 * 使用apt-get安裝 ~~~ sudo apt-get install nodejs sudo apt-get install npm ~~~ ## CentOS * 在 CentOS 使用 yum 包管理器來安裝 Node.js,首先啟用 EPEL 軟件庫,然后運行: ` $ sudoyum install npm` ## 參考文檔 * [菜鳥教程](http://www.runoob.com/nodejs/nodejs-tutorial.html) * [cnode社區](http://cnodejs.org/?tab=good) * [node123](https://github.com/youyudehexie/node123) * [官方api文檔](http://nodejs.cn/api/) * [node課程包教包會](https://github.com/alsotang/node-lessons) * [前端網node專題](http://www.qdfuns.com/notes/id/all:all:all:ad9ade5483728d5d1b335087ee1f8394.html) * [nodejs框架資源](https://www.awesomes.cn/repos/NodeJS/Frameworks) * [node新手入門](https://cnodejs.org/getstart)
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看