Node学习——开篇

前言:自从下决心转学前端以来,我的专业课java基本荒废了,所以对于后台开发的逻辑也已基本忘干净了。但是作为一名准前端程序猿,我认为还是有必要了解后端开发的,虽不必深入学习,但是能够了解项目从前端到后端的整个流程,实现简单的业务逻辑(增删改查)应该对我们大有裨益。NodeJS应该说是前端开发人员涉及后端开发的最佳选择,因为使用的是前端很熟悉的Javascript语言。

一、什么是Node.js

Node.js是一个基于V8引擎的服务器端Javascript运行环境。Javascript(简称JS,下同)从此有了开发后段应用程序的能力。

因为使用的是JS语言,所以一发布以来就受到了广大前端开发人员的喜爱。很多前端开发人员开始涉足后端开发,使用Node.js重构前端工具。

Node.js通过非阻塞I/O流、事件驱动机制展现了它超强的高并发能力。此外,Node使用的是高性能的V8引擎,提供了很多不同用途的API,采用全新的编译技术,实现了一个高性能的服务器。

二、Node.js环境安装

Node.js的环境安装十分简单,去官网 http://nodejs.org/en/ 下载稳定版本安装包,点击下一步下一步安装即可。

完成以后可以打开CMD输入node -v查看是否安装成功:

C:\Users\dawei>node -v
v6.11.1

出现node的版本号则表示安装成功。

现在我们就开始学习Nodejs。Node.js中,将很多功能划分为一个个module(模块)。Node.js中的很多功能都是通过模块来实现的。

三、http模块

HTTP模块用于创建服务器,接收和响应客户端的请求。

//1、引入http模块
var http = require(‘http‘);

//创建服务器
var server = http.createServer(function (req , res) {
    //发送HTTP头部
    //HTTP状态码:200:OK
    //设置HTTP头部,状态码是200,文件类型是html,字符集是utf-8
    res.writeHead(200,{"Content-Type":"text/html;charset=UTF-8"});

    //发送相应数据
    res.write("Hello Node.js");

    //结束处理程序,返回数据
    res.end();
});

server.listen(8080);      //监听端口

//在终端打印如下信息,提示服务器已启动
console.log("Server running at http://127.0.0.1:8080/");  

这样我们就完整的创建了一个web服务器,可以在浏览器通过http://127.0.0.1:8080访问该服务器。

回调函数中的req对象包含了客户端请求的信息,可以使用req.url属性拿到用户请求的URL地址,在后期我们就是要通过不同的URL来设计不同的路由。那么识别这个URL,就用到了URL模块。

四、URL模块

URL模块提供了几个方法用于操作url。

  • url.parse(req.url):解析url,将url地址转为url对象
  • url.format():将url对象转为url字符串,是parse方法的逆向操作
  • url.resolve(from,to) :添加或者替换路由

1、url.parse()

假设在上面的代码段中引入了url模块

url.parse(req.url)

那么将会打印如下内容
{
  protocol: null,
  slashes: null,
  auth: null,
  host: null,
  port: null,
  hostname: null,
  hash: null,
  search: null,
  query: null,
  pathname: ‘/‘,
  path: ‘/‘,
  href: ‘/‘ }
  

由于我们只是访问了根路径,所以内容基本为空,很多情况下我们需要访问详细的页面并且传递参数

http://127.0.0.1:8080/login.html?uaername=dawei&pass=123

{
  protocol: null,
  slashes: null,
  auth: null,
  host: null,
  port: null,
  hostname: null,
  hash: null,
  search: ‘?uaername=dawei&pass=123‘,
  query: ‘username=dawei&pass=123‘,
  pathname: ‘/login.html‘,
  path: ‘/login.html?uaername=dawei&pass=123‘,
  href: ‘/login.html?uaername=dawei&pass=123‘ }

可以看到,这个对象的query属性保存了我们的参数,也叫做查询字符串。pathname属性中保存了我们的访问路径。这两个属性很常用。

我们往往需要获取参数信息,在服务器端做进一步处理。在JS中我们可以使用字符串截取来获取参数,不过再这里我们可以直接给parse方法传递一个参数true来将查询字符串转为对象格式,从而很方便的获取。

url.parse(req.url,true)

{
  protocol: null,
  slashes: null,
  auth: null,
  host: null,
  port: null,
  hostname: null,
  hash: null,
  search: ‘?username=dawei&pass=123‘,
  query: { username: ‘dawei‘, pass: ‘123‘ },
  pathname: ‘/login.html‘,
  path: ‘/login.html?username=dawei&pass=123‘,
  href: ‘/login.html?username=dawei&pass=123‘ }

这样我们就可以很方便的获取参数的值。

2、url.resolve()

a、增加路由

var a = url.resolve(‘http://example.com/‘, ‘/one‘);
console.log(a);     //  http://example.com/one

b、替换路由

var b = url.resolve(‘http://example.com/one‘, ‘/two‘);
console.log(b);        //   http://example.com/two
时间: 2024-11-08 22:25:54

Node学习——开篇的相关文章

Node学习HTTP模块(HTTP 服务器与客户端)

Node学习HTTP模块(HTTP 服务器与客户端) Node.js 标准库提供了 http 模块,其中封装了一个高效的 HTTP 服务器和一个简易的HTTP 客户端.http.Server 是一个基于事件的 HTTP 服务器,它的核心由 Node.js 下层 C++部分实现,而接口由JavaScript封装,兼顾了高性能与简易性.http.request 则是一个HTTP 客户端工具,用于向 HTTP 服务器发起请求. 'http'模块提供两种使用方式: 作为服务端使用时,创建一个HTTP服务

node学习错题集

1.请求路径/favicon.ico 问题:node http.createServer()创建服务器,用户请求一次,但是服务器显示两次请求:一次为用户请求,一次请求路径为/favicon.ico ?? 代码如下: var http = require('http'); http.createServer(function(req,res){ console.log( req.url ); }).listen(8080);console.log("The server is on ...&quo

[学姿势]实验室搬砖+node学习

这周开始进行收尾工作,我当然没有进行核心技术的开发,主要负责的是对web端进行展示上的修修补补,主要包括添加VLC播放器.rtsp视频流以及一些js细节. 1.VLC 全称为Video Lan Client,此播放器支持各种格式,在平台中主要作为播放实时视频的工具.首先找到VLC的wiki,webplugin一节中有快速上手的文字,学习一些播放控制的方法.对于web端,通过html的OBJECT标签在网页中加入播放器,在target属性中写入实时监控的视频即可.其中还有一些其他参数用来控制播放.

node学习 process笔记

如果你是node大神好了可以关闭此页面了因为接下来游览会白白浪费你许多时间,最近一直学习node.js今晚看到 alsotang 在 github上的node教程 https://github.com/alsotang/node-lessons.其中有一段代码不太明白其含义process.argv[2] 具体代码如下: //当前文件main.jsvar fibonacci = function(n){ //这是一个斐波那契数列 if(n === 0 || n === 1){ return n;

node学习第三天(1)

今天学习了,node调用模块的方法 node调用模块 要调用模块的js 1 var http = require("http"); 2 3 var Teacher = require("./Teacher"); 4 5 http.createServer(function(request,response) 6 { 7 8 response.writeHead(200,{'Content-Type':'text/html;charset=utf-8'}); 9 10

HTML学习开篇

最近开的博客,一切都是从零开始,昨天刚写了java的开篇,今天写一写HTML开篇. 很多初学者都不太看重前端的学习,甚至鄙视前端,我刚开始时就这样.其实,要想成为一个真正的程序员,前端和后端都必须了解,然后再重点向自己想成为的方向发展.废话少说,无论你想成为哪方面的程序员,前端都是要学的. 前端知识学校好像不教,反正我的学校不学.介绍几个学习HTML的地方.慕课网,w3school,codecadmy. 这次简单介绍下HTML的基本结构. what is HTML? HTML stands fo

2015第40周二Node学习

node历史 今天看cnode开源项目用了io.js,在查这个项目时发现这篇文章node历史,node.js和io.js关系谈到Node.js的由来,不可避免要聊到它的创始人Ryan Dahl.在2009年时,服务端JavaScript迎来了它的拐点,因为Ryan Dahl带来了Node.js,在那之后Node.js将服务端JavaScript带入了新的境地,大量的JavaScript在GitHub上被贡献出来,大量的JavaScript模块出现,出现了真正的繁荣.Node.js创始人Ryan

Node学习笔记(四):gulp+express+io.socket部署angularJs2(填坑篇)

这篇就先暂停下上篇博客--你画我猜的进度,因为在做这个游戏的时候,想采用最新的ng2技术,奈何坑是一片又一片,这边就先介绍下环境部署和填坑史 既然要用ng2,首先要拿到资源,我这边用的是angularJs2 beta版的,网上的资源有两种,一个是文件全压缩版的.min.js版的另一个就是一大堆乱七八糟的js文件,主要是ng2已经完全采用TypeScript,加之对es6的支持,所以需要引入一大堆兼容,编译文件 这边刚好特别手欠想学学gulp,于是开搞配置gulp环境,压缩所有的js文件成一个mi

Node学习笔记(三):基于socket.io web版你画我猜(一)

经过惨淡的面试,也是知道了自己的不足,刚好最近在学习node,心中便有了做一个web版的你画我猜的想法 首先说下思路,在做准备工作的时候,有两个大概的思路: 1.规定一块div,捕捉鼠标事件,动态生成position absolute,长宽1px的红色小div,这样可以模拟出划线的轨迹,做一个long polling,不断获取DOM结构,推送到socket端口,然后再广播给所有客户端 2.利用canvas作图,将canvas的数据推送到socket端口,广播所有客户端 其实之所以有两种想法,无非