一、前言                                                                                                                                                                                                                          Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。 Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。node.js现在已经成为前端工程师的必备技能。

本节涉及的基础内容:

                               

                              1. node中的javascript

                               2.http服务能力

                               3.文件操作能力

                               

一、知识

      1、打开cmd窗口的三种方式

方式一:传统的cmd   cd到我们要操作的目录

方式二:shift + 鼠标右键,选择快速打开窗口命令

方式三:如果你的电脑装了git  选中要操作的项目 --》右击--》git bash here

     2、使用node来解析和执行文件

第一步:用编辑器建立脚本文件

第二步:使用上面的方式定义到项目目录

第三步:在cmd框中输入  node  + project.js 执行node文件(这里的文件名不能起做node.js,最好不要含有中文)

     3、node.js中的javascript

(1)node中没有BOM、DOM

验证:在你的工程目录下新建js文件---》打开当前的命令提示框---》执行node 文件 ,说明node里面并没有BOM、DOM

console.log(document);
console.log(window)

(2)node中包含一些基本的EcmaScript基本的语言

比如:变量,方法,数据类型,内置对象,Array, Object, Date, 等

可以参考:http://www.w3school.com.cn/js/index.asp

(3)一些核心模块如:FS(文件操作)

4、node中的文件操作能力

在node中如果想要对文件进行操作就必须引入FS核心模块,核心模块中提供了文件操作相关的API

读取文件:readFile(第一个参数,第二个参数)   第一个参数:是读取的文件路径  ,第二个参数:是一个回调函数

在目录下建一个文本文件和一个js文件

1)

2)

//第一步:用require来加载核心模块
var fs=require('fs');
//第二步:调用这个API
fs.readFile('hello.txt',function(error,data){
console.log(error); //读取成功返回null,
console.log(data);
})

3)执行文件

我们发现当读取成功的时候,error返回的是null   data中返回的是用十六进制输出的数据,为什么是十六进制的数据呢?是因为计算机只认识二进制的,但是没有找到二进制数据,就将我们的文本内容转化为16进制

接下来:用toString()来转化

//第一步:用require来加载核心模块
var fs=require('fs');
//第二步:调用这个API
fs.readFile('hello.txt',function(error,data){ if(error){
console.log('读取失败');
}else{
console.log(data.toString());
}
})

小提示:如果发现命令提示符输出的中文为乱码,可以百度搜索解决  https://jingyan.baidu.com/article/fcb5aff775f3e3edaa4a71dd.html

写入文件:fs.writeFile(第一个参数,第二个参数,第三个参数)  第一个参数:为文件路径,第二个参数为:文件内容,第三个参数为回调函数function(error){}

//第一步:用require引入fs模块
var fs =require('fs');
//第二步:用上面的对象调用API
fs.writeFile('./hellonode.txt','想要学好node',function(error){ if(error){
console.log('写入失败');
}else{
console.log('写入成功');
}
});

 小提示:平时我们保存文件的时候,文件的命名不能有特殊的符号,比如:* / ?之类的

5、node中的http服务

(1) 先了解几个概念:

端口号:是用来定位对应的具体程序的,所有需要联网通信的程序都要占用端口号

IP地址:是用来定位计算机的

服务器:提供对数据的服务,发请求,接受请求,给用户一些反馈

还是不理解端口号和IP作用的话引用一个前辈的图来解释:

我们在访问浏览器,用微信,QQ等软件进行通信的时候需要访问服务器,那么服务器就是通过不同软件对应的不同软件来区分接收到的是哪个应用程序的信息。然后在返回给客户端想要的信息。

并且要知道端口号和ip地址才能访问(会不会有疑问我们访问百度的时候没有带端口号呀)?

客户端的浏览器会自动开启端口号,所以只要客户端来请求,服务端就知道客户端端口号 

可以同时开启多个服务,但是一定确保不同服务占用端口号不一致

说白了,在一台计算机中,同个端口号,同一时间只能被一个程序使用

(2)使用node来轻松构建一个web服务器

//第一步:加载http核心模块
var http = require('http');
//第二步:调用createServer()方法来创建
var server=http.createServer(); //第三步:注册request事件,当客户端发过来请求之后执行回调函数,对接受的数据进行反馈
server.on('request',function(){
console.log('接受到了客户端的请求,请通过服务端http://localhost:3000访问');
});
//第四步:给我们的服务器设置一个端口号,客户端要知道这个端口号才能访问
server.listen(3000,function(){
console.log('服务启动成功了');
});

启动服务器:

之后浏览器中输入 localhost:3000访问我们的服务器,服务器接受到响应执行回调

web服务器的响应:平时我们访问百度,或者其他网站的时候,会根据输入不同的访问路径返回给客户端不同的信息,那么他们是怎么做的呢?

请求百度:

返回给我们百度首页:

如果找不到输入的路径就会反馈给我们一个错误提示页

所以我们可以知道,服务器就是看这个Request URL来区别用户查找的不同内容,并且给出不同的反馈

优化刚刚的代码,并且用write()函数让浏览器反馈

var http = require('http');
var sever=http.createServer();
sever.on('request',function(request,response){
if(request.url==='/'){
response.write('index js');
}else if(request.url==='/login'){
console.log('登录');
}else{
console.log('404 not found');
} });
sever.listen(3000,function(){ console.log('服务器已经启动');
})

下面通过不同的访问路径来访

发现上面的中文乱码了,为什么?因为服务器响应的类型只能为二进制和字符串,具体解决方法看下篇:https://www.cnblogs.com/xxm980617/p/10506183.html

一、总结

  • Node.js 中的 JavaScript

    • 没有 BOM、DOM
    • EcmaScript 基本的 JavaScript 语言部分
    • 在 Node 中为 JavaScript 提供了一些服务器级别的 API
    • 文件操作的能力
    • http 服务的能力
  • http服务:
  • require
  • 端口号
  • ip 地址定位计算机
  • 端口号定位具体的应用程序
  • Content-Type
  • 服务器最好把每次响应的数据是什么内容类型都告诉客户端,而且要正确的告诉
  • 不同的资源对应的 Content-Type 是不一样,具体参照:http://tool.oschina.net/commons
  • 对于文本类型的数据,最好都加上编码,目的是为了防止中文解析乱码问题
  • 通过网络发送文件
  • 发送的并不是文件,本质上来讲发送是文件的内容
  • 当浏览器收到服务器响应内容之后,就会根据你的 Content-Type 进行对应的解析处理

node(基础)_node中的javascript的更多相关文章

  1. node(基础)_node.js中的http服务以及模板引擎的渲染

    一.前言 本节的内容主要涉及: 1.node.js中http服务 2.node.js中fs服务 3.node.js中模板引擎的渲染 4.利用上面几点模拟apache服务器 二.知识 1.node.js ...

  2. js基础知识温习:Javascript中如何模拟私有方法

    本文涉及的主题虽然很基础,在很多人眼里属于小伎俩,但在JavaScript基础知识中属于一个综合性的话题.这里会涉及到对象属性的封装.原型.构造函数.闭包以及立即执行表达式等知识. 公有方法 公有方法 ...

  3. Node中的JavaScript和浏览器中的JavaScript的区别

    浏览器中的JavaScript: 1.基于ECMAscript规范,这个规范规定了语法 2.添加了dom:用来处理文档 document object model 3.添加了BOM:用于操作浏览器 w ...

  4. 第十一章:WEB浏览器中的javascript

    客户端javascript涵盖在本系列的第二部分第10章,主要讲解javascript是如何在web浏览器中实现的,这些章节介绍了大量的脚本宿主对象,这些对象可以表示浏览器窗口.文档树的内容.这些章节 ...

  5. node基础—概述与安装

    什么是Nodejs 简单的说 Node.js 就是运行在服务端的 JavaScrip(编写高性能网络服务器的JavaScript工具包(用js开发服务端程序))t. JS是脚本语言,脚本语言都需要一个 ...

  6. Node基础篇(概要)

    Node简介 客户端的JavaScript是怎样的 什么是 JavaScript? 脚本语言 运行在浏览器中 一般用来做客户端页面的交互(Interactive) JavaScript 的运行环境? ...

  7. java基础---->java中正则表达式二

    跟正则表达式相关的类有:Pattern.Matcher和String.今天我们就开始Java中正则表达式的学习. Pattern和Matcher的理解 一.正则表达式的使用方法 一般推荐使用的方式如下 ...

  8. jQuery-vsdoc.js文件是vs中的JavaScript intellisense,

    在VS 2008中启用jQuery Intellisense的步骤 要在VS中启用jQuery的intellisense完成,你要遵循三个步骤: 第一步: 安装VS 2008 SP1 VS 2008 ...

  9. [MSDN] 使用 SharePoint 2013 中的 JavaScript 库代码完成基本操作

    MSDN:http://msdn.microsoft.com/zh-cn/library/jj163201.aspx 了解如何编写代码以在 SharePoint 2013 中使用 JavaScript ...

随机推荐

  1. css居中小技巧

    一.行内元素-水平居中 在父元素的样式中添加: text-align:center; 二.定宽块级元素-水平居中 所谓定宽块级元素指块级元素的宽度指定,而不是默认的100%,否则此方法无效: 代码: ...

  2. 51nod1016

    1016 水仙花数 V2 1 秒 131,072 KB 160 分 6 级题   水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身.(例如:1^3 + 5^3 ...

  3. PC平台的SIMD支持检测

    如果我们希望在用SIMD来提升程序处理的性能,首先需要做的就是检测程序所运行的平台是否支持相应的SIMD扩展.平台对SIMD扩展分为两部分的支持: CPU对SIMD扩展的支持.SIMD扩展是随着CPU ...

  4. JarvisOJ Basic 美丽的实验室Logo

    出题人丢下个logo就走了,大家自己看着办吧 扔进01Editor中,发现最后有14844个不属于jpg的字节 扔进Kali中用dd命令提取出附加的文件,可以看到也是一个图片,图片上的文字即是flag

  5. 洛谷 P1441 砝码称重

    题目描述 现有n个砝码,重量分别为a1,a2,a3,……,an,在去掉m个砝码后,问最多能称量出多少不同的重量(不包括0). 输入输出格式 输入格式: 输入文件weight.in的第1行为有两个整数n ...

  6. Linux各目录及每个目录的详细介绍

    http://www.cnblogs.com/duanji/p/yueding2.html

  7. js窗体间传值

    A页面传值给 B页面 页面A <html xmlns="http://www.w3.org/1999/xhtml"> <HEAD> <TITLE> ...

  8. Codeforces1101G (Zero XOR Subset)-less 【线性基】【贪心】

    题目分析: 考虑到这是一个区间的异或问题,不妨求出前缀和,令$sum[i] = Xor_{j=1}^{i}a[j]$. 对于区间$[l,r]$的异或结果,等于$sum[r] \oplus sum[l- ...

  9. 洛谷P2085最小函数值题解

    题目 首先我们先分析一下题目范围,\(a,b,c\) 都是整数,因此我们可以得出它的函数值在\((0,+\infty )\)上是单调递增的,,然后我们可以根据函数的性质,将每个函数设置一个当前指向位置 ...

  10. wstngfw IPsec 站点到站点连接示例

    wstngfw IPsec 站点到站点连接示例 在本例中,将假设以下设置: IPsec站点设置 站点 A 站点 B 名称 Beijing Office(北京办公室) 名称 Shenzheng Offi ...