С C ++ 11 приведенное выше возможно для базовых типов как
class Foo {
public:
static constexpr int MEMBER = 1;
};
Часть constexpr
создает статическое выражение в противоположность статическому variable - и это ведет себя так же, как чрезвычайно простое определение встроенного метода. Тем не менее подход оказался немного шатким с C-string constexprs внутри классов шаблонов.
Когда требуется указать путь к папке, он будет искать файл index.js в этой папке; если он есть, он использует это, а если нет, то он терпит неудачу.
Вероятно, имеет смысл (если у вас есть контроль над папкой) для создания файла index.js, а затем назначить все «модули», а затем просто потребовать этого.
yourfile.js
var routes = require("./routes");
index.js
exports.something = require("./routes/something.js");
exports.others = require("./routes/others.js");
Если вы не знаете имена файлов, вы должны написать какой-то загрузчик.
Рабочий пример загрузчика:
var normalizedPath = require("path").join(__dirname, "routes");
require("fs").readdirSync(normalizedPath).forEach(function(file) {
require("./routes/" + file);
});
// Continue application logic here
Еще один вариант - require-dir-all , объединяющий функции из самых популярных пакетов.
У большинства популярных require-dir
нет опций для фильтрации файлов / dirs и делает не имеет функции map
(см. ниже), но использует небольшой трюк, чтобы найти текущий путь модуля.
Вторая по популярности require-all
имеет фильтрацию и предварительную обработку регулярного выражения, но не имеет относительного пути, поэтому вам нужно использовать __dirname
(у этого есть плюсы и контрасты), например:
var libs = require('require-all')(__dirname + '/lib');
Упомянутый здесь require-index
весьма минималистичен.
С помощью map
вы можете выполнить некоторую предварительную обработку, например создать объекты и значения конфигурации передачи (предполагая модули ниже конструкторов экспорта):
// Store config for each module in config object properties
// with property names corresponding to module names
var config = {
module1: { value: 'config1' },
module2: { value: 'config2' }
};
// Require all files in modules subdirectory
var modules = require('require-dir-all')(
'modules', // Directory to require
{ // Options
// function to be post-processed over exported object for each require'd module
map: function(reqModule) {
// create new object with corresponding config passed to constructor
reqModule.exports = new reqModule.exports( config[reqModule.name] );
}
}
);
// Now `modules` object holds not exported constructors,
// but objects constructed using values provided in `config`.
У меня есть папка / поля, заполненные файлами с одним классом, ex:
fields/Text.js -> Test class
fields/Checkbox.js -> Checkbox class
Отбросьте это в полях / index.js для экспорта каждого класса:
var collectExports, fs, path,
__hasProp = {}.hasOwnProperty;
fs = require('fs');
path = require('path');
collectExports = function(file) {
var func, include, _results;
if (path.extname(file) === '.js' && file !== 'index.js') {
include = require('./' + file);
_results = [];
for (func in include) {
if (!__hasProp.call(include, func)) continue;
_results.push(exports[func] = include[func]);
}
return _results;
}
};
fs.readdirSync('./fields/').forEach(collectExports);
Это делает модули более похожими на Python:
var text = new Fields.Text()
var checkbox = new Fields.Checkbox()
Я рекомендую использовать glob для выполнения этой задачи.
var glob = require( 'glob' )
, path = require( 'path' );
glob.sync( './routes/**/*.js' ).forEach( function( file ) {
require( path.resolve( file ) );
});
glob
? вы имеете в виду glob-savior-of-the-nodejs-race
. Лучший ответ.
– deepelement
21 April 2017 в 16:30
var x = require('x')
Что такое var x
в этом случае?
– Matt Westlake
18 October 2017 в 20:55
Основы решения @ tbranyen, я создаю файл index.js
, который загружает произвольные javascripts в текущей папке как часть exports
.
// Load `*.js` under current directory as properties
// i.e., `User.js` will become `exports['User']` or `exports.User`
require('fs').readdirSync(__dirname + '/').forEach(function(file) {
if (file.match(/\.js$/) !== null && file !== 'index.js') {
var name = file.replace('.js', '');
exports[name] = require('./' + file);
}
});
Тогда вы можете require
установить этот каталог из любого места.
/\.js(on)?$/
будет лучше. Также не является !== null
избыточным?
– user
4 August 2015 в 20:57
Может использовать: https://www.npmjs.com/package/require-file-directory
Я знаю, что этот вопрос составляет 5+ лет, и данные ответы хороши, но я хотел что-то более мощное для выражения, поэтому я создал пакет express-map2
для npm. Я собирался называть его просто express-map
, однако люди в yahoo уже имеют пакет с этим именем, поэтому мне пришлось переименовать мой пакет.
1. основное использование:
app.js (or whatever you call it)
var app = require('express'); // 1. include express
app.set('controllers',__dirname+'/controllers/');// 2. set path to your controllers.
require('express-map2')(app); // 3. patch map() into express
app.map({
'GET /':'test',
'GET /foo':'middleware.foo,test',
'GET /bar':'middleware.bar,test'// seperate your handlers with a comma.
});
использование контроллера:
//single function
module.exports = function(req,res){
};
//export an object with multiple functions.
module.exports = {
foo: function(req,res){
},
bar: function(req,res){
}
};
2. расширенное использование с префиксами:
app.map('/api/v1/books',{
'GET /': 'books.list', // GET /api/v1/books
'GET /:id': 'books.loadOne', // GET /api/v1/books/5
'DELETE /:id': 'books.delete', // DELETE /api/v1/books/5
'PUT /:id': 'books.update', // PUT /api/v1/books/5
'POST /': 'books.create' // POST /api/v1/books
});
Как вы можете видеть, это экономит массу времени и делает простую маршрутизацию вашего приложения простой, чтобы писать, поддерживать и понимать. он поддерживает все http-глаголы, которые выражают поддержку, а также специальный метод .all()
.
Я использую модули узла copy-to module для создания одного файла, требующего всех файлов в нашей системе на основе NodeJS.
Код для наш файл утилиты выглядит так:
/**
* Module dependencies.
*/
var copy = require('copy-to');
copy(require('./module1'))
.and(require('./module2'))
.and(require('./module3'))
.to(module.exports);
Во всех файлах большинство функций записываются как экспорт:
exports.function1 = function () { // function contents };
exports.function2 = function () { // function contents };
exports.function3 = function () { // function contents };
Итак, тогда чтобы использовать любую функцию из файла, вы просто вызываете:
var utility = require('./utility');
var response = utility.function2(); // or whatever the name of the function is
Другой вариант - использовать пакет require-dir , который позволит вам сделать следующее. Он также поддерживает рекурсию.
var requireDir = require('require-dir');
var dir = requireDir('./path/to/dir');
require-dir
, поскольку он автоматически исключает вызывающий файл (индекс) и по умолчанию используется текущий каталог. Отлично.
– biofractal
5 March 2015 в 10:15
Один модуль, который я использовал для этого точного варианта использования, - require-all .
Он рекурсивно требует, чтобы все файлы в данном каталоге и его подкаталогах так долго, как они не соответствуют свойству excludeDirs
.
Он также позволяет указать фильтр файлов и как выводить ключи возвращаемого хеша из имен файлов.
Если вы включили все файлы * .js в пример каталога («app / lib / *. js»):
example.js:
module.exports = function (example) { }
example-2.js:
module.exports = function (example2) { }
index.js:
module.exports = require('./app/lib');
require
задан путь к папке, он будет искатьindex.js
в этой папке; если он есть, он использует это, а если нет, он терпит неудачу. См. github.com/christkv/node-mongodb-native для примера в реальном мире: в корневом каталоге естьindex.js
, для которого требуется./lib/mongodb
, каталог;./lib/mongodb/index.js'
делает все остальное в этом каталоге доступным. – Trevor Burnham 26 April 2011 в 06:18require
является синхронной функцией, поэтому нет никакой выгоды от обратного вызова. Вместо этого я бы использовал fs.readdirSync. – Rafał Sobota 11 January 2012 в 00:35require('./routes/*')
? – Robert Martin 24 July 2012 в 20:59