Node.js
新闻
nw.js 前端开发桌面应用
内容
node.js实战 照例提供百度云链接,本来以为是实战系列的那本,但不是,不过这本也不错
链接:https://pan.baidu.com/s/1HC2Vhv2EwnYJs0htDTpQTg
提取码:wws9
菜鸟教程至事件循环
随手笔记
Node核心技术
告诉Node去做某件事情,并且完成后告诉node传送给谁
第一个应用
var http = require('http');
http.createServer(function (request, response) {
// 发送 HTTP 头部
// HTTP 状态值: 200 : OK
// 内容类型: text/plain 还有application/json这个
response.writeHead(200, {'Content-Type': 'text/plain'});
// 发送响应数据 "Hello World"
response.end('Hello World\n');
}).listen(8888);
// 终端打印如下信息
console.log('Server running at http://127.0.0.1:8888/');
类的定义
function shape() {
this.x=0;
this.y=0;
this.move=function (x,y) {
this.x=x;
this.y=y;
}
this.distance=function () {
return Math.sqrt(this.x*this.x+this.y*this.y);
}
}
var s=new shape();
s.move(10,10);
console.log(s.distance());
使用原型添加类的对象
function shape() {}
shape.prototype.x=0;
shape.prototype.y=0;
shape.prototype.move=function (x,y) {
this.x=x;
this.y=y;
}
shape.prototype.distance=function () {
return Math.sqrt(this.x*this.x+this.y*this.y);
}
var s=new shape();
s.move(10,10);
console.log(s.distance());
console
warn 打印标准错误
time 标准时间戳
timeEnd time之后又过了多长时间
assert 又抛出了异常
//延时
console.log('start');
setTimeout(function () {
console.log('i have done my work');
},2000)//2000就是两秒
//异步读文件
var fs=require('fs');
fs.open(
'gou.txt','r',
function (err,handle) {
if(err){
console.log("Error"+err.code+"("+err.message+")");
return;//注意报了错之后要返回
}
var buf=new Buffer(100000);
fs.read(
handle,buf,0,100000,null,
function(err,length){
if(err){
console.log("Error"+err.code+"("+err.message+")");
return ;
}
console.log(buf.toString('utf-8',0,length));
fs.close(handle,function(){})
}
)
}
)
//输完所有的参数后,要有一个function(err,什么参数),if(err)怎么样,之后再有一个处理
var fs=require('fs');
function FileObject() {
this.filename="";
this.file_exists=function (callback) {
var me=this;//异步回调插入事件队列后,执行完返回不再有FileObject的继承关系了,要有重新的this指针,用一个变量代替this,可以使this保留下来
console.log('try to open',me.filename);
fs.open(this.filename,'r',function (err,handle) {
if(err){
console.log(err.stack);
}
fs.close(handle,function () {
});
callback(null,true);
});
}
};
var fo=new FileObject();
fo.filename='ou.txt';
fo.file_exists(function (err,results) {
if(err)
{
console.log('oh! xiba!'+err.stack);
}
console.log('file exits!');
});
err
值为null,表示操作成功,并且会有一个返回值
值为一个Error对象的实例,偶尔会看到不一致的地方
callback(null,a)//没有错误,把a的值送回去
回调函数
大多数回调函数在所有项加载完后就调用这个函数,该回调函数拥有回调都有的原型,一个err参数和result参数
process.nextTick
我放弃主动权,你可以在你空闲的时候执行我给你提供的函数,每隔一段时间就处理一次其他任务
打造服务器
var http=require('http');
function f(req,res) {
de(req.method);
res.writeHead(200,{"Content-Type":"application/app"});
res.end(JSON.stringify({error:null})+'\n');//选中后会下载一个文件
}
var s=http.createServer(f);//把处理函数作为参数传进去
s.listen(8080);
//一个查看本地照片目录的应用
var http=require('http');
var fs=require('fs');
function f(callback) {
fs.readdir(
"img",
function (err,files) {
if(err){
callback(err);//第一个参数喂err,第二个参数不用你管了
return ;
}
callback(null,files);//没有错误,带回文件
}
);
}
function g(req,res) {
de(req.method);
f(function (err,albums) {
if(err){
res.writeHead(503,{'Content-Type':'application/json'});//就相当于错误404
res.end(JSON.stringify(err)+'\n');
}
var out={
error:null,
data:{albums:albums}
};
res.writeHead(200,{"Content-Type":"application/json"});
res.end(JSON.stringify(out)+'\n');//把输出json化,别忘了带一个回车
});
}
var s=http.createServer(g);
s.listen(8080);
//{"error":null,"data":{"albums":["1.jpg","2.jpg","3.jpg","4.jpg","5.jpg"]}}
事件循环
//readFileSync是同步的,后面不能加回调函数,去掉Sync即可回调
//应该先on好处理器,再emit信号
// 引入 events 模块
var events = require('events');
// 创建 eventEmitter 对象
var eventEmitter = new events.EventEmitter();
// 创建事件处理程序
var connectHandler = function connected() {
console.log('连接成功。');
// 触发 data_received 事件
eventEmitter.emit('data_received');
}
// 绑定 connection 事件处理程序
eventEmitter.on('connection', connectHandler);
// 使用匿名函数绑定 data_received 事件
eventEmitter.on('data_received', function(){
console.log('数据接收成功。');
});
// 触发 connection 事件
eventEmitter.emit('connection');
console.log("程序执行完毕。");
node学习笔记(一)本地文件目录查看器的更多相关文章
-
微信小程序开发:学习笔记[9]——本地数据缓存
微信小程序开发:学习笔记[9]——本地数据缓存 快速开始 说明 本地数据缓存是小程序存储在当前设备上硬盘上的数据,本地数据缓存有非常多的用途,我们可以利用本地数据缓存来存储用户在小程序上产生的操作,在 ...
-
JVM学习笔记-第三章-垃圾收集器与内存分配策略
JVM学习笔记-第三章-垃圾收集器与内存分配策略 tips:对于3.4之前的章节可见博客:https://blog.csdn.net/sanhewuyang/article/details/95380 ...
-
Docker技术入门与实战 第二版-学习笔记-8-网络功能network-3-容器访问控制和自定义网桥
1)容器访问控制 容器的访问控制,主要通过 Linux 上的 iptables防火墙来进行管理和实现. iptables是 Linux 上默认的防火墙软件,在大部分发行版中都自带. 容器访问外部网络 ...
-
node学习笔记(二)(ajax方式向node后台提交数据)
通过ajax向node后台提交数据过程(附手写前后台代码),并总结post与get的区别 POST 前台代码 //CSS简单给点样式 <style> form{ width: 200px; ...
-
Hadoop-2.4.1学习之edits和fsimage查看器
在hadoop中edits和fsimage是两个至关关键的文件.当中edits负责保存自最新检查点后命名空间的变化.起着日志的作用,而fsimage则保存了最新的检查点信息.这个两个文件里的内容使用普 ...
-
node学习笔记第一天
ES6---* JavaScript语言随着使用的人越来越多,ECMA语法规范:if/else* 为了让js语言更适应大型应用的开发.旨在消除一些怪异的行为 ### 包含内容(strict严格模式)- ...
-
Go语言学习笔记——在本地建立一个官网查看
命令行内运行 godoc -http=:8080 运行完成后打开浏览器输入网址:http://localhost:8080能看到一个和官网一模一样的网站,然后查看帮助文档
-
node学习笔记
一.准备(github地址) 什么是Javascript? ... Javascript能做什么? ..... 浏览器中的Javascript可以做什么? 操作DOM(增删改查) AJAX/跨域 BO ...
-
node 学习笔记 - Modules 模块加载系统 (1)
本文同步自我的个人博客:http://www.52cik.com/2015/12/11/learn-node-modules-path.html 用了这么久的 require,但却没有系统的学习过 n ...
随机推荐
-
使用ViewPager+Fragment实现选项卡切换效果
实现效果 本实例主要实现用ViewPage和Fragment实现选项卡切换效果,选项卡个数为3个,点击选项卡或滑动屏幕会切换Fragment并实现选项卡下方下边框条跟随移动效果. 本程序用androi ...
-
alarm rtc
http://sharp2wing.iteye.com/blog/1329518 http://blog.csdn.net/sking002007/article/details/6593809 io ...
-
实战android菜单项之XML加载菜单与动态菜单项[转]
原文地址:http://blog.csdn.net/kaiwii/article/details/7767225 自定义android应用程序的菜单项首先要知道切入点.经过学习,知道主要是两个Acti ...
-
关于js的callback回调函数的理解
回调函数的处理逻辑理解:所谓的回调函数处理逻辑,其实就是先将回调函数的代码 冻结(或者理解为闲置),接着将这个回调函数的代码放到回调函数管理器的队列里面. 待回调函数被触发调用的时候,对应的回调函数的 ...
-
北京Uber优步司机奖励政策(12月3日)
用户组:人民优步(适用于12月3日) 滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://w ...
-
get方式中文乱码问题
<a target="_blank" href="ftpFileAction!downloadFile.action?filename=测试.xml"&g ...
-
JAVA内存模型与线程
概述 由于计算机的运算速度和它的存储和通讯子系统的速度差距巨大,大部分时间都花在IO,网络和数据库上.为了压榨CPU的运算能力,需要并发.另外,优秀的并发程序对于提高服务器的TPS有重要的意义. 硬件 ...
-
因为网络安全的重要性打算学习linux
互联网的普及,在给人们带来巨大便利的同时,也让人们感受到网络安全隐患带给人们的不安与威胁.尤其是随着计算机技术和网络技术应用范围的不断扩充,网络安全方面存在的漏洞也越来越多,在这种情况下,如何提高网络 ...
-
『PyTorch』第一弹_静动态图构建if逻辑对比
对比TensorFlow和Pytorch的动静态图构建上的差异 静态图框架设计好了不能够修改,且定义静态图时需要使用新的特殊语法,这也意味着图设定时无法使用if.while.for-loop等结构,而 ...
-
linux中使用locate搜索文件方法记录
在linux中,有时用apt或者yum等软件包管理工具直接安装软件的时候,不知道软件到底安装到哪里去了,配置文件放哪里?这个时候就可以使用搜索命令locate来找到这些文件.海词上locate翻译为找 ...