首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在app.locals上设置属性和调用app.set()有什么区别?

在app.locals上设置属性和调用app.set()有什么区别?
EN

Stack Overflow用户
提问于 2012-08-09 22:22:38
回答 2查看 5.9K关注 0票数 22

我正在学习Express --并且正在考虑保存配置样式数据的最佳位置。可用选项有app.locals或app.set (设置)...所以:

代码语言:javascript
复制
app.locals({ config: {
    name: 'My App',
    domain: 'myapp.com',
    viewPath: __dirname+'/views',
    viewEngine: 'jade'
    port: 3000
} });

app.set('view engine', app.locals.config.viewEngine || 'jade');

这也允许我在我的视图中使用以下内容:

代码语言:javascript
复制
<title>#{config.name}</title> // <title>My App</title>

或者,也可以像这样使用app.set:

代码语言:javascript
复制
app.set('name', 'My App');
app.set('domain', 'myapp.com');

..。然后在视图中使用以下代码:

代码语言:javascript
复制
<title>#{settings.name}</title>

我知道这两种方法都有效,但我正在努力确定哪种方法更好。目前,我倾向于使用app.locals,带有额外的'app‘命名空间,因为我相信如果使用app.set,与未来的更新和其他模块发生冲突的可能性会更小。

EN

回答 2

Stack Overflow用户

发布于 2014-08-27 23:50:12

app.locals的所有属性都可以在模板中找到。使用app.set将属性分配给app.locals.settings,该属性用于全局应用程序设置,并由已装载的应用程序继承。例如:

代码语言:javascript
复制
var app1 = express(),
    app2 = express();

app1.set('inheritable', 'foo');
app1.locals.notInheritable = 'bar';

app1.use('/mount', app2);

app2.get('inheritable') === 'foo'; // true
app2.locals.notInheritable === 'bar'; // false

因此,这实际上是一个偏好的问题,以及您是否要安装应用程序。

票数 4
EN

Stack Overflow用户

发布于 2012-08-09 23:04:51

很多人确实使用本地变量而不是app.set,所以我的建议是使用它。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11885562

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档