首頁 >web前端 >js教程 >js中對node的詳細介紹

js中對node的詳細介紹

零下一度
零下一度原創
2017-06-30 10:52:581359瀏覽

目錄:

一、介紹

#二、node安裝

三、webstorm配置node環境

四、程式碼介紹

#、如何使用

# #六、自訂網域七、其他
 
一、介紹

# #1、背景     日常工作中,跟後端商定好接口格式後;通常採用的開發方式,就是自己新建一個json文件,手動的模擬一批數據,進行ajax呼叫。
但是如果遇到後端提供的介面不是同一個網域下的話,就需要將普通的ajax呼叫改為jsonp形式。

2、功能介紹

      於是想到,可以用node.js搭建一個簡單的http服務,供日常開發使用。分別提供jsonp/json呼叫。 也是第一次接觸node,就從node的安裝、webstorm設定環境、node模組介紹等,都做個詳細的記錄。

 

程式碼已上傳至github,位址:


 

#二、node安裝
### 從node官網下載對應平台的安裝包,在Windows上安裝時務必選擇全部元件。 ######### 安裝完成後,開啟cmd指令,輸入###node -v###,出現以下提示表示安裝成功。 #########
C:\Users\IEUser>node -v
v6.10.0
####

       這個表示,我的node版本是6.10.0。  

 

三、webstorm設定node環境

       1、透過file->settings ,開啟設定窗口,定位至Node. js and NPM 選項

            

##卷為node安裝目錄\node_modules\npm,點選configure即可。              

       3、偵測是否能正常使用。

            1)新一個test.js文件,輸入一行程式碼

console.log('hello!');

            2)  設定node環境

                  ①#   

                  ②點選+號,選擇node.js

#Name、javascript file,點選Ok即可。

④點擊右上角的小三角啟動程序,可以看到控制台輸出了 hello 。

 

#四、程式碼介紹     

       0、整體的一個想法

            1)在本地手動新建一些json文件,根據使用者的請求是jsonp還是json;以及請求的是哪個json文件,來輸出對應的程式碼。

            2)代碼相關邏輯:

                 ②偵測對應的json檔案是否有

                  ③輸出對應的結果

 

  

##               node-jsonp        

#                 |       |-1 .json

                  |       |-2.json

    1# #              json資料夾下存放對應的json檔案;getjson.js為node服務的起始檔案。

 

        2、涉及到的node模块有:

  HTTP              提供HTTP服务器与客户端,可以搭建一个http服务,捕获和响应请求等。

  URL                用于 URL 处理与解析 

  querystring     用于解析与格式化 URL 查询字符串

  fs                    用于操作文件

  Path               用于处理文件与目录的路径   

 

        3、新建一个起始文件 getjson.js,引用这些模块。              

var http = require('http');var url=require('url');var querystring = require('querystring');var fs=require('fs');var path=require('path');

        

         4、使用http.createServer方法,启动一个http服务,并且监听3000端口。这个端口号随意,只要别跟其他端口冲突。           

http.createServer(function(request, response){}).listen(3000);

 

         5、其他代码就不多作解释了,大家一看就懂。getjson.js完整代码如下:

 1 /** 2  * node.js的入口文件. 3  * 必须的参数:file - 文件名称; callback - jsonp形式调用 4  * 返回jsonp形式 5  */ 6 var http = require('http'); 7 var url=require('url'); 8 var querystring = require('querystring'); 9 var fs=require('fs');10 var path=require('path');11 12 function writeMsg(response,msg){13     response.writeHead(200, {'Content-Type': 'text/plain;charset=utf-8;'});14     response.write(msg);15     response.end();16 }17 18 19 http.createServer(function(request, response){20     //获取url的query21     var arg = url.parse(request.url).query;22     //转换为json形式23     var arg_json = querystring.parse(arg);24     //输出的内容25     var content = '';26     var filepath = arg_json.file;27     var callback =arg_json.callback;28 29     if(filepath){30        //file -- 本地的json文件路径31         filepath = path.resolve('./json/'+filepath);32        //判断文件是否存在33        if(!fs.existsSync(filepath)){34             content='error:文件不存在';35             writeMsg(response,content);36        }else{37            fs.readFile(filepath,'utf-8',function(err,data){38                if(err){39                    console.log(err);40                    content='error:文件读取失败';41                    writeMsg(response,content);42                }else{43                    //读取成功44                    if(callback){45                        //callback -- jsonp形式46                        response.writeHead(200, {'Content-Type': 'application/javascript;charset=utf-8;'});47                        content = callback+'('+data+');';48                        response.write(content);49                        response.end();50                        return false;51                    }52                    else{53                        //callback -- jsonp形式54                        response.writeHead(200, {'Content-Type': 'text/json;charset=utf-8;'});55                        response.write(data);56                        response.end();57                        return false;58                    }59                }60            });61        }62     }else{63         content='error:参数错误';64         writeMsg(response,content);65     }66 67 68 }).listen(3000);
View Code

  

 五、如何使用

        使用方式可以分为两种:

        1、在webstorm中运行

              直接点击右上角的小三角,就可以运行此服务。

              点击控制台左侧的红色正方形,可以关闭服务。 

              

 

        2、在cmd命令中运行

             先定位到getjson.js文件所在的目录,使用命令: node getjson.js 就可以运行此服务。

            按住 ctrl+c,就可以退出服务。

        

       

 

3、测试下自己的服务

     新建一个demo.html页面,引用jquery文件,调用下自己的服务。     

<!DOCTYPE html><html><head><title></title></head><body><script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js?1.1.11"></script><script>$(function(){
        $.post('http://127.0.0.1:3000/?file=2.json',function(ret) {
                   document.write(JSON.stringify(ret));
                },'jsonp');
    });</script></body></html>

 

 

六、自定义域名

      如果不想用 localhost 或者127.0.0.1 来访问的话,可以在 hosts 中映射下即可。

      用记事本打开C:\Windows\System32\drivers\etc\hosts文件,新增一行。

127.0.0.1 www.getjson.com

        我把本地的请求,映射到www.getjson.com这个域名下了,当然你也可以改成任意你想要的域名。

       然后就可以在浏览器中输入::3000/?file=2.json 来访问你的服务了。 

 

 七、参考链接

    阮一峰的node教程

    node.js相关的api

    浅试webstorm配置node.js开发环境

   node.js遍历文件生产文件列表   

 

以上是js中對node的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn