用NodeJS+Express开发WEB应用---第一篇

大漠穷秋2014-03-28

预热

为了对后面的内容理解更加透彻,推荐首先阅读下面这篇很好的文章:

http://www.nodebeginner.org/index-zh-cn.html

以上链接中的这种方式显然过于繁琐,一切都靠我们手动编码和组织。

我们知道,在Java或者其它语言下开发WEB应用有各种各样的框架可以支撑,理所当然,在NodeJS下也应该有这样的框架来支持我们的开发。

express就是这样一款框架,只不过它是基于NodeJS。

好吧,说直白一点儿,express只不过是数十万个node模块中的其中之一。

express的官方首页在这里: http://expressjs.com/

中文首页在这里: http://express.jsbin.cn/

很可惜,官方页面里面的文档组织得并不好,也没有对一些基本的问题做出解释。

所以,还是跟我来吧。

安装express

第一步:装好NodeJS。 http://nodejs.org/ ,这太简单了,没啥好说的。

第二步:用npm安装express

    npm install -g express

请注意,最好加上-g选项,因为这样npm会把express安装成一个全局模块。

小僧在用npm安装模块的时候一般都会加上-g选项,因为这样配置环境变量会比较省力。

全局node模块一般位于C盘的用户目录中,在我机器上是这样的:

    C:\Users\zhangxf10\AppData\Roaming\npm\node_modules

注意:由于功夫网的存在,npm安装express的过程可能会卡住,可以先ctrl+c强退一次,然后再来。当然你也可以使用代理进行安装,请查阅npm config指令进行代理配置。

第三步:配置环境变量

把以上路径配置到系统环境变量里面去,图示如下:

第四步:安装jade

这是一款模板框架,express默认会使用它,而且它的语法相当赞,写起HTML来非常爽,我们还是装上吧:

    npm install -g jade

开始动手

第一步:在任意目录下建一个文件夹,小僧本机新建了一个express文件夹。

第二步:从命令行cd到你新建的文件夹下,敲以下命令

    express test

注意:如果报找不到express模块啥的,说明你的环境变量没配置好,或者没有新起一个cmd黑窗口。怎么办你懂的,不解释。

第三步:通过以上命令,express就为你自动创建了test项目的目录结构,还有一些初始化文件。在我本机上是这样的:

其中,app.js就是我们的入口啦!

第四步:启动server

    node app

第五步:浏览器访问3000端口

第六步:测试其它路由

访问以下地址查看效果:

    http://localhost:3000/users

小结

好了,通过以上内容express就已经可用了。

简单来说,你可以把express看成是nodejs下的struts或者其它blabla框架就好了,它提供了基础的结构支持,让你不用啥都自己从头写。

接下来会详细介绍jade和express的更多用法。

(PS:这段时间比较忙,只能等周末写文章有木有! ~~~ 求支持有木有!~~~求转发有木有!~~~附件里面的PDF排版更好,阅读体验更佳有木有!~~~小僧真的很贴心有木有!~~~)

nodejs express开发的更多相关文章

  1. nodejs+express开发blog(1)

    前言 Nodejs是一个年轻的编程框架,充满了活力和无限激情,一直都在保持着快速更新.基于Nodejs的官方Web开发库Express也在同步发展着,每年升级一个大版本,甚至对框架底层都做了大手术.在 ...

  2. NodeJS+Express开发web,为什么中文显示为乱码

    把你的文件另存为下,格式为utf-8的试下就行!

  3. nodejs+express开发blog(2)

    npm install -g nodemon 1,把ejs文件修改为html文件 app.engine('.html', require('ejs').__express);app.set('view ...

  4. NodeJS+Express+mySQL服务端开发详解

    随着NodeJS的发展,现在已经被很多人熟知,NodeJS已经成为了前端开发人员必备的技能.本文不会对NodeJS过多介绍 如果你感兴趣可以访问NodeJS 官网, 维基百科 本文是利用NodeJS+ ...

  5. 像asp.net Mvc一样开发nodejs+express Mvc站点

    像asp.net Mvc一样开发nodejs+express Mvc站点 首先,我是个c#码农.从事Mvc开发已然4个年头了,这两年前端MVC的兴起,我也跟风学了一些,对前端的框架也了解一些,angu ...

  6. NodeJS+Express+MySQL开发小记(2):服务器部署

    http://borninsummer.com/2015/06/17/notes-on-developing-nodejs-webapp/ NodeJS+Express+MySQL开发小记(1)里讲过 ...

  7. nodejs学习篇 (1)webstorm创建nodejs + express + jade 的web 项目

    之前简单了解过nodejs,觉得用nodejs来做个网站也太麻烦了,要自己拼html的字符串返回,这能做网站嘛? 最近看到使用jade模板来开发,觉得挺新奇的,于是试了一把,也了解了一些特性,算是个新 ...

  8. CentOS编译安装NodeJS+Express

    NodeJS是基于Chrome’s Javascript runtime,也就是Google V8引擎执行Javascript的快速构建网络服务及应用的平台,其优点有: 在CentOS编译安装Node ...

  9. nodejs+express Mvc站点

    nodejs+express Mvc站点 像asp.net Mvc一样开发nodejs+express Mvc站点 首先,我是个c#码农.从事Mvc开发已然4个年头了,这两年前端MVC的兴起,我也跟风 ...

随机推荐

  1. view.getParent()与view.getRootView()

    顾名思义,getParent就是获取view的父亲节点,而getRootView是寻找当前的view层次中处在最顶层的view,可理解为找出该view实例所在的view层次的根view. 如果这个vi ...

  2. cocos creator destroy方法

    node.destroy(),Node.destroyAllChildren并不会立即销毁,实际销毁操作会延迟到当前帧渲染前执行. 这段话可能不明白,但是在Node.destroyAllChildre ...

  3. charAt 写一个反序函数

    function reverStr(str){ var tmpStr = ""; for(var i=str.length-1;i>=0;i--){ tmpStr += st ...

  4. 七牛直播云-m3u8格式直播

    直播架构 业务服务器:负责协调直播类应用的业务逻辑 创建直播房间 返回直播房间播放地址列表 关闭直播房间 LiveNet 实时流网络:负责流媒体的分发.直播流的创建.查询等相关操作 采集端:负责采集和 ...

  5. CSS练习:仿小米官网

    代码: <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UT ...

  6. 从零开始的 webpack4 + vue2.x

    新建文件夹 webpack-vue 安装依赖 yarn init //初始化package.json yarn add webpack webpack-cli //添加webpack.webpack- ...

  7. C#学习笔记_13_静态类&Sealed&运算符重载&抽象类

    13_静态类&Sealed&运算符重载&抽象类 静态类 由static修饰的类就是静态类 特点: 静态类不能实例化对象 静态类中不允许写非静态的成员 静态类只能由一个父类Obj ...

  8. python - 那些零碎的知识点

    python - 那些零碎的知识点 一. 字符串格式化 1. "旧式字符串解析(%操作符)" 'Hello, %s' % name "Hello, Bob" ' ...

  9. 编译OpenWrt失败

    /home/fly/work_dir/OpenWrt-SDK/OpenWrt-Test/trunk/scripts/download.pl "/home/fly/work_dir/OpenW ...

  10. [TS-A1488][2013中国国家集训队第二次作业]魔法波[高斯消元]

    暴力直接解异或方程组,O(n^6)无法接受,那么我们考虑把格子分块,横着和竖着分别分为互不影响的块,这样因为障碍物最多不超过200个,那么块的个数最多为2*(800+200)=2000个,最后用bit ...