网站环境:使用express框架、bootstrap样式、jade模板、mongoose数据库

npm insatll express -g
npm insatll jada -g
npm insatll mongoose -g

1、创建express工程:myMovie

进入工程执行npm install,npm start 后 访问很正常,可以往下继续了

2、创建路由,打通入口

初拟可能浏览的入口================

网站跟目录:localhost:3000/

某个电影详情页:localhost:3000/movie/1

后台电影添加页:localhost:3000/admin/add

后台列表页:localhost:3000/admin/list

根据所需修改app.js

var express = require("express");
var app=express(); //访问网站跟目录:localhost:3000/
app.get("/",function(req,res){
res.send("网站首页");
}); //localhost:3000/movie/1
app.get("/movie/:id",function(req,res){
res.send("电影详情");
}); //localhost:3000/admin/add
app.get("/admin/add",function(req,res){
res.send("后台电影添加页");
}); //localhost:3000/admin/list
app.get("/admin/list",function(req,res){
res.send("后台电影列表");
}); app.listen(3030,function(){
console.log("请访问http://localhost:3030");
});

3、jade准备视图

index.jade主页、add.jade后台添加页、detail.jade(电影详情)、list.jade(后台电影列表)的准备,为了便于观察,放入基本的信息,用于关联jade视图

app.js

var express = require("express");
var app=express();
var path = require('path'); //设置模板引擎
app.set("view engine",'jade');
app.set('views','./views/pages'); //设置静态资源
app.use(express.static(path.join(__dirname, './public'))); //访问网站跟目录:localhost:3000/
app.get("/",function(req,res){
res.render('index.jade',{
title:'网站首页',
movies:{}
});
}); //localhost:3000/movie/1
app.get("/movie/:id",function(req,res){
res.render('detail.jade',{
title:'电影详情',
movie:{}
})
}); //localhost:3000/admin/add
app.get("/admin/add",function(req,res){
res.render('control.jade',{
title:'后台电影添加页',
movie:{}
});
}); //localhost:3000/admin/list
app.get("/admin/list",function(req,res){
res.render('list.jade',{
title:'后台电影列表',
movies:{}
});
}); app.listen(3000,function(){
console.log("请访问http://localhost:3000");
});

layout.jade

doctype html
html
head
meta(charset="utf-8")
title #{title}
include ./includes/link.jade
body
include ./includes/header.jade
block content

header.jade

.container
.row
.page-header
h1 #{title}

index.jade、control.jade、detail.jade、list.jade

extends ../layout.jade
block content

4、jade数据伪造

app.js

var express = require("express");
var app=express();
var path = require('path'); //设置模板引擎
app.set("view engine",'jade');
app.set('views','./views/pages'); //设置静态资源
app.use(express.static(path.join(__dirname, './public'))); //访问网站跟目录:localhost:3000/
app.get("/",function(req,res){
res.render('index.jade',{
title:'网站首页',
movies:[
{
_id:1,
title:"海绵宝宝3D",
poster: 'http://img31.mtime.cn/mg/2015/11/17/094620.70277104_170X256X4.jpg'
},
{
_id:2,
title:"星际迷航3",
poster:'http://img31.mtime.cn/mg/2016/09/01/143653.31713698_170X256X4.jpg'
},
{
_id:3,
title:"惊天绑架团",
poster:'http://img31.mtime.cn/mg/2016/07/12/091819.79722823_170X256X4.jpg'
},
{
_id:4,
title:"爱宠大机密",
poster:'http://img31.mtime.cn/mg/2016/06/21/093149.12209704_170X256X4.jpg'
},
{_id:5,
title:"冰川时代4",
poster:'http://img31.mtime.cn/mt/2012/07/19/131845.38602455_170X256X4.jpg'
}
]
});
}); //localhost:3000/movie/1
app.get("/movie/:id",function(req,res){
res.render('detail.jade',{
title:'电影详情',
movie:{
title:'海绵宝宝3D',
director:'保罗·蒂比特',
country:'美国',
language:'英语',
year:2016,
poster:'http://img31.mtime.cn/mg/2015/11/17/094620.70277104_170X256X4.jpg',
summary:'安东尼奥·班德拉斯饰演的大反派海盗杰克现身,他找到了一本神奇的宝书,可是想要获得完全的力量,一定要找到书中的最后一页。经过调查,这宝贵的最后一页,正存在海绵宝宝的家里。',
flash:'#'
}
})
}); //localhost:3000/admin/add
app.get("/admin/add",function(req,res){
res.render('control.jade',{
title:'后台电影添加页',
movie:{
title:'',
director:'',
country:'',
language:'',
year:'',
poster:'',
summary:'',
flash:''
}
});
}); //localhost:3000/admin/list
app.get("/admin/list",function(req,res){
res.render('list.jade',{
title:'后台电影列表',
movies:[
{
_id:1,
title:'海绵宝宝3D',
director:'保罗·蒂比特'
}
]
});
}); app.listen(3000,function(){
console.log("请访问http://localhost:3000");
});

index.jade

extends ../layout.jade
block content
.container
.row
each item in movies
.col-md-2
.thumbnall
a(href="/movie/#{item._id}")
img(src="#{item.poster}",alt="#{item.title}")
.caption
h3 #{item.title}
p: a.btn.btn-primary(href="/movie/#{item._id}") 查看详情

detail.jade

extends ../layout.jade
block content
.container
.row
.col-md-7
video(src="#{movie.flash}",autoplay="true",width="720",height="400")
.col-md-5
dl.dl-horizontal
dt 电影名字
dd=movie.title
dt 导演
dd=movie.director
dt 国家
dd=movie.country
dt 上映年份
dd=movie.year
dt 简介
dd=movie.summary

list.jade

extends ../layout.jade
block content
.container
.row
table.table.table-hover.table-bordered
thead
tr
th 电影名字
th 导演
th 查看
th 更新
th 删除
tbody
each item in movies
tr
td #{item.title}
td #{item.director}
td: a(target="_blank",href="../movie/#{item._id}") 查看
td: a(target="_blank",href="../movie/update/#{item._id}") 修改
td
a.btn.btn-danger.del(type="button",href="/admin/delete?id=#{item._id}") 删除

control.jade

extends ../layout.jade
block content
.container
.row
form.form-horizontal(method="post",action="/admin/movie/do")
//电影名字
.form-group
label.col-sm-2.control-label(for="inputTitle") 电影名字:
.col-sm-10
input#inputTitle.form-control(type="text",name="movie[title]",value="#{movie.title}")
//导演
.form-group
label.col-sm-2.control-label(for="inputTitle") 导演:
.col-sm-10
input#inputDirector.form-control(type="text",name="movie[director]",value="#{movie.director}")
//国家
.form-group
label.col-sm-2.control-label(for="inputCountry") 国家:
.col-sm-10
input#inputCountry.col-sm-10.form-control(type="text",name="movie[country]",value="#{movie.country}")
//语言
.form-group
label.col-sm-2.control-label(for="inputLanguage") 语言:
.col-sm-10
input#inputLanguage.col-sm-10.form-control(type="text",name="movie[language]",value="#{movie.language}")
//上映年份
.form-group
label.col-sm-2.control-label(for="inputYear") 上映年份:
.col-sm-10
input#inputYear.col-sm-10.form-control(type="text",name="movie[year]",value="#{movie.year}")
//简介
.form-group
label.col-sm-2.control-label(for="inputSummary") 简介:
.col-sm-10
input#inputSummary.col-sm-10.form-control(type="text",name="movie[summary]",value="#{movie.summary}")
.form-group
.col-sm-2
.col-sm-10
input.btn.btn-default(type="submit",name="submit")

各页效果预览

下载>>

目前,静态页面已经准备完毕,接着将接入mongodb

Nodejs电影建站开发实例(上)的更多相关文章

  1. Nodejs电影建站开发实例(下)

    作为一个真正的网站,不能没有数据的支持,下面使用的数据库为mongodb,电影可能有的数据:电影名称.导演.国家.语言.上映时间.图片.简介.视频 4.使用路由 app.js var express ...

  2. Mac电脑 阿里云ECS(ContentOS) Apache+vsftpd+nodejs+mongodb建站过程总结

    简介:我这里采用的阿里云免费提供的6个月ECS服务器:制作了一个简单的爬虫程序:里面很多功能还么做:搜索里面功能回去的数据未做处理会崩溃(大家不要点搜索功能):地址:http://loldragon. ...

  3. Hexo 静态博客指南:建站教程(上)

    本文最初发布于我的个人博客Bambrow's Blog,采用 BY-NC-SA 许可协议,转载请注明出处.若有后续更新,将更新于原博客.欢迎去我的博客阅读更多文章! 本文详细记录一下站点建立过程,以便 ...

  4. 在mvc4中多语言建站的实例

    环境:vs2012 asp.net mvc4. 实现方式:resource 资源文件,根据路由规则中Lang参数来判断载入哪种语言方式 在网上找到了相关资料,顺便自己做了个练习,新建工程之类的步骤就免 ...

  5. [web建站] 优课急送《零基础快速学习建站》视频+课件【价值399元】

    [课程介绍]你想快速建一个网站出来吗?你想从什么都不懂到一两天出一个漂漂亮亮的站吗?你想完成领导交给你的任务找人建站吗?你想自己建站来创业吗?你想学会建站之后,利用给别人建站来赚钱吗?你想建一个跟某个 ...

  6. WAP自助建站平台娃派宣布关闭 感谢建站之路有你的启蒙

    如题所示的这篇文章是我心血来潮在网上搜索到的,写的挺让我感同身受的,不妨先看一下原文吧. 原文 不知是偶然还是"冥冥定数",最后一次访问娃派建站(wap.ai)已有数十月之久了,突 ...

  7. Nodejs学习笔记(三)——一张图看懂Nodejs建站

    前言:一条线,竖着放,如果做不到精进至深,那就旋转90°,至少也图个幅度宽广. 通俗解释上面的胡言乱语:还没学会爬,就学起走了?! 继上篇<Nodejs学习笔记(二)——Eclipse中运行调试 ...

  8. 开发小白也毫无压力的hexo静态博客建站全攻略 - 躺坑后亲诉心路历程

    目录 基本原理 方法1 - 本机Windows下建站 (力荐) 下载安装node.js 用管理员权限打开命令行,安装hexo-cli和hexo 下载安装git 初始化hexo 使用hexo gener ...

  9. [web建站] 极客WEB大前端专家级开发工程师培训视频教程

    极客WEB大前端专家级开发工程师培训视频教程  教程下载地址: http://www.fu83.cn/thread-355-1-1.html 课程目录:1.走进前端工程师的世界HTML51.HTML5 ...

随机推荐

  1. 【原】storm源码之storm代码结构【译】

    说明:本文翻译自Storm在GitHub上的官方Wiki中提供的Storm代码结构描述一节Structure of the codebase,希望对正在基于Storm进行源码级学习和研究的朋友有所帮助 ...

  2. POJ 3691 DNA repair(AC自动机+DP)

    题目链接 能AC还是很开心的...此题没有POJ2778那么难,那个题还需要矩阵乘法,两个题有点相似的. 做题之前,把2778代码重新看了一下,回忆一下当时做题的思路,回忆AC自动机是干嘛的... 状 ...

  3. Graph database_neo4j 底层存储结构分析(5)

    3.5 Property 的存储 下面是neo4j graph db 中,Property数据存储对应的文件: neostore.propertystore.db neostore.propertys ...

  4. .net操作xml文件(新增.修改,删除,读取)---datagridview与xml文件

    参考网址: http://www.cnblogs.com/liguanghui/archive/2011/11/10/2244199.html 很详细的,相信能给你一定的帮助.

  5. 简单了解Flux,注意这是一个设计思想,是一个架构!!!!!

    在RN开发中,我们总是需要去更改一个组件个数据(也就是所谓的状态),我们一般是采用是在初始化的函数constror()(好像拼错了) 在这个函数里面申明我们的初始化数据(状态)eg:this.stat ...

  6. javamail发送邮件的简单实例

    今天学习了一下JavaMail,javamail发送邮件确实是一个比较麻烦的问题.为了以后使用方便,自己写了段代码,打成jar包,以方便以后使用.呵呵 以下三段代码是我的全部代码,朋友们如果想用,直接 ...

  7. 基于HTML5实现的超酷摄像头(HTML5 webcam)拍照功能 - photobooth.js

    在线演示 WebRTC可能是明年最受关注的HTML5标准了,Mozilla为此开发了一套帮助你控制硬件的API,例如,摄像头,麦克风,或者是加速表.你可以不依赖其它的插件来调用你需要的本机硬件设备. ...

  8. ArcEngine 不能再打开其他表了

    在IFeatureClass.Search()是弹出这个问题,根据网上的资料,采用 System.Runtime.InteropServices.Marshal.ReleaseComObject()或 ...

  9. prelaod场景,用来显示资源加载进度

    phaser.js的源码可以到它在github上的托管里去下载,游戏要用到的图片声音等素材资源请点击这里下载.Phaser的使用非常简单,只需要引入它的主文件,然后在页面中指定一个用来放置canvas ...

  10. Lucene实战(第2版)》

    <Lucene实战(第2版)>基于Apache的Lucene 3.0,从Lucene核心.Lucene应用.案例分析3个方面详细系统地介绍了Lucene,包括认识Lucene.建立索引.为 ...