nodejs初印象

初学Nodejs,特意在此记录学习过程,算是对这段时间的一个summary吧,相互勉励,共同进步嘛,Now Begin:

1、什么是nodejs

nodejs 是一种基于事件驱动、非阻塞I/O模型,用于方便地搭建响应速度快且易于拓展的网络应用。基于Google V8引擎进行封装,V8引擎执行javascript效率高、速度快。nodejs其实就是一种解析器,用于进行各种运算。nodejs中内置了诸如文件 操作(fs)、http or https、Buffer等模块或对象。

2、如何安装nodejs

nodejs的安装直接在https://nodejs.org/下载并安装即可。

3、入门实例

这里先创建一个简单的http服务并返回“hello nodejs”:

var http = require("http");
 var server = http.createServer(function(req,res){
    if (req.url !== "/favicon.ico") {

        res.writeHead(200,{"Content-Type":"text/plain"});
        res.write("hello nodejs");
        res.end();

        req.on("end",function(){
            console.log("客户端请求数据全部接收完毕");
        });
    }
 }).listen(1337,"localhost");
 console.log("http服务器已创建并开始监听");

将上述代码保存为js文件如:http_server.js,然后 在cmd窗口中切换至该文件的路径后,使用命令:node http_server.js,即可创建一个简单的http服务器。这时再在浏览器中输入:http://www.127.0.0.1:1337,观察浏 览器窗口输出:hello nodejs,并且cmd窗口中输出:http服务器已创建并开始监听(换行)客户端请求数据全部接收完毕。这样一个简单的http服务创建与请求处理就 完成了。下面是一些说明:

  • 使用require语句可以直接导入nodejs内置模块,即这里的http模块(一般来讲一个模块就是一个封装好各种功能的js文件,使用时直接require即可)
  • 导 入http模块后,使用http自带的createServer方法创建一个http服务,该方法含有一个function参数,理解为回调函数,即 http服务创建成功后执行的函数。该回调函数自带req、res分别代表http的request、response。if判断只是过滤掉对浏览器收藏 夹图标的请求,可以忽略(ps:如果不过滤掉的话,可能你的cmd窗口就会打印出2条数据,因为不仅请求了"/"根路径,还顺带请求了" /favico.ico"路径)
  • 使用res对象的writeHead方法,写入http响应的头文件,指定状态码200、响应类型为text/plain。write方法用于直接将该文本响应至浏览器端,end表示响应结束
  • on表示为req对象注册一个end事件,当请求结束时该事件会被自动调用,即基于事件驱动。end事件正常响应后使用内置回调function自动处理
  • 创建完http服务之后还需指定该服务所监听的具体url、端口等,使用listen可以做到
  • console.log表示在cmd窗口直接打印输出

4、Exports

Exports对象是当前模块的一个导出对象,用于导出模块内的公有属性或方法。这样其它模块可以使用require直接导入使用,模块导出对象默认为一个普通对象,如果想改成一个函数的话,可以如下操作:

module.exports = function(){
    console.log("hello world");
 };

5、Require的路径解析规则

require函数支持以斜杠(/)或盘符(c:)开头的绝对路径,也支持以./开头的相对路径。

  • 如果传给require的是node_modules下的默认模块,不做路径解析,直接返回内部模块的导出对象,如:require("fs");
  • nodejs 定义了一个node_modules目录用于存放模块,如某个模块的绝对路径为/home/user/hello.js,在该模块中使用 require("foo/bar")的方式请求模块时,依次请求以下路径:/home/user/node_modules/foo/bar、 /home/node_modules/foo/bar、/node_modules/foo/bar

 6、NPM包使用

npm是同nodejs一起安装的一个包管理工具,使用npm可以安装各种模块的包。npm的使用比较简单,比如想安装包名为argv的包,直接在cmd窗口中输入:npm install argv。

npm包的安装时有本地安装和全局安装两种,全局安装使用:npm install -g argv,全局安装和本地安装的区别是,本地安装的包如果要在cmd窗口中引用,应该切换到该包所在目录方可,全局安装的包不用切换目录。

 7、关于Webstorm&Express

Express是基于nodejs的一种web开发框架,同java中ssh框架一般,封装好了很多现有模块,比如Request、Response、Router等,提供诸多强大特性帮助创建各种web和移动设备应用。

关于Express具体介绍http://www.expressjs.com.cn/,Webstorm对js文件的支持很是不错,被誉为The Smartest JavaScript IDE,下面着重介绍在Webstorm下创建一个简单项目:

  1. 下载安装Webstorm,\\192.168.20.50\Tech\soft\开发工具\WebStorm
  2. 打开IDE后选择:File -> New Project如图,,Template一般选择EJS(一种视图模板引擎),设置好后直接点击Create即可创建一个基于Express的Nodejs项目(ps:一般Create后可能会要求指定nodejs的源码,这时直接在官网下载并指定即可)
  3. 刚创建好的项目结构如图,其 中,bin\www文件代表项目启动配置,包括端口号设置等。node_modules目录保存当前项目自动引入的一系列模块(如果想再导入其它模块的话 直接通过npm安装再将其复制到此即可)。public目录存放引用的资源文件,包括images、css等。routes存放路由模块,负责处理各种 url请求。views目录保存视图资源。app.js文件负责引用各种中间件模块以及错误处理等。package.json文件存放部分配置信息。
  4. app.js文件,如图,其中,use表示对所有请求方法均拦截处理,使用routes或者users进行具体url请求处理。相当于路由中转功能。
  5. index.js文件代码如下,对相应的url请求进行分别处理:

    var express = require(‘express‘);
    var router = express.Router();
    /* GET home page. */
    router.get(‘/‘, function(req, res, next) {
      if(req.url !== "/favicon.ico"){
        res.render("index",{title:"Express"});
        next();
      }
    });
    router.use("/list",function(req,res,next){
      if(req.url !== "/favicon.ico"){
        console.log("router.use/add请求返回信息");
        //next();
      }
    });
    module.exports = router;
  6. 在浏览器中输入:http:localhost:3000,观察输出如下:至此,一个简单的Express应用就完成了。

完整的一个增删改查实例:

点击下载Nodejs_crud

时间: 2024-10-12 10:29:58

nodejs初印象的相关文章

Nodejs初阶之express

Nodejs初阶之express 2014-02-28 23:00 by 聂微东, 85627 阅读, 26 评论, 收藏, 编辑 PS: 2014/09/24 更新<Express 4.X 启航指南>,欢迎阅读和评论:) 老规矩,开头部分都是些自娱自乐的随想,想到哪写到哪... 到今天俺已经在俺厂工作俩年零几天了,工作以来头一回在一家企业工作超俩年,对于这俩年确实只有满满的成就感,不管是工作还是生活...写到这句突然又想写篇这俩年的总结,等这篇文章发了之后就着手整理吧,吼吼. 那篇<n

OpenCL学习笔记(一):摩尔定律、异构计算与OpenCL初印象

关于摩尔定律: 摩尔定律1965年提出,晶体管密度是按照每年翻倍发展的,之后的趋势也是这样--每一代芯片的的时钟频率提高50%,而同时工艺节点减小了0.3,功耗密度翻倍(保持功耗相同的情况下,面积0.7*0.7=0.49,因此提高频率使得性能提升了):而在2000年中期之后,出现了物理尺寸更小的器件,意味着,我们没有办法保持功耗密度不变,而同时提高频率,结果我们看到自此之后,时钟频率并没有显著提高,需要通过并行来提高性能,所以多核CPU流行起来.即使是最基本的处理器,超标量和无序指令执行等高级体

初印象至Vue路由

初印象系列为快速了解一门技术的内容,后续会推出本人应用这门技术时发现的一些认识. Vue路由和传统路由的区别: Vue路由主要是用来实现单页面应用内各个组件之间的切换,同样支持传递参数等功能.而传统路由使用超链接 以下内容来自官网,js使用ES6 如何在vue项目中使用vue-router HTML <script src="https://unpkg.com/vue/dist/vue.js"></script> <script src="htt

Vue.js之初印象

一.背景 MVVM模式,很多人在说在用,好吧,我落后了,我目前的项目木有用到MVVM模式的框架,vuejs,reactjs,angularjs,nonono,自己去捣鼓过ng,项目木有用到.实在不敢称自己是front-end developer.趁这个失业期,vuejs的学习起哟. 二.简介 1.vue.js是什么 Vue.js是当下很火的一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的.相比于Angular.js,Vue.js提供了更加简洁.更易于理解的API,使得我们

uml时序图的初印象-------Day64

最近有好多想法迫不及待的想去实现,可是事实上是在那些最开始想的非常明白,感觉会没问题的地方也总是会出现问题,导致略微有些急躁,还是要淡定啊,又到了周末,明后天要收拾东西搬家,不知道宽带能不能顺利的给挪过去,想提前来记录下这周的工作吧. 总的来说,这周完成了界面的初始设计,然后就是这概要设计了,结果整合下来,word文档都有近百页了,太多时序图了,画的我都有些头昏脑涨.其实,在很久之前的某公司,我面试的第一道问题就是时序图,结果当时的我是可怜的一片茫然,结果也就自然而然了.这次再看时序图,又理解了

gulp初印象

几个月前三木君向我推荐过gulp,到现在因为工作需要才接触到它,真的很惭愧,在此记录下对gulp的初印象. 全局安装: $ npm install –global gulp 一个gulpfile.js文件: 这个文件需要在项目的根目录下创建.默认任务(什么也不做): var gulp = require('gulp'); gulp.task('default', function() { // place code for your default task here }); 下面的命令将执行这

Django初印象之视图(view)

一.view的初印象 一个视图函数(类),简称视图.我们发起web请求时,返回的web响应.[大家约定成俗将视图放置在项目(project)或应用程序(app)目录中的名为views.py的文件中.] 二.普通view的样子 下面是一个以HTML文档的形式返回当前日期和时间的视图: from django.http import HttpResponse import datetime def current_datetime(request): now = datetime.datetime.

【转】Nodejs初阶之express

老规矩,开头部分都是些自娱自乐的随想,想到哪写到哪... 到今天俺已经在俺厂工作俩年零几天了,工作以来头一回在一家企业工作超俩年,对于这俩年确实只有满满的成就感,不管是工作还是生活...写到这句突然又想写篇这俩年的总结,等这篇文章发了之后就着手整理吧,吼吼. 那篇<node.js 初体验>好像才发生在前几月,没想到时间已过两年有多.且看到文章末尾处那句: “这篇文章只会是一个开始” 令俺脸红掩面,尼玛真没想到这一开始就开始了两年多,这让老夫情何以堪... 好吧,反正脸皮厚已不是俩三天,让俺装傻

NodeJs初相识

一.nodeJs简介 1.Node 是一个服务器端 JavaScript 解释器. 2.Node 的目标是帮助程序员构建高度可伸缩的应用程序,编写能够处理数万条同时连接到一个物理机的连接代码.处理高并发和异步I/O是Node受到开发人员的关注的原因之一. 3.Node 本身运行Google V8 JavaScript引擎,所以速度和性能非常好,而且Node对其封装的同时还改进了其处理二进制数据的能力.因此,Node不仅仅简单的使用了V8,还对其进行了优化,使其在各种环境下更加给力. 4.第三方的