位置: 编程技术 - 正文

从零学习node.js之利用express搭建简易论坛(七)(node.js快速入门)

编辑:rootadmin

推荐整理分享从零学习node.js之利用express搭建简易论坛(七)(node.js快速入门),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:怎么学node.js,node.js怎么学,node.js快速入门,node.js怎么学,node.js快速入门,node.js入门教程,node.js自学,node.js自学,内容如对您有帮助,希望把文章链接给更多的朋友!

一、应用生成器

使用上节学习到express的知识,我们也可以从0开始,一步步把系统搭建起来。不过express中还有一个应用生成器,使用这个应用生成器可以快速的创建一个应用的框架,然后我们再在这个框架中完善我们需要的内容。首先安装应用生成器:

运行express --version若能正常输出版本号,则安装成功。

我们的论坛名称可以为node_express_forum,然后使用express创建一个框架:

运行后,生成器会在这个目录下生成几个目录和文件:

已经生成成功。进入到这个目录:

我们来看下生成的这个框架,方便知道后面怎么进行填充。

打开package.json后,我们看到还需要再安装几个模块才能运行:

好了,到现在框架已搭建完毕,我们来运行一下:

然后在浏览器中输入.0.0.1:,就可以看到了:Express Welcome to Express。

二、准备工作

基本框架已经创建好了,现在开始我们论坛的准备工作。这里我们的准备工作有3个:模板引擎,模型,数据库,路由。

2.1 模板引擎

express里默认使用的模板引擎是jade,不过我们也可以选择其他的模板引擎,我这里选择了ejs,因为感觉ejs更像是个html文件,方便维护,当然,每个人都有自己的喜好。

然后在app.js中修改模板引擎:

这里我会将views目录中的.jade文件清空,后续使用.ejs编写模板。

2.2 模型

这里我们说的模型是指MVC中的M,主要是进行数据库的连接和操作。创建models目录用来存放文件。

2.3 数据库

我们使用mysql数据库来存放数据,数据库名称可以叫做forum。里面有3张表:user, list, reply。

user表(用户)的字段有: id, username, password, regtime list表(主题)的字段有: id, uid(用户id), title, content, createtime reply表(回复)的字段有: id, pid(主题id), uid(用户id), content, createtime

2.4 路由

上节我们是使用app.use()或app.get()等方式来实现路由,同时,express还提供了express.Router类来创建模块化。可挂载的路由。Router 实例是一个完整的中间件和路由系统,因此常称其为一个 “mini-app”。

在routes/user.js中(这里我将其users.js改为了user.js):

然后在app.js中加载路由模块:

这样就可以访问/user和/user/reg页面了。如果需要增加其他的路由,则依照此方式创建添加即可。

三、注册与登录

我们论坛的功能:注册、登录、发布主题和回复主题。这4个功能的实现都需要连接数据库。

3.1 数据库连接

引入mysql模块,然后使用mysql.createPool()创建连接:

在models目录下创建db.js,其他需要操作数据库的,首先引入db.js:

3.2 注册功能

注册功能的流程我们非常熟悉了:

加载注册页面; 用户输入数据后提交; 处理表单数据然后进行数据库操作

我们在routes/user.js中创建一个reg的get方式的路由用来加载注册页面:

在views目录下创建reg.ejs:

运行程序,并用浏览器访问.0.0.1:/user/reg,注册页面就出来了。

然后再在routes/user.js中创建一个reg的post方式的路由用来处理提交过来的数据,post方式过来的数据并不能使用req.query变量获取,而应该使用req.body:

从零学习node.js之利用express搭建简易论坛(七)(node.js快速入门)

凡是设计到数据库处理的,我们都将其放到models中。这里,我们在models中创建一个user.js:

我们将检测用户名和插入数据两个功能放到一起处理了,实际应用中,最好是在用户提交数据之前就对用户名进行检测。注册功能的model写好之后,就可以调用了,承接上面的代码,从数据库处理接着编写。

页面若跳转到首页,则说明注册成功了,查看下数据库是否将数据正确的插入了。

到这里,注册功能完成了,完成了吗?还没呢,我们这里注册完成后仅仅是跳转到了首页,还缺少的操作是:

若直接跳转到首页,则默认是已经登录了,这里就需要记录用户的登录状态; 若不跳转到首页,则注册成功后要跳转到登录页面让用户登录

我们这里使用第1种方式,稍后讲解如何记录用户的登录状态。

3.2 登录功能

登录过程与注册是非常类似的,而且比注册还要简单,只需要查询数据库中是否存在对应的用户名和密码即可。

首先编写一个登录页面:

然后在model/user.js中添加上对数据库的登录操作:

最后在routes/user.js中添加上登录的路由:

登录功能也编写好了。

3.3 保存登录状态

我们通常是使用session来保存用户的登录状态,express框架没有对session处理的功能,需要我们引入额外的模块express-session:

然后在app.js中引用:

设置完成后,就可以使用session保存数据了。以登录成功后保存数据为例:

还有一个问题:如何把session中的数据传递给模板呢,比如没有登录时,显示“注册,登录”连接,登录后显示“用户名,登录”信息。

在app.js中添加:

然后在模板中就可以使用user变量了:

四、首页及详情页

我们在首页能够展示主题列表并能发表主题,点击链接进入详情页后能该主题进行回复。当然发表主题和对主题进行回复都是在已经登录的状态进行的。

4.1 首页

在models目录创建list.js,从数据库中获取主题列表:

在routes中的index.js中调用getIndexList获取数据,并调用index.ejs模板:

在views/index.ejs创建首页模板:

展示数据完毕。

4.2 发表主题

我们在首页上添加了可以输入标题和内容的两个输入窗口,可以使用ajax的方式提交数据。

这里的提交接口是/list/addtopic,因此我们需要再创建一个这样的路由:在routes目录下创建list.js:

这里用到了list_m.addTopic,因此需要在models/list.js中添加 addTopic 方法:

4.3 详情页

在首页列表中,可以看到,我们将详情页的链接设置为了/list/1.html的方式,也可以设置成其他的方式(比如 /list&#;pid=1 等),只要设置好路由就行。

在详情页中需要获取到这个主题的详细信息和对这个主题的回复,因此在list_m中:

然后在路由中进行调用,这里使用async简单的控制了下两个异步的流程问题:

稍微解释下async.parallel的功能,下节我们会详细的讲解。 async.parallel([f1, f2, f3,…, fn], fb); 是f1到fn所有的异步都执行完了就会执行fb函数。这里我们是主题的详情和对主题的回复都请求完成了,就可以调用模板渲染。

对主题的回复功能可以自己实现一下。

总结

写着写着就发现篇幅这么大了,而且充斥了大量的代码,需要我们细心的理解。下面给出详细的示例代码,大家可以下载学习,希望本文的内容对大家能有所帮助。

下载地址:点击这里

node.js入门学习之url模块 前言今天主要记录的是关于node.js里面的一个简单的模块,url模块。这个url的模块要使用的话需要先引入。若只是在命令行里比如cmd或gitbash等使用url这个

关于Sequelize连接查询时inlude中model和association的区别详解 前言大家都知道在使用Sequelize进行关系模型(表)间连接查询时,我们会通过model/as来指定已存在关联关系的连接查询模型,或是通过association来直接指

利用Node.js+Koa框架实现前后端交互的方法 前言对于一个前端工程师来说不仅仅要会前端的内容,后端的技术也需要熟练掌握。今天我就要通过一个案例来描述一下前端是如何和后端进行数据交

标签: node.js快速入门

本文链接地址:https://www.jiuchutong.com/biancheng/376388.html 转载请保留说明!

上一篇:从零学习node.js之express入门(六)(node js入门)

下一篇:node.js入门学习之url模块(node.js快速入门)

  • 应交增值税和未交增值税都有余额
  • 税务师入会与不入会冲突
  • 城市维护建设税优惠政策
  • 境外培训费计入关税完税价格
  • 如何理解合并报表中少数股东损益的抵消
  • 可供出售金融资产公允价值变动
  • 税控盘开票机号是哪个
  • 过路费报销属于什么费用科目
  • 外购原材料自用要进项转出吗
  • 有现金折扣方式有哪些
  • 外经证缴纳个税流程
  • 不得抵扣的会计分录
  • 支付股权投资的会计科目
  • 转出多交增值税借方余额表示
  • 意外死亡公司赔偿多少标准
  • 出口退税征税
  • 建筑业预收账款如何缴税
  • 发票作废了还能认证吗
  • 小规模纳税人需要汇算清缴吗
  • 城市公交可以承包吗
  • 固定资产在什么时候计提折旧
  • 工资计提不发放工资个税
  • 小规模纳税人别人开了专票怎样处理
  • 个人独资企业简易注销流程及材料
  • 发票单据流水号
  • 会议展览服务费需要交印花税吗
  • 少计提增值税0.01计入营业外
  • Win11如何设置快捷键调音量
  • 暂估入库材料分录
  • 自制原始凭证包括哪些凭证
  • vue中使用swiper6
  • 出租门面是否缴增值税
  • 业务招待费的纳税筹划
  • php中关键字修饰属性是什么
  • 关联方利息支出标准比例
  • 废旧物资回收经营单位
  • 非金融机构从事贷款谁负责监管
  • thinkphp怎么用
  • 前端工程搭建
  • 07. vue3+vite+qiankun搭建微应用前端框架,并接入vue3微应用
  • 包装费 增值税
  • mongodb4.4安装
  • Js模板字符串添加点击事件
  • php windows
  • 增值税 转出
  • 如何在国家税务局增值税纳税申报
  • 现金和现金等价物包括哪些
  • 没有综合所得的经营所得如何预扣预缴个税
  • 待摊费用和预提费用属于什么账户
  • 带息票据和不带息票据怎么区分
  • 没有进项票开了销项票后期有了进项票可以吗
  • 疫情期间制造费用账务处理
  • 火车票丢了还能再取吗
  • 宣告分配现金股利和股票股利的区别
  • sqlserver2008数据库定时备份
  • 金税四期对企业纳税管理影响分析
  • 临时用工费开票项目
  • 专门借款本金汇兑差额
  • 运输费和货款一样吗
  • 材料折扣会计分录
  • 未实现融资收益借贷方向
  • 服务费税额部分计算公式
  • 按不同要求分类
  • linux管理工具有哪些
  • linux系统中用户可以分为三种
  • winadslave.exe - winadslave是什么进程
  • xmpdisabled什么意思
  • ctd module
  • windows7包含6个版本其中什么最强大支持的功能最多
  • 好用linux
  • linux使用ssh命令
  • 前端 插件
  • javaweb技术栈是什么
  • dos脚本 菜鸟教程
  • 批处理文件是可执行文件吗
  • insmod: init_module 'hello.ko' failed (Exec format error)
  • Unity-DF 2048界面
  • js如何定义类
  • 所得税的核定征收方法
  • 国际税务网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设