博客
关于我
使用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学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>
Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
查看>>
Mysql学习总结(9)——MySql视图原理讲解与使用大全
查看>>
MySQL学习笔记十七:复制特性
查看>>
Mysql学习第一课-mysql的定义及sql语句
查看>>
mysql安全模式: sql_safe_updates
查看>>