nodejs教程之制作一个简单的文章发布系统

前端技术 2023/09/08 JavaScript

前言

我们今天就来做一个简单的新闻发布系统,系统第一阶段不需要太难,主要有以下功能

① 新闻类型管理

② 新闻管理(具有图片上传功能)

③ 新闻浏览

功能虽然不多,但是也涵盖很多基本操作了,程序不过增删查改嘛,外加上传附件,够了。于是开始我们今天的学习吧

准备工作

根据昨天的折腾后,我们已经有了nodeJS与mongoDB环境了,现在直接新建工程文件与数据库文件即可

第一步,打开命令符切换到D盘后输入

复制代码 代码如下:
D:\\>express -e news

于是系统会自动开开心心构建基本环境

很明显,里面很多模块依赖没有,这个时候将昨天的package.json直接考过来:

复制代码 代码如下:

{
  \"name\": \"application-name\",
  \"version\": \"0.0.1\",
  \"private\": true,
  \"scripts\": {
    \"start\": \"node app.js\"
  },
  \"dependencies\": {
    \"express\": \"3.4.8\",
    \"ejs\": \"*\",
    \"mongodb\": \"*\"
  }
}

然后切换到项目目录下:

复制代码 代码如下:
nmp install

依赖文件全部搞下来了,然后我们输入

复制代码 代码如下:

D:\\news>node app
Express server listening on port 3000

于是,我们的程序高高兴兴的运行起来了,打开网址一看,确实没问题

PS:这里有个问题需要注意,我们下载下来的文件不是UTF-8编码,所以中文可能有乱码,文件编码需要各位自己统一

程序跑起来了就需要数据库相关的配置了

① 首先在mongoDB目录中新建news文件夹

② 为项目新增配置文件settings.js

复制代码 代码如下:

module.exports = {
  cookieSecret: \'myNews\',
  db: \'news\',
  host: \'localhost\'
};

③ 新建models目录,新建db.js

复制代码 代码如下:

var settings = require(\'../settings\'),
    Db = require(\'mongodb\').Db,
    Connection = require(\'mongodb\').Connection,
    Server = require(\'mongodb\').Server;
module.exports = new Db(settings.db, new Server(settings.host, Connection.DEFAULT_PORT), { safe: true });

④ 在桌面新建news.bat程序

复制代码 代码如下:
d:\\mongodb\\bin\\mongod.exe -dbpath d:\\mongodb\\news

以后要启动数据库,只需要运行他即可,如此,我们初步的准备工作基本结束

但是这里有两个比较烦的事情,一个是每次要启动news程序很烦,二个是修改任何东西都需要重启,于是我们这里先解决这两个问题

① 在桌面新建news_app.bat,以后运行他就可以启动程序了

复制代码 代码如下:
node d:\\news\\app

② supervisor为一进程保护程序,我们可以使用他帮我们重启程序,首先按照,然后调整我们的node_app.bat

复制代码 代码如下:
supervisor d:\\news\\app

当然之前需要安装:

复制代码 代码如下:
npm install -g supervisor

这个样子后,修改了文件就不需要手动重启了(需要将news_app放到项目目录下),于是准备工作到此为止

项目结构

第一步结束后,我们就需要思考下项目结构了

① 首页为index这里将列出所有新闻类型以及对于新闻条目

② 各个新闻条目拥有编辑/删除/查看 三个按钮

③ 首页具有增加新闻按钮(增加时候可上传图片)

基本功能如上

于是,我们去掉app里面的路由功能,将路由全部放到index里面

复制代码 代码如下:

//将路由功能放入index
//app.get(\'/\', routes.index);
//app.get(\'/users\', user.list);
routes(app);

复制代码 代码如下:

module.exports = function (app) {
  //主页,现在也是首页
  app.get(\'/\', function (req, res) {
    res.render(\'index\', { title: \'Express\' });
  });
  app.get(\'/add\', function (req, res) {
    res.send(\'增加新闻请求\');
  });
  app.get(\'/delete\', function (req, res) {
    res.send(\'删除新闻请求\');
  });
  app.get(\'/view\', function (req, res) {
    res.send(\'查看新闻请求\');
  });
  app.get(\'/update\', function (req, res) {
    res.send(\'修改新闻请求\');
  });
};

第一步简单如此,因为增加新闻应该有单独的页面,而具体点击增加按钮又会有其他处理,所以内部还得细分各个请求,现在规定如下:

/ 默认页面,该页面显示所有类型以及新闻,并带有删除按钮

/add 进入添加新闻页面

/addNews 添加新闻具体post请求地址(点击按钮时候的响应)

/delete 删除新闻请求

/view 具体新闻查询

于是稍微修改下上述路由:

复制代码 代码如下:

module.exports = function (app) {
  //主页,现在也是首页
  app.get(\'/\', function (req, res) {
    res.render(\'index\', { title: \'Express\' });
  });
  app.get(\'/add\', function (req, res) {
    res.send(\'添加新闻页面\');
  });
  app.post(\'/addNews\', function (req, res) {
    res.send(\'处理添加新闻请求\');
  });
  app.get(\'/delete\', function (req, res) {
    res.send(\'删除新闻请求\');
  });
  app.get(\'/view\', function (req, res) {
    res.send(\'查看新闻请求\');
  });
};

于是我们需要新建几个模板组织我们的网页,这里我们先不分离头尾只要最简单的页面即可

新增add与view两个模板文件,暂时表现与index.ejs一致,并且修改导航相关

复制代码 代码如下:

module.exports = function (app) {
  //主页,现在也是首页
  app.get(\'/\', function (req, res) {
    res.render(\'index\', { title: \'Express\' });
  });
  app.get(\'/add\', function (req, res) {
    res.render(\'add\', { title: \'添加新闻页面\' });
  });
  app.post(\'/addNews\', function (req, res) {
    res.send(\'处理添加新闻请求\');
  });
  app.get(\'/delete\', function (req, res) {
    res.send(\'删除新闻请求\');
  });
  app.get(\'/view\', function (req, res) {
    res.render(\'view\', { title: \'查看新闻请求\' });
  });
};

至此项目结构结束

数据操作

整体结构出来后,我们就需要进行数据操作了:

① 增加数据(增加新闻)

② 展示数据(展示新闻)

③ 删除数据(删除新闻)

本来还涉及到类型操作的,但是做着做着给搞没了,暂时不管他吧,因为首次做容易迷糊

增加新闻

这里,我们就不使用表单提交了,我们用ajax......这里顺便引入zepto库,于是我们的页面成了这样

复制代码 代码如下:

<!DOCTYPE html>
<html>
<head>
    <title>
        <%= title %></title>
    <link rel=\'stylesheet\' href=\'/stylesheets/style.css\' />
    <script src=\"javascripts/zepto.js\" type=\"text/javascript\"></script>
</head>
<body>
    <h1>
        <%= title %></h1>
    <div>
        标题:<input type=\"text\" id=\"title\" />
    </div>
    <div>
        内容:<textarea id=\"content\"></textarea>
    </div>
    <div>
        <input type=\"button\" type=\"button\" id=\"ok\" value=\"添加新闻\" />
    </div>
    <script type=\"text/javascript\">
        $(document).ready(function () {
            $(\'#ok\').click(function () {
                var param = {};
                param.title = $(\'#title\').val();
                param.content = $(\'#content\').val();
                $.post(\'/addNews\', param, function () {
                    console.log(\'添加成功\');
                });
            });
        });
    </script>
</body>
</html>

虽然现在还没有请求响应程序,所以数据并不会被处理,另外我们这里的附件也没有(现在附件只允许一个好了),于是再修改下代码,加入图片:

PS:比较麻烦的是图片经过ajax处理有点麻烦,所以我们这里乖乖的换回form操作算了,不然又要搞多久......

复制代码 代码如下:

<html>
<head>
    <title>
        <%= title %></title>
    <link rel=\'stylesheet\' href=\'/stylesheets/style.css\' />
</head>
<body>
    <h1>
        <%= title %></h1>
    <form enctype=\"multipart/form-data\" method=\"post\"  action=\"/addNews\">
    <div>
        标题:<input type=\"text\" id=\"title\" name=\"title\" />
    </div>
    <div>
        图片:<input type=\"file\" id=\"pic\" name=\"pic\" />
    </div>
    <div>
        内容:<textarea id=\"content\" name=\"content\"></textarea>
    </div>
    <div>
        <input  type=\"submit\" id=\"ok\" value=\"添加新闻\" />
    </div>
    </form>
</body>
</html>

这个样子就不需要过多的考虑附件问题,先暂时如此吧,现在先处理请求程序,这里先在public里面新建news文件夹用于存储其图片

model

在models文件夹新增news.js文件,为其构建实体,并赋予新增查询相关操作:

复制代码 代码如下:

var mongodb = require(\'./db\');

function News(title, content, pic) {
  this.title = title;
  this.content = content;
  this.pic = pic;//保存存储路径
};
module.exports = News;
//存储数据
News.prototype = {
  save: function (callback) {
    var date = new Date();
    var time = {
      date: date,
      year: date.getFullYear(),
      month: date.getFullYear() + \"-\" + (date.getMonth() + 1),
      day: date.getFullYear() + \"-\" + (date.getMonth() + 1) + \"-\" + date.getDate(),
      minute: date.getFullYear() + \"-\" + (date.getMonth() + 1) + \"-\" + date.getDate() + \" \" +
      date.getHours() + \":\" + (date.getMinutes() < 10 ? \'0\' + date.getMinutes() : date.getMinutes())
    }
    //数据存储对象
    var news = {
      title: this.title,
      content: this.content,
      pic: this.pic, //图片处理最后来说,现在先乱存
      time: time
    };
    //打开数据连接,打开就是一个回调......
    mongodb.open(function (err, db) {
      //错误就退出
      if (err) {
        return callback(err);
      }
      //打开news集合
      db.collection(\'news\', function (err, collection) {
        if (err) {
          mongodb.close();
          return callback(err);
        }
        //写入集合(写入数据库)
        collection.insert(news, { safe: true }, function (err) {
          return callback(err);
        });
        callback(null);//err为null
      });
    });
  }
};

本文地址:https://www.stayed.cn/item/23210

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。