node笔记-4.node服务端渲染简单的留言板功能

node服务端渲染简单的留言板功能

源码 github

目录结构

├─assets
├─node_modules
│  ├─ejs
│  │  └─lib
│  └─moment
│      ├─locale
│      ├─min
│      └─src
│          ├─lib
│          │  ├─create
│          │  ├─duration
│          │  ├─format
│          │  ├─locale
│          │  ├─moment
│          │  ├─parse
│          │  ├─units
│          │  └─utils
│          └─locale
└─view
    |-404.html
    |-index.html
    |-login.html
    |-release.html

主要nodeJS代码

  • ejs 模板完成动态的html渲染
  • moment包处理时间格式化
  • url包 处理get过来的请求参数并格式化
const http = require('http')
const ejs = require('ejs')
const url = require('url')
const moment = require('moment') //处理时间格式化
moment.locale('zh-cn');
const DirPath = './view' // 建议换成绝对路径 
// 创建服务器
const service = http.createServer()
let indexData = [
    {name:'张三',message:'粘弹说带上飞机的萨芬计划',dateTime:'2019-10-11'},
    {name:'李四',message:'就是觉得发喀什酱豆腐立刻洒家发生',dateTime:'2019-10-12'},
    {name:'王二麻子',message:'健身房的空间赛季分解机而非',dateTime:'2019-10-13'},
    {name:'小淘气',message:'核武i肉片附件是JFK了撒法',dateTime:'2019-10-14'},
    {name:'栓蛋',message:'对方门将批评家恩恩分为哦附件',dateTime:'2019-10-15'},
]
// 监听客户端请求
service.on('request',(req,res)=>{
  const parseUrl = url.parse(req.url,true)
  const uri = parseUrl.pathname
  const queryGet = parseUrl.query
  if( uri == '/' ){
    ejs.renderFile(DirPath+'/index.html',{indexData},(_,data)=>{
        res.end(data)
    })
  }else if(uri == '/release'){
    ejs.renderFile(DirPath+'/release.html',(_,data)=>{
        res.end(data)
    })
  }else if(uri == '/relaseGet'){
    console.log(queryGet)
    let item = {name:queryGet.name,message:queryGet.message,dateTime:moment(new Date()).format('YYYY-MM-DD')}
    indexData.push(item)
    // 页面重定向 到 首页
    res.statusCode = 302
    res.setHeader('Location','/')
    res.end()
  }else{
    ejs.renderFile(DirPath+'/404.html',(_,data)=>{
        res.end(data)
    })
  }
})
service.listen(3000,()=>{console.log('server is runing.')})
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。