Make your local imports and requires relatively absolute!
WARNING This package modifies the global
require()
function. Do not use this if you do not completely control your execution environment (ie. don't use this when writing a library for 3rd parties etc.).
This package allows you to resolve your local project modules by using a pre-configured prefix when you require()
them, instead of having to use relative paths to that module from wherever you are.
Instead of
const User = require('./api/models/user')
You can now write
const User = require('api:models/user')
Now, the path to the User
model will be always the same, no matter where you require it (as long as the User
model does not change its location, that is!).
Require this module at the soonest opportunity in your application's lifecycle, most likely in an app.js, server.js or index.js files and call it with an object which contains keys as the prefixes you would like to register and the keys' values being the absolute paths where those require calls should be directed to. The paths can also be arrays - in that case, they will be path.join()
ed for you.
require('import-paths')({
api: [__dirname, 'api'],
'api:controller': [__dirname, 'api' 'controllers'],
'api:model': [__dirname, 'api' 'models'],
})
Now, if you require('api:model:user')
, the actual model's path with be resolved to something like /users/me/project-root/api/models/user
.
You can register as many prefixes as you like. Generally I would suggest using some kind of common pattern, so that it's obvious to everyone what is actually being required.
Other require
statements which do not contain a colon (:
) will be unmodified and will work as usual. You can even keep using relative paths if you are so inclined, but then... what's the point of using this library? 😀
This software is licensed under the BSD-3-Clause License. See the LICENSE file for more information.