node+express+mongo:快速实现网页前后端交互(一)

笔者最近忙着考研,买了新版的《第一行代码》还没来得及看,Android知识真是很多呀,考研只能先把Android学习先缓缓啦!
最近学习了如何通过node.js实现一个网页与后台数据库的交互 !决定写个小总结与大家共同学习一下!

先申明所用到的软件等:node.js(js的运行环境)、mongo(数据库)、VS Code(代码编辑器)、Chrome浏览器(网页开发必备呀)、express框架(node.js的制作网页利器)、MVC框架(分层封装,各司其职)

下面开始(按步骤写吧,条例清晰些,大家也好参考):
第一步:创建一个新文件夹,在cmd该文件目录中初始化工程,导入需要用到的包。
这里介绍一个快速进入cmd要进入的文件目录的方法,直接在文件夹目录中输入cmd敲回车键就可以直接进入项目目录cmd了!超方便!在这里插入图片描述
下面在改文件目录cmd中初始化,把该导入的包都导入文件夹里。需要的语句如下:
1.npm init -y(初始化)
2.npm i express(安装express包)
3.npm i ejs(安装ejs包)
4.npm i mongo(安装mongo数据库包)
这些包都提供许多方法供我们使用,后面都会用得到的。初始化工作完了的文件夹下是这样的
在这里插入图片描述

第二步:通过vs code打开项目,在项目结构下创建一个server.js写服务器的入口各种方法

let express = require("express");  //导入express包
let app = express();               //创建一台叫app的服务器
app.get("/",(req,res)=>{           //服务器响应请求,回送信息
    res.send("Hello,world") 
    })
app.listen(3000,()=>{     //指定3000端口为服务器端口,监听其是否启动
    console.log("服务器启动了")
    })

做完上面这些,我们通过cmd启动这个服务器试试
启动服务器代码:nodemon server.js(需要安装这个全局模块,一次安装,以后可以一直用。安装命令:npm I nodemon -g)
(写nodemon这个命令的好处是在我们改动代码的时候服务器会自动更新重启,不用我们一遍遍启动。)
在这里插入图片描述
服务器启动成功了,去浏览器输入localhost:3000试试吧
在这里插入图片描述

第三步:渲染HTML页面
可见,服务器收到了我们的请求,返回了Hello,word,那么同理,我们同样也可以让服务器给我们返回一个HTML页面。由此我们使用MVC方法分别创建3个文件夹:models、views、controllers。至于为什么要使用MVC,我觉得就是让代码条例更清晰,把每个功能一样的部分放在一起,便于维护。MVC我就不细展开了。我们在views文件夹下创建个index.html
在这里插入图片描述有了html页面,我们修改一下server.js里面的一行代码,让服务器渲染出这个页面
app.get("/",(req,res)=>{ //服务器响应请求,回送信息 // res.send("/index.html") res.render("./view/index.html") })

好,让我们去浏览器看看吧。
在这里插入图片描述
出问题了,显示找不到html页面,这是因为我们渲染页面必须要用到模板引擎,通过模板引擎才能将页面渲染出来。
要使用模板引擎,我们需要:
1.把html文件的后缀改为ejs(因为我们使用的模板引擎是ejs)
2.在服务器入口中(server.js就是服务器入口文件)告诉express我们使用模板引擎ejs

let express = require("express");  //导入express包
let app = express();               //创建一台叫app的服务器
app.set("view engine","ejs")      //设置模板引擎为ejs
app.get("/",(req,res)=>{           //服务器响应请求,回送信息    	// res.send("/index.html")
        res.render("index")       //一旦告诉express使用了模板引擎,只需要写views下面的视图文件名就行,不需要写路径和后缀
        })
app.listen(3000,()=>{             //指定3000端口为服务器端口,监听其是否启动    
	console.log("服务器启动了")
	})

OK,再去浏览器看看在这里插入图片描述
成功了!使用模板引擎好处我们通过模板引擎将数据传给页面,修改一下代码试试吧。

app.get("/",(req,res)=>{           //服务器响应请求,回送信息    
	// res.send("/index.html")    
	res.render("index",{data:123})       
	})

我们修改一下get里代码,在这里添加一个数据data为123

<p><%= data %></p>

再修改一下html里代码,加上上面一行来使用data数据。
来吧,看看data引用成功了没
在这里插入图片描述
可以看到,data已经出来了证明引用成功了。到这里应该可以想到,如果这些data是数据库传入的,我们就可以把数据库里的数据加载到我们的html页面了。这正是我们最后要实现的目的!

第四步:渲染数据前的准备–MVC的封装
前面我们已经讲到我们使用MVC封装同样功能的方法。
首先V,即Views,我们把所有的html页面都放在这里
然后M,即Models,我们把与数据库操作有关的代码都放进这里面
最后C,即Controllers,我们把控制逻辑的代码都放这里

数据库相关的代码最后才用到,让我们先把控制逻辑的代码放到controllers文件夹里吧。这里我们创建一个students.js文件将server.js里的渲染index.html代码封装一下,后面所有类似工作的代码都是这样。
students里的代码:

exports.showIndex = (req,res)=>{              
 	res.render("index",{data:123})       
 }

server.js里的代码:

let express = require("express"); 
let students = require("./controllers/students")   //在服务器入口文件中导入controllers里的students文件
let app = express();
               
app.set("view engine","ejs")
      
app.get("/",students.showIndex)                 //在这里渲染的代码都封装到了students里,我们只需引用students里的方法即可

app.listen(3000,()=>{                 
console.log("服务器启动了")
})

这样,我们就实现了将渲染html页面的逻辑代码封装到students里了,然后再server里导入students,直接使用其方法即可,效果是一样的。
在这里插入图片描述
好了,为了讲解下面的内容,我将html里的内容换成一个提前写好的学生信息页面,后面我们要实现把数据库里的信息通过代码加载到html页面里。

<!DOCTYPE html>
<html lang="en">
    <head>        
    	<meta charset="UTF-8">        
    	<title>学生管理</title>        
    	<style>            
    		table {                
    			text-align: center;                
    			width: 500px;                
    			height: 200px;                
    			margin: 20px auto;                
    			border-collapse: collapse;                
    			font-family: Futura, Arial, sans-serif;            
    		}                
	
		th,td {                
		padding: .65em;            
		}                
		
		th {                
		background: rgb(85, 85, 85) ;           
		color: #fff;            
		}                              
		
		tbody tr:nth-child(odd) {          
		background: rgb(93, 218, 250);            
		}                
		
		th:first-child {                
		border-radius: 9px 0 0 0;            
		}                
		
		th:last-child {                
		border-radius: 0 9px 0 0;            
		}                
		
		tr:last-child td:first-child {                
		border-radius: 0 0 0 9px;            
		}                
		
		tr:last-child td:last-child {                
		border-radius: 0 0 9px 0;            
		}                
		h1,h3 {                
		text-align: center;            
		}        
		</style>    
	</head>
	<body>    
	<h1>学生列表(ajax去请求数据,浏览器自己渲染数据)</h1>    
	<h3><a href="/add">[增加新学生]</a></h3>    
	<table >        
	<thead>            
	<tr>                
	<th>姓名</th>                
	<th>年龄</th>                
	<th>性别</th>                
	<th>籍贯</th>        
	</tr>        
	</thead>
        
        <tbody>            
        <tr>                
        <td>wangcai</td>                
        <td>18</td>                
        <td></td>                
        <td>中国</td>            
        </tr>            
        <tr>                
        <td>wangcai</td>                
        <td>18</td>                
        <td></td>                
        <td>中国</td>            
        </tr>            
        <tr>                
        <td>wangcai</td>                
        <td>18</td>                
        <td></td>                
        <td>中国</td>            
        </tr>        
        </tbody>    
        </table>
        </body>
        <script type="text/template" id="mytemplate">
        </script>
        <script src="/js/jquery1.11.3.js">
</script>
        <script src="/js/underscore.min.js"></script>
        </script>
</html>

页面是这样的
在这里插入图片描述
好了,不知不觉写了三个小时,已经晚上11点半了,暂时写到这吧!
现在页面里都是静态数据,我们只差将数据库中数据通过代码来导入到表格中,实现增删改,就完成一个基本网页和数据库的联系。

下次见!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个系统其实是出于学习nodejs的目的而改写的系统。 原来的系统前端使用了extjs4.2.1,后端使用了PHP5.4和ZEND框架开发,后台数据库是用mongodb2.2.2。 我抽离出了原来系统中的账户管理,角色管理,菜单管理,权限管理这4个部分, 我想这4个部分,基本上所有的系统都会用到。具有一定的普遍性。所以将这4个部分用nodejs重新改写了。 该系统目前使用模块有express,ejs,connect-mongo,mongodb,express-partials,connect-flash,fibers,wind等 其实wind模块这次系统中没有使用。可以将它排除出去。我是出于学习wind的目的,才加入这个模块的。 本来准备使用wind模块,是为了实现同步的目的,由于后来改用了fibers模块之后,就没有使用它。这里说明一下 不是fibers要比wind好,而是我暂时不能理解wind,或则是说对wind的研究不够吧。 众所周知nodejs是推崇异步模式。但是这个系统是从php过来的,而php的代码是同步模式的写法,所以为了在改写的过程中 希望 1是代码改动最少 2是同步写法更加适合思维习惯。而且代码可读性高的目的,用到了fibers。 这个系统的源代码中有些js文件里保留了一些原来的PHP代码,这是出于代码对比的目的。 是让大家了解原来的php代码是怎么实现的,用nodejs之后是如何改写的。通过对比,大家会发现 其实通过使用fibers之后,几乎两者是一模一样的。 还有源代码中还保留了一些被注释掉的函数,有些是用到了wind,有些是用到了fibers,有些是直接异步的写法。 这些内容都是在开发过程中我不断尝试后的产物。我花了1周的时间才实现了一个递归的调用,而且还是同步的方式。 到目前为止,我还不能理解在异步模式下实现递归调用函数。比如说源代码中有个函数getMenuTree,菜单下面可能有子菜单, 子菜单的下面可能还有菜单。所以是一个递归的过程。我现在是同步的写法实现了这个函数,如果有人能够提供异步写法实现的递归函数并 emai给我,我不胜荣幸。 在使用本系统之前,必须要安装nodejs 0.10.10,mongodb2.2.2,python2.7.5至于安装的方法请googel解决。 将源代码下载之后,解压到某个目录下,比如说d:\nodejs\umav4simple目录。 进入到那个目录, a)运行以下命令 npm install express npm install ejs npm install connect-mongo npm install mongodb npm install express-partials npm install connect-flash npm install fibers npm install wind 尽管在源代码中已包含了这些模块,但是最好还是要重新运行一遍。 因为有些模块可能需要重新的编译。 比如说fibers模块,我在window下运行npm install fibers的时候编译了一个win32-ia32-v8-3.14 而在linux下重新编译了linux-ia32-v8-3.14。所以说根据操作系统的不同,可能会有一些不同。 以免造成想不到的错误。 b)打开settings.js,并且将你的mongodb的设置改写并保存。 c)运行node app.js或则node cluster.js 如果没有提示错误的话,那么就说明环境配置成功了。 d)通过以下的URL可以在mongodb中追加一些数据,不过只能运行一次。否则会重复追加数据。 浏览器上输入 http://localhost:3000/admin/index/install 做完之后, 浏览器上输入http://localhost:3000/ 就通过用户名admin 密码adminadmin进行登录,并使用这个系统了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值