美文网首页Node.jsnodeNode.js
node.js+layui+bootstrap快速开发响应式企业

node.js+layui+bootstrap快速开发响应式企业

作者: danieldai | 来源:发表于2017-01-08 20:34 被阅读11787次

前言:

最近使用node.js开发了一个简单的企业网站。发现node.js中许多现有的模块使用起来确实便捷,再配合前台json交互,网站就很快就开发完成。
相关工具:

  • node 4.4.5
  • mongodb3.2.6(64bit)
  • Robomongo0.9.0-RC8
  • webstrom11.0.1

先上效果图吧(没有美工,资源就网上搜了)
1、网站效果图:

网站首页.png 前台新闻列表.png

2、移动端显示:

移动端1.png
移动端2.png

3、后台管理系统:

登陆界面.png 新闻列表.png 管理员列表.png

一:网站整体结构(express+mongoose+bootstrap+layui):

1.1、服务端

  • express+mongoose:后台整体结构我直接参照之前写的一个express+mongoose实现增删改查的例子。栗子在这儿
  • express:一个node.js快速开发web应用的框架。
  • mongoose:一个在node.js异步环境下对mongodb进行便捷操作的对象模型工具。
  • moment.js:一个极好用的node.js时间模块。
  • svg-captcha:node.js图片验证码模块。
  • express-session:用户登录登录以及图片验证码校验时session管理。

1.2、网站

1.3、后台管理系统

  • Layui,一个很好用的前端框架,相对于bootstrap有各种实现好的功能直接用,如弹窗,时间选择器以及拥有活跃的社区。

二:主要功能:

  • 前台ui设计及信息展示。
  • 后台管理系统登录、注册。
  • 新闻,招聘,离职公告结合UEditor实现动态添加、删除。
  • express中使用图片验证码。
  • 用户反馈,用户反馈时后台消息弹窗提示。

三、开发流程及项目结构图:

  • 3.1、前台静态页面设计。
  • 3.2、express项目搭建、数据库设计、路由设计等。
  • 3.3、后台cms设计,UEditor整合express。
项目工程图.png

四、网站相关代码说明:

  • 4.1、导航栏选中变色;公共页面并不添加选中效果,在各自页面通过添加class实现选中效果。
//include_header.html包含所有的li链接。
  <li  id="main"><a href="/">首页</a></li>
//index.html页面初始化时执行
  $("#main").addClass("active");
  • 4.2、网页中轮播相片在手机端显示时,被等比例缩放,显得特别窄。
//index.html页面中给轮播img标签设置最小高度200px
<div class="item active">  
      ![](http://localhost:3000/web/images/index3.jpg)
</div>
  • 4.3、同样也是图片问题,使用UEditor上传图片内容后,如果图片过大,在手机端网页会图片撑开,不太友好。
//设置div的id为tabContent下所有的img标签最大宽度为屏幕90%
/*设置新闻详情图片最大宽度不超过90%,同时居中显示*/
#tabContent img{  max-width:90%;}
  • 4.4、ejs include实现重复代码抽,在页面中引用的时候,include进来就好了,不过要注意相对路径。如下图将网页中的共有的头部和尾部提取出来。


    include.png
//引入头部:
<%include ../common/include_header.html%>
//网页其他代码
//引入尾部:
<%include ../common/include_footer.html%>

五、后台管理系统相关代码说明:

  • 5.1、关于express下图片验证码模块svg-captcha,不过使用前先要安装express-session,因为我们需要使用session存验证码字符串,便于校验。详细使用介绍在这儿

  • 5.2、验证码模块安装配置好后,在用户登录或者注册的时候。如何实现点击图片验证码刷新呢。


    验证码示例.png
//网页中使用图片验证码的地方,有个style设置图片可以点击,同时onclick实现图片验证码点击刷新。
![](http://localhost:3000/captcha)
  • 5.3、当网站有用户提交反馈信息时,工作人员希望在后台可及时收到消息提示信息。想着简单的方法,通过js定时查询数据库,发现有数据更新及时弹窗提醒工作人员。效果如下:
弹窗消息提醒.png
//在页面初始化的时候执行,这里设置5秒执行一次。
 setInterval(getFeedbacks,5000);
//在admin/main.html中ajax查询数据库函数
function getFeedbacks(){  
         $.get("/admin/check_feedbacks",function(resu
![Uploading 弹窗消息提醒_987878.png . . .]lt){     
           if(result.status==='success'){         
                            layer.open({           
                                     type: '1' 
                                     ,offset: 'rb' //右下方                          
                                    ,id: 'LAY_demo'+'rb' //防止重复弹出            
                                    ,content: '<div style="padding: 20px 100px;">你有'+result.size+'条待处理反馈信息,请在反馈信息列表查看!</div>'            
                                    ,btn: '我知道了'           
                                    ,btnAlign: 'c' //按钮居中           
                                    ,shade: 0 //不显示遮罩           
                                    ,time: 10000 //10秒后自动关闭            
                                    ,anim: 2 //设置弹出的动画样式           
                                     ,yes: function(){               
                                              layer.closeAll();          
                                      }        
                               });     
                     }  
 });};
  • 5.4、关于后台使用到的分页建议参考代码,或者去layui找实例改。一般就是传当前页数,后台返回数据条数以及总数据条数。

六、服务端相关代码说明:

  • 6.1、关于后台权限问题,类似于java中过滤器。当用户访问登录及注册页面时可直接访问,但是当用户访问其他后台页面时,提醒用户先登录。app.js文件里面的路由文件是顺序执行的。
    参考资料
//网页中使用图片验证码的地方,有个style设置图片可以点击,同时onclick实现图片验证码点击刷新。
/*官网后台做操作是需要,登录验证*/
app.use(function(req,res,next){
              if (!req.session.user) {   
                       if(req.url=="/login"||req.url=="/register"){    
                                  next();//如果请求的地址是登录则通过,进行下一个请求    }    
                       else {     
                       res.redirect('/login');   
                 }  } 
                else if (req.session.user) 
                        {    
                              next(); 
                      }
});
/*后台登录验证*
//后台其他路由。
/require('./routes/admin')(app);
moment格式化.png
/*引入时间模块*/
var Moment = require('moment');
//使用Moment,获得格式化后的当前时间
var time=Moment().format('YYYY-MM-DD HH:mm');
  • 6.3、express中使用UEditor相关配置。多文本编辑器不管是ueditor还是images他们都需要直接放在public下,不然会出错。 参照这位朋友博客

  • 6.4、关于node.js中分页的处理。 资料

七、:最后

项目部署用的是阿里云的windows系统,懒得部署的话直接用在服务器上webstrom启动就是了。
也可参考我的另外一个博文: nssm部署node.js项目
素材来源: 一个神奇的高清图片库
完整源代码

所有资料都来自互联网,有冒犯之处请告知。

相关文章

  • nodejs学习收藏

    1、Node - 从0基础到实战企业官网 2、node.js+layui+bootstrap快速开发响应式企业网站...

  • node.js+layui+bootstrap快速开发响应式企业

    前言: 最近使用node.js开发了一个简单的企业网站。发现node.js中许多现有的模块使用起来确实便捷,再配合...

  • 快速掌握-bootstrap

    笔记-bootstrap 是什么 bootstrap 前端开发框架,可以快速的搭建 web 页面。 框架分为响应式...

  • js基础(6)

    27、移动端响应式布局开发 响应式布局开发 1、什么是响应式布局开发?把我们开发完成的产品,能够让其适配不同的设备...

  • 响应式布局---bootstrap框架

    移动端WEB开发之响应式布局 1.0 响应式开发原理 1.1 响应式开发原理 就是使用媒体查询针对不同宽度的设备进...

  • bootstrap

    BootStrap是基于HTML、CSS和JavaScript的框架,用来快速搭建开发前端页面,具备响应式特点,可...

  • “一套代码,三屏齐发”——响应式开发浅析

    响应式开发 响应式是什么? 它能帮我们做些什么? 我们该怎么应用?它能达到什么效果?工作之余,通过响应式开发,我梳...

  • Web工具&框架

    快速开发工具 bootstrap 响应式布局,移动设备优先bootstrap官网 Swiper 移动端滑动效果 S...

  • 响应式架构简介

    为什么企业级软件难以开发   在介绍响应式编程技术会使软件开发工作变得简单之前,让我们先了解一下开发企业级软件为何...

  • 响应式开发

    响应式开发 响应式网站设计 -----Ethan Marcotte 第一章 响应式网站设计的三大技术成分 流动网格...

网友评论

  • qianduanxuexi:您好后台账号密码是什么
    danieldai:@qianduanxuexi 你好,先需要,注册一个账号,再去数据库改一个字段就好了
  • 7be9de3efe97:老哥,为什么会出现captcha error ?
    danieldai:@toby2017 你是否安装了captcha模块?也有可能captcha模块作者不维护
  • c881b221f504:good ,tks
  • slimsallen:怎么我打开 前端 布局乱了
    danieldai:@音乐君 你用谷歌浏览器打开调试模式(F12),你可以看到一些文件引入有问题,因为你是部署到服务器,所以一些localhost路径要修改一下就可以了。
    slimsallen:@danieldai 你看我这个 啥问题 http://sallen.cc:3000
    danieldai:我以为真的有问题,刚刚还特意从github下载下来运行一下,样式是没有问题的,如果有问题可直接在github问。(我用的webstrom,下载下来先npm install安装依赖)
  • slimsallen:不错 多谢博主
  • 罗桂林:服务端源码链接貌似有问题,https后面少了个“:”,应该是:https://github.com/dpc761218914/express_restapi
    danieldai: @起这么长的名字根本没有用 私信了
    起这么长的名字根本没有用:项目可以运行但是能给一下后台登录账号和密码么?我想看一下后台添加的效果
    danieldai::smiley: 感谢提醒,已修改。

本文标题:node.js+layui+bootstrap快速开发响应式企业

本文链接:https://www.haomeiwen.com/subject/vedxbttx.html