打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
node.js留言板案例

文章目录

示例

链接

https://download.csdn.net/download/weixin_45525272/15356934

注意

  • 判断访问路径 不包含 ? 之后的内容
  • 省略server简写方式,http .createServer(function (req, res) { }该函数会直接被注册为 server 的 request 请求事件处理函数
    使用 url.parse() 方法将路径解析为一个方便操作的对象,第二个参数为 true 表示直接将查询字符串转为一个对象(通过 query 属性来访问)
  • template.render() 默认读取到的data是二进制数据,模板引擎的render接收的是字符串,需要data转toString
  • /public资源统一处理操作
    • 如果请求路径是以 /public/ 开头的,则我认为你要获取 public 中的某个资源
    • 所以我们就直接可以把请求路径当作文件路径来直接进行读取
  • 界面操作导致的parseObj变化
  • 在服务端中,文件中的路径就不要去写相对路径了。
    因为这个时候所有的资源都是通过 url 标识来获取的
    我的服务器开放了 /public/ 目录
    所以这里的请求路径都写成:/public/xxx
    / 在这里就是 url 根路径的意思。
    浏览器在真正发请求的时候会最终把 http://127.0.0.1:3000 拼上,不要再想文件路径了,把所有的路径都想象成 url 地址

代码

app.js

// 模块加载
var http = require('http')
var fs = require('fs')
var url = require('url')
var template = require('art-template')

// 评论留言数组
var comments = [
  {
    name: '张三',
    message: '今天天气不错!',
    dateTime: '2019-10-16'
  },
  {
    name: '大壮2',
    message: '今天天气不错!',
    dateTime: '2019-10-16'
  },
  {
    name: '喜子',
    message: '今天天气不错!',
    dateTime: '2018-10-16'
  },
  {
    name: '蒙蒙',
    message: '今天天气不错!',
    dateTime: '2018-10-16'
  },
  {
    name: '小舞',
    message: '今天天气不错!',
    dateTime: '2018-10-16'
  }
]

// 请求模块
http
  .createServer(function (req, res) { 
    var parseObj = url.parse(req.url, true)

    // 单独获取不包含查询字符串的路径部分(该路径不包含 ? 之后的内容)
    var pathname = parseObj.pathname
    
    if (pathname === '/') {
      fs.readFile('./views/index.html', function (err, data) {
        if (err) {
          return res.end('404 Not Found.')
        }
        var htmlStr = template.render(data.toString(), {
          comments: comments
        })
        res.end(htmlStr)
      })
    } else if (pathname === '/post') {
      // 其它的都处理成 404 找不到
      fs.readFile('./views/post.html', function (err, data) {
        if (err) {
          return res.end('404 Not Found.')
        }
        res.end(data)
      })
    } else if (pathname.indexOf('/public/') === 0) {
      fs.readFile('.' + pathname, function (err, data) {
        if (err) {
          return res.end('404 Not Found.')
        }
        res.end(data)
      })
    } else if (pathname === '/pinglun') {
      var comment = parseObj.query
      var myDate = new Date();
      myDate.toLocaleString(); //获取日期与时间
      comment.dateTime = myDate
      comments.unshift(comment)

      res.statusCode = 302
      res.setHeader('Location', '/')
      res.end()
    } else {
      // 其它的都处理成 404 找不到
      fs.readFile('./views/404.html', function (err, data) {
        if (err) {
          return res.end('404 Not Found.')
        }
        res.end(data)
      })
    }
  })
  .listen(3000, function () {
    console.log('running...')
  })

index.html

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>留言本</title>
  <!-- 
    浏览器收到 HTML 响应内容之后,就要开始从上到下依次解析,
    当在解析的过程中,如果发现:
      link
      script
      img
      iframe
      video
      audio
    等带有 src 或者 href(link) 属性标签(具有外链的资源)的时候,浏览器会自动对这些资源发起新的请求。
   -->
   <!-- 
      注意:在服务端中,文件中的路径就不要去写相对路径了。
      因为这个时候所有的资源都是通过 url 标识来获取的
      我的服务器开放了 /public/ 目录
      所以这里的请求路径都写成:/public/xxx
      / 在这里就是 url 根路径的意思。
      浏览器在真正发请求的时候会最终把 http://127.0.0.1:3000 拼上

      不要再想文件路径了,把所有的路径都想象成 url 地址
    -->
  <link rel="stylesheet" href="/public/css/bootstrap.css">
</head>

<body>
  <div class="header container">
    <div class="page-header">
      <h1>Example page header <small>Subtext for header</small></h1>
      <a class="btn btn-success" href="/post">发表留言</a>
    </div>
  </div>
  <div class="comments container">
    <ul class="list-group">
      {{each comments}}
      <li class="list-group-item">{{ $value.name }}说:{{ $value.message }} <span class="pull-right">{{ $value.dateTime }}</span></li>
      {{/each}}
    </ul>
  </div>
</body>

</html>


post.html

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <link rel="stylesheet" href="/public/css/bootstrap.css">
</head>

<body>
  <div class="header container">
    <div class="page-header">
      <h1><a href="/">首页</a> <small>发表评论</small></h1>
    </div>
  </div>
  <div class="comments container">
    <form action="/pinglun" method="get">
      <div class="form-group">
        <label for="input_name">你的大名</label>
        <input type="text" class="form-control" required minlength="2" maxlength="10" id="input_name" name="name" placeholder="请写入你的姓名">
      </div>
      <div class="form-group">
        <label for="textarea_message">留言内容</label>
        <textarea class="form-control" name="message" id="textarea_message" cols="30" rows="10" required minlength="5" maxlength="20"></textarea>
      </div>
      <button type="submit" class="btn btn-default">发表</button>
    </form>
  </div>
</body>

</html>
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
node.js从入门到菜鸟——资源无法载入?你需要学会地址解析
NodeJS文件文件夹/文件操作 | 码客
3步轻松制作属于自己的浏览器导航
一个好玩的辞职信HTML版
【Go语言实战】(2) Gin+Vue 电子商城
Node.js路由改造
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服