Express细节探究(1)——app.use(express.static)

express相信是很多人用nodejs搭建服务器的首选框架,相关教程有很多,也教会了大家来如何使用。如果你想更深的了解他的细节,不妨和我一起来研究一下。

先来看一个每个人都用到的方法app.use(express.static(__dirname+'/public'));

你肯定在你的app文件中这么用过它:

  app.use(express.static(__dirname + '/public'));//设置静态文件目录

正如注释中写的那样,这句话的意思是,将静态文件目录设置为项目根目录+/public,当然你也可能是这么写的:

app.use(express.static(path.join(__dirname, 'public')));//和上面是一样的

运用path模块的join方法效果和前面是等价的,注意这里要引入path模块。

你有没有产生过疑问,为什么这句话能够帮我们设置静态文件目录呢?他到底做了些什么呢?

为了照顾初学者,我们不妨先从最基本的静态资源文件说起,什么是静态资源文件呢?

静态资源文件通俗的可以理解成对于不同的用户来说,内容都不会变化的文件。比如不管是张三李四还是王五访问百度,他们所接收到的看到的图片、css文件和前端javascript文件都是一样的,我们称这类文件为静态资源文件。

那么响应的,对于不同用户做出不同反应的就是动态文件了,张三李四王五登录百度,百度会分别对他们显示"你好张三"、"你好李四"、"你好王五",那么负责这么动态逻辑的文件就是动态文件了,根据你是用的技术不同,动态文件可能是.jsp文件、php文件或者我们node.js的服务器端js文件。

那么app.use()方法又干了什么事情呢,我们先来看看官方API怎么说的:

大意是说,app.use是用来给path注册中间函数的,这个path默认是'/',也就是处理任何请求,同时要注意的是他会处理path下的子路径,比如如果设置path为'/hello',那么当请求路径为'/hello/','/hello/nihao','/hello/bye'这样的请求都会交给中间函数处理的。

于是我们现在知道了app.use(express.static(__dirname + '/public'))是将所有请求,先交给express.static(__dirname + '/public')来处理一下,虽然我们暂时不知道express.static()的处理细节,但是这不影响我们做出一些推测,最起码我们可以知道,express.static()的返回值肯定是一个函数。

官方文档十分详尽,像我们解释了express.static()的一些细节,我简单的翻译给大家:

Serving static files in Express

为了提供对静态资源文件(图片、csss文件、javascript文件)的服务,请使用Express内置的中间函数 express.static 。

传递一个包含静态资源的目录给 express.static 中间件用于立刻开始提供文件。比如用以下代码来提供public目录下的图片、css文件和javascript文件:

app.use(express.static('public'));

现在,你可以加载 public目录下的文件了:

http://localhost:3000/images/kitten.jpg
http://localhost:3000/css/style.css
http://localhost:3000/js/app.js
http://localhost:3000/images/bg.png
http://localhost:3000/hello.html

Express 会在静态资源目录下查找文件,所以不需要把静态目录作为URL的一部分。

 通过多次使用 express.static 中间件来添加多个静态资源目录:

app.use(express.static('public'));
app.use(express.static('files'));

Express 将会按照你设置静态资源目录的顺序来查找静态资源文件。

为了给静态资源文件创建一个虚拟的文件前缀(实际上文件系统中并不存在) ,可以使用 express.static 函数指定一个虚拟的静态目录,就像下面这样:

app.use('/static', express.static('public'));

现在你可以使用 /static 作为前缀来加载 public 文件夹下的文件了。

http://localhost:3000/static/images/kitten.jpg
http://localhost:3000/static/css/style.css
http://localhost:3000/static/js/app.js
http://localhost:3000/static/images/bg.png
http://localhost:3000/static/hello.html

然而,你提供给 express.static 函数的路径是一个相对node进程启动位置的相对路径。如果你在其他的文件夹中启动express app,更稳妥的方式是使用静态资源文件夹的绝对路径: 

app.use('/static', express.static(__dirname + '/public'));

 

转载于:https://www.cnblogs.com/A-dam/p/5053299.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 是的,在 Express.js 中,你可以多次使用 app.use() 函数来使用静态资源中间件。 app.use(express.static()) 方法允许你指定一个路径来提供静态资源(例如 HTML 文件、图片、CSS 文件等)。这样,当客户端请求一个这个路径下的静态资源时,服务器就会返回对应的文件。 例如,你可以这样使用 app.use(express.static()) 方法: ``` app.use(express.static('public')); ``` 这样,你就可以把你的静态资源放在一个名为 "public" 的文件夹中,然后通过这个路径来访问这些资源。 你也可以使用多个 app.use(express.static()) 方法来提供多个静态资源路径,例如: ``` app.use(express.static('public')); app.use(express.static('files')); ``` 这样,你就可以通过两个不同的路径来访问静态资源了。 ### 回答2: 可以多次使用app.use(express.static())来指定不同的静态文件目录。 在Node.js中,使用express框架时,可以通过app.use(express.static())来指定静态文件的存放目录。该方法是express框架提供的中间件,用于访问静态资源。 在多次使用app.use(express.static(dir))时,每次传入不同的目录作为参数即可。例如,可以通过以下代码多次指定不同的静态文件目录: app.use(express.static('public')); app.use(express.static('images')); app.use(express.static('files')); 以上代码就将/public、/images和/files目录下的静态文件,如HTML、CSS、JavaScript等,对外提供访问。 这样可以实现一些特殊需求: 1. 当多个目录下的静态文件有重名时,可以通过多次使用express.static()来分别指定不同的目录,从而避免文件冲突。 2. 当项目的静态文件较多时,可以将它们分别存放在不同的目录下,并通过多次使用express.static()来指定各个目录,保持项目结构的清晰性。 需要注意的是,当多次使用app.use(express.static())时,静态资源的访问路径会按照顺序进行匹配,直到找到匹配的静态文件为止。因此,如果多个静态文件目录下存在相同的文件名时,会优先返回第一个匹配的文件。 总而言之,app.use(express.static())可以多次使用,并且可以指定不同的静态文件目录,以满足不同的项目需求。 ### 回答3: app.use(express.static())可以多次使用。express.static()是一个中间件函数,用于托管静态文件。通过调用app.use(express.static()),可以指定多个静态文件目录,来托管不同类型的静态文件。每次调用app.use(express.static()),都可以传入不同的静态文件目录作为参数,用于指定不同的文件路径。 例如,我们可以通过以下方式多次使用app.use(express.static())来指定多个静态文件目录: app.use(express.static('public')):指定public文件夹作为静态文件目录。 app.use(express.static('images')):指定images文件夹作为静态文件目录。 app.use(express.static('css')):指定css文件夹作为静态文件目录。 这样,当我们在浏览器中访问服务器上的静态文件时,express会自动查找指定的静态文件目录,并将文件发送给浏览器。多次使用app.use(express.static())可以为服务器提供多个静态文件目录,以便更好地组织和管理静态文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值