一、模块系统

1.创建模块和引用模块

//如何创建一个模块

exports.hello = function(){
console.log('hello worl');
}; //这创建了一个模块
//如何引用模块

  //1.require();
var hello = require('./module.js'); hello.hello(); //2. var {hello} = require('./module.js'); hello();

2.服务端的模块

//服务端的模块
var http = require('http'); http.createServer(function(request,response){ }); //http 模块放在哪里的呢? 模块的加载顺序又是什么样的呢? /*
* 1. 当require(); 一个模块的时候 首先会去 文件模块缓冲区去找
* 如果存在,直接exports出来
* 2.如果没有找到,在去原生模块缓冲区去找 => 原生模块 => 缓存 => exports
*
* 3.没有找到就去文件系统
*
*/

二、函数

//其实就javascript中的函数。
var lan = function(lang){
console.log(lang);
} function say(factory,lang){
factory(lang);
} say(lan,'chinese'); var http = require('http'); http.createServer(function(request,response){
response.writeHead(200,{'Content-Type':'text/plain;charset=utf8'});
response.write('hello world');
response.end();
}).listen(3000);

三、路由

var http = require('http');
var url = require('url'); http.createServer(function(request,response){
var pathname = url.parse(request.url,true).pathname;
//http://localhost:8080/user
console.log(pathname);
//pathname /user /*
http://localhost:8080/admin pathname => /admin */
response.writeHead(200,{'Content-Type':'text/plain;charset=utf8'});
response.write('这个路径是:' + pathname); response.end(); }).listen(8080);

四、全局对象

1.在 node中有一个全局对象为global。所有的全局对象都可以在global找到。当然不包括他自己。而在浏览器中的全局对象为window

2.__filename  表示当前正在执行的脚本的文件名。它将输出这个文件的绝对路径

3.__dirname 表示当前正在执行脚本的目录

4.setTimeout  => clearTimeout   ||    setInterval  =>  clearInterval

5.console =>  api较多

6.process 方法较多。 主要描述node 的进程情况

五、GET、POST请求。

1.GET请求(其实就是参数带在url上吧)

var http = require('http');
var url = require('url');
var fs = require('fs'); var data = ''; var readStream = fs.createReadStream('get.html'); readStream.on('data',function(chunk){
data += chunk;
}); readStream.on('end',function(){
console.log('获取html完毕');
}); http.createServer(function(request,response){
var params = url.parse(request.url,true).query;
var userName = params.userName;
var userPhone = params.userPhone;
//http://localhost:8888/get.js?userName=node&userPhone=10086 console.log(userName,userPhone);// node 10086
response.writeHead(200,{'Content-Type':'text/html;charset=utf8'});
if(!!userPhone && !!userName){
response.write('<h1>保存成功</h1>')
}else{
response.write(data);
};
response.end();
}).listen(8888); console.log('node server start 127.0.0.1:8888')
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="./get.js" method="GET">
<input type="text" name="userName">
<input type="text" name="userPhone">
<input type="submit" value="提交">
</form>
</body>
</html>

2.POST请求 (参数没有暴露在url上获取参数的方式和GET有很大的区别);

var http = require('http');
var querystring = require('querystring');
var fs = require('fs'); var data = ''; var readStream = fs.createReadStream('post.html'); readStream.on('data',function(chunk){
data += chunk;
}); readStream.on('end',function(){
console.log('获取html完毕');
}); http.createServer(function(request,response){
var postData = ''; request.on('data',function(chunk){
postData += chunk;
});
request.on('end',function(){
var params = querystring.parse(postData);
console.log(postData);
var userName = params.userName;
var userPhone = params.userPhone;
//http://localhost:8888/post.js console.log(userName,userPhone);// node 119
response.writeHead(200,{'Content-Type':'text/html;charset=utf8'});
if(!!userPhone && !!userName){
response.write('<h1>保存成功</h1>')
}else{
response.write(data);
};
response.end();
}); }).listen(8888); console.log('node server start 127.0.0.1:8888')

post.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="./post.js" method="POST">
<input type="text" name="userName">
<input type="text" name="userPhone">
<input type="submit" value="提交">
</form>
</body>
</html>

六、结束语

Node.js的入门教程就完毕了。写得比较简洁,也没有贴图。我觉得作为一个程序员。学习能力固然重要,但更重要的是动手能力。每个方法都去敲一遍了,自然就明白这个方法

有什么用了。没有什么东西去敲一遍解决不了的,如果非要说有那就多敲2遍。

Node.js的基础知识很多,这2篇博文的挑了些,比较重要的说了下。其中主要是文件系统,文件流,路由,GET\POST。模块知识在工作中会经常遇到。当然在实际项目会用不到这些,因为都会借助express框架。来进行项目开发。但当我们了解其原理。操作起来就根据得心应手了。

没有什么坎坷是过不去的,加油!Comm on!

node入门学习(二)的更多相关文章

  1. ReactJS入门学习二

    ReactJS入门学习二 阅读目录 React的背景和基本原理 理解React.render() 什么是JSX? 为什么要使用JSX? JSX的语法 如何在JSX中如何使用事件 如何在JSX中如何使用 ...

  2. SpringMVC入门学习(二)

    SpringMVC入门学习(二) ssm框架 springMVC  在上一篇博客中,我简单介绍了一下SpringMVC的环境配置,和简单的使用,今天我们将进一步的学习下Springmvc的操作. mo ...

  3. node入门学习(一)

    一.安装node.js 方式很多npm,git等,新手建议从官网上直接去下载node的安装包.一键安装. 二.创建一个web服务器. const http = require('http'); htt ...

  4. git入门学习(二):新建分支/上传代码/删除分支

    一.git新建分支,上传代码到新的不同分支  我要实现的效果,即是多个内容的平行分支:这样做的主要目的是方便统一管理属于同一个内容的不同的项目,互不干扰.如图所示: 前提是我的github上已经有we ...

  5. Egg入门学习(二)---理解service作用

    在上一篇文章 Egg入门学习一 中,我们简单的了解了Egg是什么东西,且能做什么,这篇文章我们首先来看看官网对Egg的整个框架的约定如下,及约定对应的目录是做什么的,来有个简单的理解,注意:我也是按照 ...

  6. node入门(二)——gulpfile.js初探

    本文关于gulpfile.js怎么写,利于完成个性化需求.本文开发环境默认已安装node,详情参考<node入门(一)——安装>. 一.安装gulp npm install -g gulp ...

  7. dubbo入门学习(二)-----dubbo hello world

    一.dubbo hello world入门示例 1.提出需求 某个电商系统,订单服务需要调用用户服务获取某个用户的所有地址: 我们现在需要创建两个服务模块进行测试: 模块 功能 订单服务web模块 创 ...

  8. iOS中 Swift初级入门学习(二)

    // Copyright (c) 2015年 韩俊强. All rights reserved. // import Foundation /* // 控制语句 // for - in // 遍历字符 ...

  9. node.js学习二---------------------同步API和异步API的区别

    /** * node.js大部分api都有同步的方法,同步方法名后面都会带有Sync,js编译的时候,同步代码会立即执行,异步代码会先存到异步池中,等同步代码执行完后它才会执行异步:不会阻塞线程,没有 ...

随机推荐

  1. bzoj1294 [SCOI2009]围豆豆

    Description Input 第一行两个整数N和M,为矩阵的边长. 第二行一个整数D,为豆子的总个数. 第三行包含D个整数V1到VD,分别为每颗豆子的分值. 接着N行有一个N×M的字符矩阵来描述 ...

  2. django学习笔记(2)

    Part 2: The admin site ====> Creating an admin user$ python manage.py createsuperuser   Username: ...

  3. 3、计数排序,电影top100

    1.计数排序 # -*- coding: utf-8 -*- # @Time : 2018/07/31 0031 11:32 # @Author : Venicid def count_sort(li ...

  4. 【AHOI2006】基因匹配

    题面 题解 众所周知,最长公共子序列的$dp$是$\text{O}(n^2)$, 但是每一个数字只重复$5$遍,那么我们暴力匹配$25n$个点对 那么我们就可以将其变成求最长上升子序列 用二分栈或者树 ...

  5. P2939 [USACO09FEB]改造路Revamping Trails

    P2939 [USACO09FEB]改造路Revamping Trails 同bzoj2763.不过dbzoj太慢了,bzoj又交不了. 裸的分层图最短路. f[i][j]表示免费走了j条路到达i的最 ...

  6. ARP 地址分类 NAT技术

    第1章 OSI回顾 1.1 TCP/IP协议族组成 应用层 主机到主机层   互联网层   网络接入层 1.2 总结应用层掌握的协议与端口号对应关系 http(80) telnet(23) ftp(2 ...

  7. STM8S——Flash program memory and data EEPROM

    1.简介 STM8S内部的FLASH程序存储器和数据EEPROM是由一组通用寄存器来控制的:所以我们可以通过这些通用寄存器来编程或擦除存储器的内容.设置写保护.或者配置特定的低功耗模式.我们也可以自己 ...

  8. 分享一个DataTable转List强类型的类库

    类库扩展自Datatable,可以直接用Datatable.ToList<T>()进行转换.为了方便把DataReader装入Datatable,开扩展了一个LoadForReader(t ...

  9. Pyhton配置CGI

    目录 CGI配置(Mac版) 添加CGI python文件测试 CGI--common gateway interface 通用网关接口的意思,本文通过python的CGI来整体了解下CGI的配置和使 ...

  10. lua栈

    既然Lua虚拟机模拟的是CPU的运作,那么Lua栈模拟的就是内存的角色.在Lua内部,参数的传递是通过Lua栈,同时Lua与C等外部进行交互的时候也是使用的栈.,先关注的是Lua栈的分配,管理和相关的 ...