node.js 基础学习笔记1
1.
node -v 查看版本
node -e --js代码
node --进入编辑模式
Ctrl+C 退出编译模式
var http=require('http')
http.createServer(function(req,res){
res.writeHead(200,{'Content-Type':'text/html'});
res.write('<h1>Hello world</h1>');
res.end('<p>china</p>');
}).listen(3000);
将文件保存为 app.js,进入使用命令行进入app.js 所在没得目录,启动服务器。
在浏览器中输入 http://localhost:3000/,即可看到页面内容。

npm -install -supervisor -g //全局模式
2.全局对象与全局变量
所有属性都可以在程序中的任何地方访问,即全局变量。
Node.js的全局对象是global,Js中,通常window是全局对象。
global最根本的作用是作为全局变量的宿主。
满足以下条件称为全局变量。
1.在最外层定义的变量。
2.全局对象的属性。
3.隐式定义的变量(未定义直接副职的变量)
在Node.js中不可能在最外层定义变量,因为所有用户代码都是属于当前模块的,而模块本身不是最外层上下文。
因此,不提议全局变量。
3.process 用于描述当前Node.j进程状态的对象。
(1) process.argv 命令行参数数组
我们在G\nt\argv.js,
argv.js----- console.log(process.argv)
运行,输入 G:\nt>node argv.js xianrongbin liudehua
输出: [ 'node', 'G:\\nt\\argv.js', 'xianrongbin', 'liudehua' ]
(2)process.stdout 标准输出流
console.log() 底层是用process.stdout.write()实现。
(3)prcess.stdin是标准输入流,初始时它是被暂停的
process.stdin.resume();
process.stdin.on('data',function(data){
process.stdout.write('read from console======== '+data.toString());
})
运行:如果我们输入: this is node demo
则输出 rread from console====== tis is node demo
(4)process.nextTick(callback)的功能是为事件循环设置一项任务。
Node.js会在下次事件循环相应时调用callback。Node.j适合IO密集型应用,而不是计算密集型应用。
如下:
function doSomething(args,callback){
somethingComputeBefore(args);
callback();
}
doSomething('',function onEnd(){
compute();
});
假如somethingComputeBefore()与compute()是两个较为耗时的函数,调用
doSomething()先调用 somethingComputeBefore(),然后立即调用回调函数,在onEnd()中又会执行compute();
可以改下
function doSomething(args,callback){
somethingBefor(args);
process.nextTick(callback);
}
使用process.nextTick()后,改写后的程序会把上面耗时的操作拆分为两个事件,减少每个事件的执行时间。
node.js 基础学习笔记1的更多相关文章
- node.js 基础学习笔记3 -http
http模块,其中封装了一个高效的HTTP服务器和一个建议的HTTP客户端 http.server是一个基于事件的HTTP服务器 http.request则是一个HTTP客户端工具,用户向服务器发送请 ...
- node.js 基础学习笔记2
Module和Package是Node.js最重要的支柱. Node.j 提供require函数来调用其他模块,而且模块都是基于文件.模块和包区别是透明的,因此常常不作区分. 1.模块和文件一一对应. ...
- node.js 基础学习笔记3 -express
1.工作原理 当通过app.js建立的服务器时,会看到一个简单的页面.返回页面时,浏览器会向服务器发送请求.app会解析请求的路径,调用相应的逻辑,调用对应的视图模板,传递对象数值,最终生成HTML页 ...
- handlebars.js基础学习笔记
最近在帮学校做个课程网站,就有人推荐用jquery+ajax+handlebars做网站前端,刚接触发现挺高大上的,于是就把一些基础学习笔记记录下来啦. 1.引用文件: jquery.js文件下载:h ...
- 两万字Vue.js基础学习笔记
Vue.js学习笔记 目录 Vue.js学习笔记 ES6语法 1.不一样的变量声明:const和let 2.模板字符串 3.箭头函数(Arrow Functions) 4. 函数的参数默认值 5.Sp ...
- Node.js入门学习笔记(一)
先来个最常见的"Hello World!". 打开你最喜欢的编辑器(我用的是Sublime Text),创建一个helloWorld.js的文件.我们要做的就是向stdout输出& ...
- Node.js基础学习四之注册功能
前言:在Node.js学习(二)和(三)中介绍了如何在Node.js 中获取登录的用户名和密码与数据库进行验证并返回数据给客户端 需求:实现注册功能 为了区分登录和注册是两个不同的请求,在端口后面加上 ...
- 两万字Vue.js基础学习笔记(二)
Vue.js学习笔记(二) 4.模块化开发 ES6模块化的导入和导出 我们使用export指令导出了模块对外提供的接口,下面我们就可以通过import命令来加载对应的这个模块了 首先,我们需要在HTM ...
- Node.js基础学习三之登录功能
本篇介绍Node.js访问数据库并返回数据给客户端 需求基于Node.js学习(二) 数据库请下载:user.sql 1.创建user 实体类(model-user.js) function User ...
随机推荐
- 在VBA中调用winsock控件
如果系统没有Winsock控件的话,可以下载下面的控件MSWINSCK.OCX,然后将该文件复制到C:\Windows\System32目录下. 在VBE窗口中,从菜单"工具"-& ...
- ThinkPad E440 Ubuntu 13.1无线网卡 RTL8723BE 驱动解决办法总结
方法一.在使用网线链接到情况下 第一步.执行下边到命令,即从github上下载驱动程序并安装 sudo apt-get install linux-headers-generic build-esse ...
- 黄聪:基于jQuery+JSON的省市区三级地区联动
查看演示:http://www.helloweba.com/demo/cityselect/ 源码下载:http://files.cnblogs.com/files/huangcong/citysel ...
- 随机数生成器console
#include <stdio.h> #include <stdlib.h> #include <time.h> int main() { ]; ]; int i; ...
- iis 应用程序池看不到 .net framework 4.0
我的情况是,先配置了iis,然后再安装.net framework 4.0 进去设置应用程序池的时候,没有找到 .net framework 4.0 ,经过一番尝试,无效,最后无奈重启. 好了.
- OpenJudge解题经验交流
1.1编程基础之输入输出01:Hello, World! 02:输出第二个整数PS:a,b需用longint类型接收 03:对齐输出 04:输出保留3位小数的浮点数 05:输出保留12位小数的浮点数 ...
- apache 配置https
1.生成密钥# openssl genrsa 1024 > server.key这是用128位rsa算法生成密钥,并保存到server.key文件 2.生成证书请求文件# openssl req ...
- 23. Sum Root to Leaf Numbers
Sum Root to Leaf Numbers Given a binary tree containing digits from 0-9 only, each root-to-leaf path ...
- Install FFMPEG and FFMPEG-PHP in CentOS 6 with Virtualmin
Install FFMPEG and FFMPEG-PHP in CentOS 6 with Virtualmin 1 year ago - by Daniel - howto centos v ...
- pytion学习1
个人感觉学习一门新语言,简单的语法懂一点足矣.接下来就是编程.读懂别人程序的每一句,理解每一句的意义. #Filename:MyAddressBook.py import cPickle as p i ...