首页前端开发JavaScriptexpress项目文件目录说明以及功能描述详解

express项目文件目录说明以及功能描述详解

时间2024-02-01 08:56:02发布访客分类JavaScript浏览993
导读:收集整理的这篇文章主要介绍了express项目文件目录说明以及功能描述详解,觉得挺不错的,现在分享给大家,也给大家做个参考。 app.js:启动文件,或者说入口文件package.jso...
收集整理的这篇文章主要介绍了express项目文件目录说明以及功能描述详解,觉得挺不错的,现在分享给大家,也给大家做个参考。

app.js:启动文件,或者说入口文件

package.json:存储着工程的信息及模块依赖,当在 dePEndencies 中添加依赖的模块时,运行 npm install,npm 会检查当前目录下的 package.json,并自动安装所有指定的模块

node_modules:存放 package.JSON 中安装的模块,当你在 package.json 添加依赖的模块并安装后,存放在这个文件夹下

public:存放 image、css、js 等文件

routes:存放路由文件

views:存放视图文件或者说模版文件

bin:存放可执行文件

打开app.js,让我们看看里面究竟有什么:

VAR exPress = require('exPRess');
    var path = require('path');
    var favicon = require('serve-favicon');
    var LOGger = require('morgan');
    var cookieParser = require('cookie-parser');
    var bodyParser = require('body-parser');
    var routes = require('./routes/index');
    var users = require('./routes/users');
    var app = express();
    // view engine SETUPapp.set('views', path.join(__dirname, 'views'));
    app.set('view engine', 'ejs');
    // uncomment after placing your favicon in /public//app.use(favicon(__dirname + '/public/favicon.ico'));
    app.use(logger('dev'));
    app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
 extended: false }
    ));
    app.use(cookieParser());
    app.use(express.static(path.join(__dirname, 'public')));
    app.use('/', routes);
    app.use('/users', users);
// catch 404 and forward to error handlerapp.use(function(req, res, next) {
        var err = new Error('Not Found');
        err.status = 404;
        next(err);
}
    );
// error handlers// development error handler// will print stacktraceif (app.get('env') === 'development') {
    app.use(function(err, req, res, next) {
            res.status(err.status || 500);
        res.render('error', {
            message: err.message,            error: err        }
    );
    }
    );
}
// production error handler// no stacktraces leaked to userapp.use(function(err, req, res, next) {
        res.status(err.status || 500);
    res.render('error', {
        message: err.message,        error: {
}
    }
    );
}
    );
    module.exports = app;

这里我们通过require()加载了express、path 等模块,以及 routes 文件夹下的index. js和 users.js 路由文件。 下面来讲解每行代码的含义。

(1) var app = express():生成一个express实例 app。

(2)app.set('views', path.join(__dirname, 'views')):设置 views 文件夹为存放视图文件的目录, 即存放模板文件的地方,__dirname 为全局变量,存储当前正在执行的脚本所在的目录。

(3)app.set('view engine', 'ejs'):设置视图模板引擎为 ejs。

(4)app.use(favicon(__dirname + '/public/favicon.ico')):设置/public/favicon.ico为favicon图标。

(5)app.use(logger('dev')):加载日志中间件。

(6)app.use(bodyParser.json()):加载解析json的中间件。

(7)app.use(bodyParser.urlencoded({ extended: false } )):加载解析URLencoded请求体的中间件。

(8)app.use(cookieParser()):加载解析cookie的中间件。

(9)app.use(express.static(path.join(__dirname, 'public'))):设置public文件夹为存放静态文件的目录。

(10)app.use('/', routes); 和app.use('/users', users):路由控制器。

(11)

app.use(function(req, res, next) {
        var err = new Error('Not Found');
        err.status = 404;
        next(err);
}
    );
    

捕获404错误,并转发到错误处理器。

(12)

if (app.get('env') === 'development') {
    app.use(function(err, req, res, next) {
            res.status(err.status || 500);
        res.render('error', {
            message: err.message,            error: err        }
    );
    }
    );
}
    

开发环境下的错误处理器,将错误信息渲染error模版并显示到浏览器中。

(13)

app.use(function(err, req, res, next) {
        res.status(err.status || 500);
    res.render('error', {
        message: err.message,        error: {
}
    }
    );
}
    );
    

生产环境下的错误处理器,不会将错误信息泄露给用户。

(14)module.exports = app :导出apP实例供其他模块调用。

我们再看 bin/www 文件:

#!/usr/bin/env nodevar debug = require('debug')('blog');
    var app = require('../app');
    app.set('port', process.env.PORT || 3000);
var server = app.listen(app.get('port'), function() {
      debug('Express server listening on port ' + server.address().port);
}
    );
    

(1)#!/usr/bin/env node:表明是 node 可执行文件。

(2)var debug = require('debug')('blog'):引入debug模块,打印调试日志。

(3)var app = require('../app'):引入我们上面导出的app实例。

(4)app.set('port', process.env.PORT || 3000):设置端口号。

(5)

var server = app.listen(app.get('port'), function() {
      debug('Express server listening on port ' + server.address().port);
}
    );
    

启动工程并监听3000端口,成功后打印 Express server listening on port 3000。

我们再看 routes/index.js 文件:

var express = require('express');
    var router = express.Router();
/* GET home page. */router.get('/', function(req, res) {
  res.render('index', {
 tITle: 'Express' }
    );
}
    );
    module.exports = router;
    

生成一个路由实例用来捕获访问主页的GET请求,导出这个路由并在app.js中通过app.use('/', routes); 加载。这样,当访问主页时,就会调用res.render('index', { title: 'Express' } ); 渲染views/index.ejs模版并显示到浏览器中。

我们再看看 views/index.ejs 文件:

!DOCTYPE htML>
    html>
      head>
        title>
    %= title %>
    /title>
        link rel='stylesheet' href='/stylesheets/style.css' />
      /head>
      body>
        h1>
    %= title %>
    /h1>
        p>
    Welcome to %= title %>
    /p>
      /body>
    /html>
    

在渲染模板时我们传入了一个变量 title 值为 express 字符串,模板引擎会将所有 %= title %> 替换为 express ,然后将渲染后生成的html显示到浏览器中,如上图所示。

在这一小节我们学习了如何创建一个工程并启动它,了解了工程的大体结构和运作流程,下一小节我们将学习 express 的基本使用及路由控制。

总结

到此这篇关于express项目文件目录说明以及功能描述的文章就介绍到这了,更多相关express项目文件目录内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • 详解nodejs的express如何自动生成项目框架
  • express 项目分层实践详解

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: 关于vuex强刷数据丢失问题解析下一篇:node.js利用express自动搭建项目...猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: express项目文件目录说明以及功能描述详解
本文地址: https://pptw.com/jishu/595188.html
ASP.NET网站管理系统退出 清除浏览器缓存,Session的代码 node.js利用express自动搭建项目的全过程

游客 回复需填写必要信息