Access a global variable from any app controller

2019-01-16 19:27发布

I need to use a global variable (user context, available from all the code) I have read some posts regarding this topic but I do not have a clear answer.

App = Ember.Application.create({
  LOG_TRANSITIONS: true,
  currentUser: null
});
  1. Is it a good practice to set the currentUser global variable in the App object ?
  2. How to update and access the currentUser property from all the controllers used in the app ?

标签: ember.js
1条回答
Explosion°爆炸
2楼-- · 2019-01-16 20:11

Is it a good practice to set the currentUser global variable in the App object ?

No, this is not a good practice. You should avoid using global variables. The framework does a lot to make this possible - if you find yourself thinking a global variable is the best solution it's a sign that something should be refactored. In most cases the right place is in a controller. For example, currentUser could be:

//a property of application controller
App.ApplicationController = Ember.Controller.extend({
  currentUser: null
});

//or it's own controller
App.CurrentUserController = Ember.ObjectController.extend({});

How to update and access the currentUser property from all the controllers used in the app ?

Use the needs property. Let's say you've declared currentUser as a property of ApplicationController. It can be accessed from PostsController like this:

App.PostsController = Ember.ArrayController.extend{(
  needs: ['application'],
  currentUser: Ember.computed.alias('controllers.application.currentUser'),
  addPost: function() {
    console.log('Adding a post for ', this.get('currentUser.name'));
  }
)}

If you need to access currentUser from a view/template, just use needs to make it accessible via the local controller. And if you need it from a route, use the route's controllerFor method.

查看更多
登录 后发表回答