美文网首页ITNotes
《Node + Express 快速搭建网站》学习笔记-7删除功

《Node + Express 快速搭建网站》学习笔记-7删除功

作者: 张大侠 | 来源:发表于2017-03-17 13:32 被阅读65次

    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 <ze.zh@hotmail.com>
    ? 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 <ze.zh@hotmail.com>'
      ],
      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 <ze.zh@hotmail.com>"
      ],
      "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 <pkg> --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删除功

        本文链接:https://www.haomeiwen.com/subject/ohsenttx.html