How can I route multiple urls to the same controller or view to work with angular single page app?!
I can do this but i think is ugly..
'/': {
view: 'homepage'
},
'/login': {
view: 'homepage'
},
'/register': {
view: 'homepage'
},
'/troller': {
view: 'homepage'
},
............
I want somethink like
['/','/login','/register','/troller'] -> view: 'homepage'
And other question, Can I use regular expressions for routing?
Thx!! and sorry for my english.
You can't currently use real regular expressions for routing. You can however use a wildcard route to do what you want (aim multiple routes at one view).
Put this at the end of your /config/routes.js
object:
'/*': function(req, res, next) {
if (req.path.match(/\..*/g)) {
return next();
} else {
return res.view('homepage');
}
}
and everything that isn't matched by one of the routes above it will execute that function. The function first checks if you're trying to access a static asset (something with a file extension, like .js
or .css
), and if so, continues matching the route so that the Express static middleware can server the file. Otherwise, it will server your view.
Update
As of Sails v0.10.0-rc5, regular expressions can be used to define routes. From the docs:
The syntax for a regular expression route is:
"r|<regular expression string>|<comma-delimited list of param names>"
That's the letter "r", followed by a pipe, a regular expression string without delimiters, another pipe, and a list of parameter names that should be mapped to parenthesized groups in the regular expression. For example:
"r|^/\d+/(\w+)/(\w+)$|foo,bar": "MessageController.myaction"
will match /123/abc/def, running the myaction
action of MessageController
and supplying the values abc
and def
as req.param('foo')
and req.param('bar')
, respectively.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With