When using a regex in iron router, how to access the match?

后端 未结 3 1252
心在旅途
心在旅途 2020-12-20 09:57

Rather than having five different routes, I am trying to combined five different paths into a single function, but I still need to know which path it matched. So if I set up

相关标签:
3条回答
  • 2020-12-20 10:15

    I think the best way to do this would be to use a loop to define several routes.

    _.each(["accounts", "contacts", "forecasts"], function (path) {
      Router.route(path, function () {
        // inside here you can reference path
      });
    });
    

    Using one route with many unrelated paths seems like a hack to me.

    0 讨论(0)
  • 2020-12-20 10:22

    I was able to use this.params after all by rewriting the regex as follows:

    Router.route(/^\/(accounts|contacts|forecasts|analytics|activities)/, function() {
        console.log('matched: '+this.params[0]);
    }
    

    Not sure if this is the best way to refer to a regex match tho.

    0 讨论(0)
  • 2020-12-20 10:24

    This is a typical scenario for Iron.Router custom route controller! Check the guide here If you need some code, let me know. ;)

    [Edit]

    1. First, you define a route controller for all your sites, which inherit from the RouteController.

      BaseController = RouteController.extend({
          // Put repeating logic for your sites here
      });
      
    2. After that, you define your routes seperatly, not via regex. This is much more modular and maintainable. The big point here is, you don't have to find out by complicated functions, which site is current.

      Router.map(function(){
          this.route('accounts', {
              path: '/accounts'
          });
      });
      
    3. Now, give your routes his own controller

      Router.map(function(){
          this.route('accounts', {
              path: '/accounts',
              controller: 'AccountsController'
          });
      });
      
    4. In this Example, your AccountsController needs to inherit from your new BaseController. Put all your route logic, which is specific for only this route, in your AccountsController

      AccountsController = BaseController.extend({
          // Put your specific route logic here
      });
      
    5. Make sure, your BaseController is loading by meteor before your routes. Check out Meteor File Load Order.You can do something like the following

      client/routes
      client/routes/routes.js
      client/routes/controller/AccountsController.js
      client/routes/controller/BaseController.js
      
    0 讨论(0)
提交回复
热议问题