一,创建表结构  /schemas/categories.js

var mongoose = require('mongoose')
 
module.exports = new mongoose.Schema({
  category_name : String,
})
 

二,创建模型 /models/Categories.js

var mongoose = require('mongoose')
var categoriesSchema = require('../schemas/categories')
 
module.exports= mongoose.model('Categories',categoriesSchema)

三,前台 ( 使用模板语法 ):

(一),  博客分类首页  : /views/category.html

{% extends 'layout.html' %}
{% block main %}
<ol class="breadcrumb">
  <li><a href="/admin">管理首页</a></li>
  <li><span>分类列表</span></li>
</ol>
<h3>分类列表</h3>
<table class="table table-bordered">
  <tr>
    <th>分类名称</th>
  </tr>
    <!-- 循环输出数组 . id是对象,需要转换成字符串 -->
 
  {% for category in categories %}
  <tr>
    <td> {{category.category_name}}</td>
    {% endfor %}
  </tr>
</table>
{% endblock %}

(二),  添加博客分类页面 : views/category_add.html

{% extends 'layout.html' %}
{% block main %}
<ol class="breadcrumb">
  <li><a href="/admin">管理首页</a></li>
  <li><span>添加分类</span></li>
</ol>
<h3>添加分类</h3>
<form method="POST">
  <div class="form-group">
  <label for="category_name">分类名称</label>
    <input type="text" class="form-control" name="category_name" id="category_name" placeholder="Category Name">
  </div>
  <button type="submit" class="btn btn-default">Submit</button>
</form>
{% endblock %}

四,后台引入模型  /router/admin.js

  var Category = require('../models/Category')
**
* 分类管理
*/
router.get('/category',(req,res)=>{ // 是/,而不是 ./
  

  Category.find().then((categories)=>{
    res.render('admin/category',{
      userInfo: req.userInfo,
      categories:categories
    })
  })
})
/**
* 添加分类
*/
router.get('/category/add',(req,res)=>{
  res.render('admin/category_add',{
    userInfo:req.userInfo
  })
})
/**
* 分类的保存 , 验证接收表单提交的信息
*/
router.post('/category/add',(req,res)=>{
  // console.log(req.body)
 
  // 当用户提交错误的信息,则返回错误的页面 (因为前台没有设置AJAX) => 渲染一个错误的页面(通用错误页面 : admin/error)
  var category_name = req.body.category_name || ''
  if(category_name == ''){
    res.render('admin/error',{
      userInfo:req.userInfo,
      message:' 分类名称不能为空 ',
      url:'/admin/category/add'
  })
    return // 中断
}
// 查询数据库中是否存在刚刚上传的分类名称,有则返回分类名称已存在的信息,没有则存储上传的分类名称
Category.findOne({
  category_name:category_name
}).then((fs)=>{
  /**
  * 【bug】此处不能填 category_name 。
  * 参数不能为查询的对象(为空),应是查询后返回的结果
  * then 方法返回的是一个 Promise 对象
  * 异步操作的最终状态(" 完成或失败 "),以及该异步操作的结果值。
  * */
  if(fs){
    res.render('admin/error',{
      userInfo:req.userInfo,
      message:' 分类名称已存在 ',
      url:'/admin/category/add'
  })
    return Promise.reject() // 返回一个带有拒绝原因reason参数的Promise对象。 表示状态失败
  }else{
    // 保存
    return new Category({
      category_name:category_name
    }).save()
  }
 
}).then((newCategory)=>{
  if(newCategory){
    res.render('admin/success',{
      userInfo:req.userInfo,
      message:' 添加分类成功 ',
      url:'/admin/category'
    })
  }
})
 

16 ~ express ~ 添加博客分类的更多相关文章

  1. 搭建自己的博客(九):使用shell模式批量添加博客文章并增加分页功能

    想做个博客分页功能,但是没有太多的文章.所以使用shell命令行创建多篇文章. 1.打开pycharm下的terminal终端 python manage.py shell # 打开python终端 ...

  2. 基于SMB协议的共享文件读写 博客分类: Java

    基于SMB协议的共享文件读写 博客分类: Java   一.SMB协议 SMB协议是基于TCP-NETBIOS下的,一般端口使用为139,445. 服务器信息块(SMB)协议是一种IBM协议,用于在计 ...

  3. Node.js 从零开发 web server博客项目[express重构博客项目]

    web server博客项目 Node.js 从零开发 web server博客项目[项目介绍] Node.js 从零开发 web server博客项目[接口] Node.js 从零开发 web se ...

  4. 原生js添加博客点击鼠标出小心心效果~~

    昨天刚申请成功JS权限,心血来潮想添加点东西,记得之前看到别人家博客首页点击鼠标的时候会出现炫酷的 “小心心”,自己也来搞一个.没有用jquery啥的框架,原生js写起来麻烦了点,不过主要是怕博客首页 ...

  5. paper 16 : 计算机视觉领域博客资源

    这是收录的图像视觉领域的博客资源的第一部分,包含:中国内地.香港.台湾 这些名人大家一般都熟悉,本文仅收录了包含较多资料的个人博客,并且有不少更新,还有些名人由于分享的paper.code或者数据集不 ...

  6. Node.js+Express搭建博客系统基本环境安装

    1.下载安装node.js 官网下载地址:https://nodejs.org/en/download/ 2.安装express. 打开node命令行工具,在命令行中输入:npm install -g ...

  7. ajaxFileUpload 报这错jQuery.handleError is not a function 博客分类: WEB前端jquery

    ajaxfileuploadhandleError  今天刚打个一个技术群,里面有人问标题上的问题,嘿,我恰好遇过,现在大家至少也在用jquery1.9以上的版本,ajaxfileupload的版本早 ...

  8. 在Eclipse中使用Maven插件 博客分类: Java相关技术

    简介 本文介绍如何在Eclipse中通过maven插件编写java项目和web项目. 安装Maven 下载Maven最新版本,见:maven.apache.org/download.html 当前版本 ...

  9. eclipse中 将java项目转换为web项目 博客分类: Tomcat

      1.找到项目工作空间目录,打开.project文件,并修改文件, 修改如下:      找到:<natures> </natures>代码段,在代码段中加入如下内容并保存: ...

随机推荐

  1. Python django 安装 mysqlclient 失败

    使用命令安装失败: C:\Program Files (x86)\Python\Python37-\Scripts>pip3..exe install mysqlclient Collectin ...

  2. js 保留两位小数 input要求是数字框,

    要求:input文本框只能输入数字,且只保留两位小数 问题:若设置input的  type="number" ,js处理部分若用到parseFloat方法处理,结果是string类 ...

  3. Link Analysis_1_Basic Elements

    1. Edge Attributes 1.1 Methods of category 1.1.1 Basic three categories in terms of number of layers ...

  4. C++ 类 与 static

    背景 从学习C++到使用现在,发现很多新的东西,正好整理一下. static 为静态,指是当类编译加载的时候,内存就会开辟存储空间的. static 数据成员 在类中,static 可修饰 类中的成员 ...

  5. Elasticsearch学习入门

    一.关于Elasticsearch 1.特点 Elasticsearch基于全文搜索引擎 Apache Lucene ,由Java开发而来,面向API进行搜索, Restful 风格,分布式文件存储. ...

  6. node - 处理跨域 ( 两行代码解决 )

    1,安装 cors 模块 : npm install cors 2,代码 : var express = require('express') var app = express() var cors ...

  7. [转]Android 如何建立AIDL

    建立AIDL服务要比建立普通的服务复杂一些,具体步骤如下: (1)在Eclipse Android工程的Java包目录中建立一个扩展名为aidl的文件.该文件的语法类似于Java代码,但会稍有不同.详 ...

  8. 打开c++ 项目遇到的错误

    前言 后续持续更新: 无法打开源文件windows.h https://blog.csdn.net/Mr__George/article/details/87714252 找不到duilib.h ht ...

  9. 014-查看PHP的环境变量

    <?php print("你正在用文件的名字为: "); print(__FILE__); print(" <BR>\n"); print(& ...

  10. Codeforces 459E Roland and Rose

    本以为是个树形DP,按照树形DP的方法在那里dfs,结果WA到死,因为它存在有向环,不是树,凡是存在环的情况切记不要用树形的方法去做 题目的突破点在于将边排完序之后,用点表示以该点为边结尾的最大长度, ...