博客
关于我
使用node.js开发博客
阅读量:787 次
发布时间:2019-03-25

本文共 1864 字,大约阅读时间需要 6 分钟。

ECMAScript是 JavaScript 的语法规范,Node.js 是基于 ECMAScript 加上 Node.js API 实现的,以完成服务端操作。JavaScript 是 ECMAScript 加上 Web API,常用于前端开发。

模块化开发common.js 是 Node.js 的模块化规范。通过在文件末尾添加 module.exports 来导出模块。在需要使用模块的文件中,通过 require 函数导入,并通过 module.exports 提供模块。

例如:

  • a.js 中:
    function add(a, b) {  return a + b;}module.exports = add;
  • b.js 中:
    var add = require("./a");var sum = add(10, 20);console.log(sum);

支持导出多个模块:a.js 中:

function add(a, b) {  return a + b;}function mul(a, b) {  return a * b;}module.exports = { add, mul };

b.js 中:

var { add, mul } = require="./a";var add = add, mul = mul;

导入插件:通过 npm 初始化并安装插件:

npm init -ynpm i lodash

导入方式:

var _ = require("lodash");

HTTP 请求处理Node.js 通过 http 模块处理 HTTP 请求。

路由处理

var http = require("http");var queryString = require("querystring");var server = http.createServer((req, res) => {  var url = req.url;  var path = url.split("?")[0];  req.query = queryString.parse(url.split("?")[1]);});

GET 请求处理

var http = require("http");var queryString = require("querystring");var server = http.createServer((req, res) => {  var method = req.method;  var url = req.url;  req.query = queryString.parse(url.split("?")[1]);  res.end(JSON.stringify(req.query));}).listen(8080, function() {  console.log("listening on 8080");});

POST 请求处理

var http = require("http");var server = http.createServer((req, res) => {  if (req.method === "POST") {    var postData = "";    req.on("data", function(chunk) {      postData += chunk.toString();    });    req.on("end", function() {      console.log(postData);      res.end(JSON.stringify(postData));    });  } else {    res.statusCode = 405;    res.end("Method Not Allowed");  }}).listen(8080, function() {  console.log("listening on 8080");});

返回格式设置设置返回格式为 JSON:

res.setHeader('Content-type','application/json');

开发环境使用工具如 node-mon 监控文件变化,使用 cross-env 设置环境变量。

接口开发当前接口不连接数据库,不考虑登录,主要完成基本的 HTTP 交互。通过以上方法可以实现接口的开发。

转载地址:http://epsuk.baihongyu.com/

你可能感兴趣的文章
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>