NodeJS基础入门
1.前端最主流的JavaScript运行环境
1>Node.js是一个基于Chrome V8引擎的JavaScript运行环境。
2>Node.js使用了一个事件驱动、非阻塞式I/O的模型,使其轻量又高效。
3>Node.js的包管理器npm,是全球最大的开源库生态系统。
2.工作原理
V8引擎
模块
事件队列
文件系统
...
3.V8引擎
引擎:电脑根本不识别也不理解JavaScript,JS引擎的作用是使电脑能够识别JS代码
NodeJS是使用C++写的
V8引擎是Node.js的核心
V8引擎的作用就是让JS代码能够被电脑识别
4.Module & Require
```
stuff.js
var adder = function(a,b){
var result = `结果是:${ a + b }`;
return result;
}
var PI = 3.14;
module.exports = {
adder: adder,
PI: PI
}
main.js
var stuff = require("./stuff");
stuff.adder(10,stuff.PI);
```
5.事件模块 Events
1>大多数Node.js核心API都是采用惯用的异步事件驱动架构(fs/http)
2>所有能触发事件的对象都是EventEmitter类的实例
3>事件流程:引入模块——创建EventEmitter对象——注册事件——触发事件
```
eg:
const EventEmitter = require("events"); //引入事件模块
class MyEmitter extends EventEmitter{}; //创建EventEmitter对象
const myEmitter = new MyEmitter();
//var myEmitter = events.EventEmitter();
myEmitter.on("someEvent",(msg)=>{ //注册事件
setImmediate(function(){ //IE,把一个需要长时间运行的操作放在一个回调函数里,在浏览器完成后面的其他语句后,就立即执行这个回调函数
console.log(msg);
});
});
myEmitter.emit("someEvent","实现事件并传递此参数到注册事件的回调函数中"); //触发事件
```
6.文件系统
读取文件 fs.readFile
写入文件 fs.writeFile
流程:引入fs模块——调用方法——异常捕获
```
eg: var fs = require("fs");
var readMe = fs.readFileSync("readMe.txt","utf8"); //同步读取文件
fs.writeFileSync("writeMe.txt",readMe); //同步写入
fs.readFile("readMe.txt","utf8",function(err,data){ //异步读取文件
if(err){
throw err;
}
console.log(data);
fs.writeFile("writeMe2.txt",data); //异步写入
})
const fs = require("fs");
//删除文件
fs.unlink("writeMe2.txt",function(err){
if(err){
throw err;
}
console.log("文件删除成功");
});
//创建文件夹同步
fs.mkdirSync("stuff");
//删除文件夹 同步
fs.rmdirSync("stuff");
//异步创建文件夹
fs.mkdir("stuff",function(){
fs.readFile("readMe.txt","utf8",function(err,data){
if(err){
throw err;
}
fs.writeFile("./stuff/writeMe.txt",data);
})
})
//异步删除文件夹——先删除文件,再删除外部文件夹
fs.unlink("./stuff/writeMe.txt",function(){
fs.rmdir("stuff",function(err){
if(err){
throw err;
}
console.log("文件夹删除成功");
});
});
```
7.Http创建服务器
通过Http模块搭建本地服务器
```
const http = require("http");
//创建本地服务器
var srv = http.createServer((req,res)=>{
res.writeHead(200,{"Content-Type":"text/plain"});
res.end("Server is working!");
});
//监听本地端口
srv.listen(8888,"127.0.0.1",()=>{
});
srv.on("upgrade",(req,socket,head)=>{
socket.write('HTTP/1.1 101 Web Socket 协议握手\r\n' +
'升级:WebSocket\r\n' +
'连接:升级\r\n' +
'\r\n'
);
socket.pipe(socket);
});
```
8.缓存区 & 流
缓存区:Buffer,可以在TCP流和文件系统操作等场景中处理二进制数据流。
Buffer,全局对象,无需单独引入。
流:Stream, NodeJS中处理流数据的抽象接口
1>读写数据流
```
const fs = require("fs");
//读取文件流
var myReadStream = fs.createReadStream(__dirname + "/readMe.txt","utf8");
//后台服务器自动触发
myReadStream.on("data",function(chunk){
console.log("=======正在接收一部分数据======");
console.log(chunk);
});
//写入文件流
var myWriteStream = fs.createWriteStream(__dirname + "/writeMe.txt");
var time = 0;
myReadStream.on("data",function(chunk){
time++;
console.log("=======正在接收" + time + "一部分数据======");
myWriteStream.write(chunk);
});
//输出到浏览器
var http = require("http");
var fs = require("fs");
var server = http.createServer(function(req,res){
if(req.url != "/favicon.ico"){ //防止发送favicon的请求
res.writeHead(200,{"Content-type":"text/html"});
var myReadStream = fs.createReadStream(__dirname + "/index.html","utf8");
}
});
server.listen(3000,"127.0.0.1");
console.log("Server is running ...");
```
2>读取HTML & JSON
```
res.writeHead(200,{"Content-type":"text/plain"});
res.writeHead(200,{"Content-type":"text/html"});
res.writeHead(200,{"Content-type":"application/json"});
```
9.路由Route
```
var http = require("http");
var fs = require("fs");
var server = http.createServer(function(req,res){
if(req.url !== "/favicon.ico"){
//判断用户所访问的页面地址
if(req.url == "/home" || req.url == "/"){
res.writeHead(200,{"Content-type":"text/html"});
fs.createReadStream(__dirname + "/index.html").pipe(res);
}else if(req.url == "/contact"){
res.writeHead(200,{"Content-type":"text/html"});
fs.createReadStream(__dirname + "/contact.html").pipe(res);
}else if(req.url == "/api/docs"){
var data = [{name:"Henny",age:"30"},{name:"Jack",age:"28"}];
res.writeHead(200,{"Content-type":"application/json"});
res.end(JSON.stringify(data));
}
}
});
```
10.NPM
Node Package Manager
Package.json
用于定义项目中所需要的各种模块,以及项目的配置信息(比如版本名称、版本、许可证等元数据)
npm install ** -g
npm install ** --save
npm install ** --save -dev
npm uninstall **
11.Express框架和nodemon
Express框架
已经封装好服务器
已经封装好路由
已经封装好中间件
已经封装好网络请求...
NPM安装Express框架——引入Express模块——实例化Express的对象——通过对象调用各种方法
```
//引入express模块
var express = require("express");
//实例化express对象
var app = express();
//通过对象调用对应的方法
app.get("/",function(req,res){
console.log(req.url);
res.send("This is home page!");
res.sendFile(__dirname + "/index.html");
});
app.get("/contact",function(){
console.log(req.url);
res.send("This is contact page!");
});
//路由参数
app.get("/profile/:id",function(req,res){
res.send("您所访问的路径参数为:" + req.params.id);
});
//监听服务器端口号
app.listen(8888);
```
12.EJS模板引擎
特点:
快速编译和渲染
简单的模板标签
支持浏览器端和服务器端
支持express视图系统
```
npm install ejs --save -dev
//引入express模块
var express = require("express");
//实例化express对象
var app = express();
//配置视图引擎为EJS
app.set("view engine","ejs");
//通过对象调用对应的方法(响应html文件)
app.get("/",function(req,res){
console.log(req.url);
res.sendFile(__dirname + "/index.html");
});
//返回ejs文件用render而非sendFile
app.get("/contact",function(){
console.log(req.url);
res.render(__dirname + "/contact.html");
});
//路由参数
app.get("/profile/:id",function(req,res){
res.render("profile",{ websiteName:"hello world!" }); //自动找到views下的profile.ejs
});
app.get("/profile/:id",function(req,res){
var data = {age:29,name:"Henry"};
//var data = [{age:29,name:"Henry"},{age:30,name:"Jack"}]
res.render("profile",{ websiteName:req.params.id },data:data); //自动找到views下的profile.ejs
});
//监听服务器端口号
app.listen(8888);
views/profile.ejs
<h1>EJS模板:Welcome To <%= websiteName %> page! </h1>
<p><strong>Name:</strong> <%= data.name %></p>
<p><strong>Age:</strong> <%= data.age %></p>
<ul>
<% data.forEach(function(item){ %>
<li><%= item %></li>
<% })%>
</ul>
```
13.公共模板
使用EJS替代HTML(根据模板引擎确定)
创建导航(公共模板)
解决外部样式不可用的问题(外部样式表无法在服务中运行)
```
public/nav.ejs (模板文件只能有一个根标签)
<nav>
<ul>
<li><a href="/">主页</a></li>
<li><a href="/contact">联系</a></li>
</ul>
<nav>
views/contact.ejs
<body>
<% include ../public/nav.ejs %>
<h1>Welcome to 联系我们页面!</h1>
<p>电话:40080000</p>
</body>
//让服务器识别外部样式表(使用use中间件)
app.use("/assets",express.static("assets"));
```
NodeJS基础入门的更多相关文章
- 02 nodejs命令参数(NodeJS基础入门)
声明:本文章可供有一定js基础的朋友参考nodejs入门,本文未讲解nodejs的安装,如有需要的同学可以加QQ3382260752找我,进行交流学习. 建议使用开发软件:webstorm或hbuil ...
- 边走边学Nodejs (基础入门篇)
1.什么是Node.js Nodejs ,或者node, 是一个基于ChromeJavaScript执行时建立的平台.用于方便地搭建响应速度快.易于扩展的网络应用.Node.js 使用事件驱动, 非堵 ...
- NodeJS基础入门-fs文件系统
文件I/O是由简单封装的标准POSIX函数提供.通过require('fs') 使用该模块.所有的方法都有异步和同步的形式. 异步方法的最后一个参数都是一个回调函数.传给回调函数的参数取决于具体方法, ...
- NodeJS基础入门-Event
大多数Node.js核心API都采用惯用的异步事件驱动架构,其中某些类型的对象(触发器)会周期性地触发命名事件来调用函数对象(监听器). 例如,net.Server对象会在每次有新连接时触发事件;fs ...
- NodeJS基础入门-Buffer
Buffer.byteLength console.log(Buffer.byteLength('test')); console.log(Buffer.byteLength('我是C语言爱好者')) ...
- Mongoose基础入门
前面的话 Mongoose是在node.js异步环境下对mongodb进行便捷操作的对象模型工具.本文将详细介绍如何使用Mongoose来操作MongoDB NodeJS驱动 在介绍Mongoose之 ...
- Elasticsearch 基础入门
原文地址:Elasticsearch 基础入门 博客地址:http://www.extlight.com 一.什么是 ElasticSearch ElasticSearch是一个基于 Lucene 的 ...
- nodejs 基础篇整合
nodeJs 基础篇整合 最近有朋友也想学习nodeJs相关方面的知识,如果你是后端想接近前端,node作为一门跑在服务端的JS语言从这里入门再好不过了.如果你正好喜欢前端,想走的更高,走的更远.no ...
- ECMAScript 6.0基础入门教程
ECMAScript 6.0基础入门教程 转:https://blog.csdn.net/hexinyu_1022/article/details/80778727 https://blog.csdn ...
随机推荐
- Unity 组件.name
组件.name 指的是组件所在游戏对象的名字,例如: Animation m_animation; m_animation =GetComponent<Animation>(); m_a ...
- 案例52-crm练习新增客户中加入文件上传功能(struts2文件上传)
1 jsp/customer/add.jsp 完整代码: <%@ page language="java" contentType="text/html; char ...
- static 和 final 和 static final
众所周知,static 是静态修饰关键字:可以修饰变量,程序块,方法,类. 1.修饰变量. 得知:如果static修饰的是变量,则JVM会将将其分配在内存堆上,该变量就与对象无关,所有对该变量的引用都 ...
- etc
小小的注意点们 交换两个变量的值时, 如果使用异或运算符, 需要先判断两个数是否相等 if (a == b) return; a ^= b; b = a ^ b; a ^= b; 取一个数组的中间位置 ...
- join() 和 sleep() 区别
来源于<Java多线程编程核心技术> 一.join() 作用 在很多情况,主线程创建并启动子线程,如果子线程中需要进行大量的耗时计算,主线程往往早于子线程结束.这时,如果主线程想等待子线程 ...
- Slickflow.NET 开源工作流引擎基础介绍-.NET Core2.0 版本实现介绍 (转)
前言:.NET Core 是.NET Framework的新一代版本,是微软开发的第一个跨平台 (Windows.Mac OSX.Linux) 的应用程序开发框架(Application Framew ...
- 【小程序报错】 TLS 版本必须大于等于 1.2
服务器是windows 2008 server 环境是IIS7SSL是申请用的阿里免费.微信小程序发现wx.request,调试报错: 小程序要求的 TLS 版本必须大于等于 1.2 直接说解决办法吧 ...
- better-scroll 遇到的问题 3 (transition-group 相关)
今天在使用vue动画 transition-group 和 better-scroll 的时候,出现了下拉列表不能滚动的问题. 问题描述: 我写了一个scroll的基础组件,组件接受一个data参数, ...
- Touch事件传递的实验
通过自定义的Relayout LinearLayout TextView , 布局为: 分别打印事件方法: 1.当所有的都是super的时候,点击TextView的时候,事件的传递是: ...
- nginx-1.12.2编译安装指导
nginx-1.12.2编译安装 下载源码包 安装 安装后配置 下载源码包 下载地址:http://nginx.org/en/download.html nginx-1.12.2:http://ngi ...