《Node + Express 快速搭建网站》学习笔记-7删除功能及项目生成配置文件

4-1删除功能及项目生成配置文件

ch4-删除功能及项目生成配置文件

修改项目结构

静态文件目前存储在bower_components下面,但是与自定义静态文件不便于集中管理。
可以利用bower指定安装的静态文件目录的功能

.bowerrc 配置文件

{
    "directory": "public/libs"
}

删除“./bower_compinents/”目录

bower install bootstrap 

更改head模板静态资源路径

编写数据库交互(删)代码

app.js

...

//list delete movie
app.delete('/admin/list', function(req, res){
    var id = req.query.id;
    if(id){
        Movie.remove({_id: id}, function(err, movie){
            if(err){
                console.log(err);
            }else{
                res.json({success: 1});
            }
        });
    }
})

在list.js中添加事件代理js

extend ../layout

block content
    .container
        .row
            table.table.table-hover.table-bordered
                thead
                    tr
                        th 电影名字
                        th 导演
                        th 国家
                        th 上映年份
                        //- th 录入时间
                        th 查看
                        th 更新
                        th 删除
                    tbody
                        each item in movies
                            tr(class="item-id-#{item._id}")
                                td #{item.title}
                                td #{item.doctor}
                                td #{item.country}
                                td #{item.year}
                                //- td #{moment(item.meta.createedAt).format('MM/DD/YYYY')}
                                td: a(target="_blank", href="../movie/#{item._id}") 查看
                                td: a(target="_blank", href="../movie/update/#{item._id}") 修改
                                td
                                    button.btn.btn-danger.del(type="button", data-id="#{item._id}") 删除

    script(src="/js/admin.js")

/public/js/admin.js,处理逻辑

$(function(){
    $('.del').click(function(e){
        var target = $(e.target);
        var id = target.data('id');
        var tr = $('.item-id-' + id);

        $.ajax({
            type: 'DELETE',
            url: '/admin/list?id=' + id,

        }).done(function(results){
            if(results.success === 1){
                if(tr.length > 0){
                    tr.remove();
                }
            }
        });
    })
})

至此,前后端逻辑,包括数据库都已经全部实现。

最后,需要对前端、后端所依赖的模块和库的版本进行锁定,生成一个配置文件

生成配置文件

配置前端的静态资源 bower init

iMooc-temp Zelda$ bower init
? name iMooc
? description demo-node-express
? main file
? keywords imooc node express
? authors zelda 
? license MIT
? homepage
? would you like to mark this package as private which prevents it from being accidentally published to the registry? Yes
cidentally published to the registry? (y/N) y
{identally published to the registry? (y/N)
  name: 'iMooc',
  authors: [
    'zelda '
  ],
  description: 'demo-node-express',
  main: '',
  keywords: [
    'imooc',
    'node',
    'express'
  ],
  license: 'MIT',
  homepage: '',
  private: true,
  ignore: [
    '**/.*',
    'node_modules',
    'bower_components',
    'public/libs',
    'test',
    'tests'
  ],
  dependencies: {
    bootstrap: '^3.3.7'
  }
}

? Looks good? Yes

配置好之后就会生成bower.json配置文件

{
  "name": "iMooc",
  "authors": [
    "zelda "
  ],
  "description": "demo-node-express",
  "main": "",
  "keywords": [
    "imooc",
    "node",
    "express"
  ],
  "license": "MIT",
  "homepage": "",
  "private": true,
  "ignore": [
    "**/.*",
    "node_modules",
    "bower_components",
    "public/libs",
    "test",
    "tests"
  ],
  "dependencies": {
    "bootstrap": "^3.3.7"
  }
}

配置后端依赖 npm init

iMooc-temp Zelda$ npm init
This utility will walk you through creating a package.json file.
It only covers the most common items, and tries to guess sensible defaults.

See `npm help json` for definitive documentation on these fields
and exactly what they do.

Use `npm install  --save` afterwards to install a package and
save it as a dependency in the package.json file.

Press ^C at any time to quit.
name: (iMooc-temp) iMooc
Sorry, name can no longer contain capital letters.
name: (iMooc-temp) imooc
version: (1.0.0) 0.0.1
description: demo
entry point: (app.js)
test command:
git repository:
keywords: imooc node express
author: zelda
license: (ISC)
About to write to /Users/Zelda/Dev/demo/iMooc-temp/package.json:

{
  "name": "imooc",
  "version": "0.0.1",
  "description": "demo",
  "main": "app.js",
  "dependencies": {
    "body-parser": "^1.17.1",
    "express": "^4.15.2",
    "jade": "^1.11.0",
    "moment": "^2.17.1",
    "mongoose": "^4.9.0",
    "serve-static": "^1.12.1",
    "underscore": "^1.8.3"
  },
  "devDependencies": {},
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [
    "imooc",
    "node",
    "express"
  ],
  "author": "zelda",
  "license": "ISC"
}


Is this ok? (yes) y
iMooc-temp Zelda$

配置好之后生成package.json配置文件

{
  "name": "imooc",
  "version": "0.0.1",
  "description": "demo",
  "main": "app.js",
  "dependencies": {
    "body-parser": "^1.17.1",
    "express": "^4.15.2",
    "jade": "^1.11.0",
    "moment": "^2.17.1",
    "mongoose": "^4.9.0",
    "serve-static": "^1.12.1",
    "underscore": "^1.8.3"
  },
  "devDependencies": {},
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [
    "imooc",
    "node",
    "express"
  ],
  "author": "zelda",
  "license": "ISC"
}

下一步:

  • 电影分类
  • 角色、权限管理
  • 还未集成到Grunt自动重启服务等
  • 单元测试的实现

高级课程见:http://www.imooc.com/learn/197

你可能感兴趣的:(《Node + Express 快速搭建网站》学习笔记-7删除功能及项目生成配置文件)