用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. c#仿照qq登录界面编辑框内容操作

    using System; using System.Drawing; using System.Windows.Forms; namespace 案例演示 { public partial clas ...

  2. Python 之多线程应用

    import socket from threading import Thread def recv_data(): while True: recv_info = udp_socket.recvf ...

  3. Android 双屏异显

    android双屏是克隆模式,如果要在第二屏幕显示不同内容,需要自定义一个Presentation类 1.先设置权限 (刚开始折腾很久没有效果,后来发现是没设置权限) <!-- 显示系统窗口权限 ...

  4. (2)搜索广告CTR预估

    https://www.cnblogs.com/futurehau/p/6184585.html 1. CTR预估的流程 数据 -> 预处理 ->特征抽取 ->模型训练 ->后 ...

  5. js 图表转图片

    最近项目上有个需求,是将一些teechart做的图表转换成图片插入自动生成的PDF里,Teechart绘图和如何生成PDF这些这里就不说了,这个任务比较别扭的一点是,图表自动生成,且整个过程中页面不能 ...

  6. 洛谷——P3906 Geodetic集合

    P3906 Geodetic集合 题目描述 图G是一个无向连通图,没有自环,并且两点之间至多只有一条边.我们定义顶点v,u最短路径就是从v到u经过边最少的路径.所有包含在v-u的最短路径上的顶点被称为 ...

  7. 【codeforces 515A】Drazil and Date

    [题目链接]:http://codeforces.com/contest/515/problem/A [题意] 每次只能走到相邻的四个格子中的一个; 告诉你最后走到了(a,b)走了多少步->s ...

  8. elasticsearch 权威指南Mapping(映射)

    什么是映射 类似于数据库中的表结构定义,主要作用如下: 定义Index下字段名(Field Name) 定义字段的类型,比如数值型,字符串型.布尔型等 定义倒排索引的相关配置,比如是否索引.记录pos ...

  9. HyperLedger项目以及社区

    本文不涉及任何技术开发的内容,仅供你跟同学.同事吹牛B之用.就像很多牛人总爱讲历史典故一样. 一.诞生与现状 HyperLedger 诞生于2015年12月17日,HyperLedger 追寻Apac ...

  10. P - How many

    Give you n ( n < 10000) necklaces ,the length of necklace will not large than 100,tell me How man ...