Node.js代码信息

运行结果
教程手册
代码仓库
点击编辑器上方的运行按钮,会在此处显示运行结果。
用户最新分享的代码
阿里面试题 发布于:2020-08-07 19:20 JS给数字加千位分隔符 发布于:2020-08-07 18:28 test-服务准别 发布于:2020-08-07 16:54 前端面试题(校招) 发布于:2020-08-07 14:58 testtest 发布于:2020-08-07 11:58 发布订阅模式 JavaScript 发布-订阅模... 发布于:2020-08-07 10:40 发布订阅模式 JavaScript 发布-订阅模... 发布于:2020-08-07 10:23 js 延时 发布于:2020-08-06 19:14 dataSet 转换 发布于:2020-08-07 10:33 模拟 localStorage 时如何实现过期时间... 发布于:2020-08-06 20:43 实现一个 normalize 函数,能将输入的特定... 发布于:2020-08-06 16:38 1.查看运行nodejs 的线上系统的参数 发布于:2020-08-07 16:53 json 数组排序 发布于:2020-08-06 10:57 测试promise捕获异常信息 发布于:2020-08-05 16:35 时间日期格式化为yyyymmdd 发布于:2020-08-05 17:57 时间日期格式化为yyyymmdd 发布于:2020-08-04 18:39 时间日期格式化为yyyymmdd 发布于:2020-08-04 18:39 时间日期格式化为yyyymmdd 发布于:2020-08-04 18:35 改进版点赞 发布于:2020-08-04 13:10 实现Generator函数的run 发布于:2020-08-01 23:30 函数编程-组合 发布于:2020-07-31 19:01 函数编程-惰性函数 发布于:2020-07-31 17:22 函数式编程-偏函数 发布于:2020-07-31 16:40 函数柯里化 发布于:2020-07-31 15:59 Tennis tournament draws &... 发布于:2020-07-31 01:28 驼峰修改字符aaa-bbb-ccc 发布于:2020-07-30 22:54 手写EventBus 发布于:2020-07-30 21:47 Iterator遍历对象 发布于:2020-07-30 18:12 第 92 题:已知数据格式,实现一个函数 fn 找... 发布于:2020-07-29 14:12 最简单的观察者模式 发布于:2020-07-29 13:52 前端面试题(社招) 发布于:2020-08-07 14:47 第 153 题:实现一个批量请求函数 multiR... 发布于:2020-07-29 11:25 阿巴巴巴把阿布 发布于:2020-07-28 17:05 改进版点赞 发布于:2020-08-06 20:26 数组根据pid转为树形结构的数组 发布于:2020-07-28 11:50 js测试代码 发布于:2020-07-27 21:46 模板字符串:标签模板 发布于:2020-07-27 19:38 promise的简单实现 发布于:2020-07-27 18:40 事件循环判断输出,重点async await pr... 发布于:2020-07-27 18:55 利用 Proxy 包裹对象 发布于:2020-07-29 13:53 手写bind 发布于:2020-07-27 17:39 nodejssd 发布于:2020-07-27 16:35 手写call apply 发布于:2020-07-27 16:22 二叉搜索树的创建,插入,遍历 发布于:2020-07-27 10:58 NFE其实就简单两条规则,1.只能在函数体内访问,... 发布于:2020-07-27 13:52 手写makeIterator遍历器 发布于:2020-07-25 17:33 ewesdf 发布于:2020-07-31 11:19 test is 发布于:2020-07-24 22:34 二叉树的层序遍历 发布于:2020-07-24 19:51 数组key第一个转为大写 发布于:2020-07-24 16:57 [更多]
显示目录

函数

Node.js 函数

在JavaScript中,一个函数可以作为另一个函数接收一个参数。我们可以先定义一个函数,然后传递,也可以在传递参数的地方直接定义函数。

Node.js中函数的使用与Javascript类似,举例来说,你可以这样做:

`function say(word) {
  console.log(word);
}

function execute(someFunction, value) {
  someFunction(value);
}

execute(say, "Hello");`

以上代码中,我们把 say 函数作为execute函数的第一个变量进行了传递。这里返回的不是 say 的返回值,而是 say 本身!

这样一来, say 就变成了execute 中的本地变量 someFunction ,execute可以通过调用 someFunction() (带括号的形式)来使用 say 函数。

当然,因为 say 有一个变量, execute 在调用 someFunction 时可以传递这样一个变量。


匿名函数

我们可以把一个函数作为变量传递。但是我们不一定要绕这个"先定义,再传递"的圈子,我们可以直接在另一个函数的括号中定义和传递这个函数:

`function execute(someFunction, value) {
  someFunction(value);
}

execute(function(word){ console.log(word) }, "Hello");`

我们在 execute 接受第一个参数的地方直接定义了我们准备传递给 execute 的函数。

用这种方式,我们甚至不用给这个函数起名字,这也是为什么它被叫做匿名函数 。


函数传递是如何让HTTP服务器工作的

带着这些知识,我们再来看看我们简约而不简单的HTTP服务器:

`var http = require("http");

http.createServer(function(request, response) {
  response.writeHead(200, {"Content-Type": "text/plain"});
  response.write("Hello World");
  response.end();
}).listen(8888);`

现在它看上去应该清晰了很多:我们向 createServer 函数传递了一个匿名函数。

用这样的代码也可以达到同样的目的:

`var http = require("http");

function onRequest(request, response) {
  response.writeHead(200, {"Content-Type": "text/plain"});
  response.write("Hello World");
  response.end();
}

http.createServer(onRequest).listen(8888);`
由JSRUN为你提供的Node.js在线工具
        JSRUN提供的Node.js在线运行,Node.js 在线编译工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。

title

使用此草稿 删除草稿