Оказывается, мне нужно было обновить Angular до версии 6.x.x при использовании rxjs 6.x.x. То есть мне также пришлось использовать новейшую версию angulartics2. Теперь это мой package.json
{
"name": "flow-app",
"version": "1.1.0",
"license": "MIT",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e",
"build:preprod": "ng build --prod --source-map --configuration=preprod --base-href /dist/",
"build:prod": "ng build --prod --build-optimizer --configuration=production --base-href /dist/"
},
"private": true,
"dependencies": {
"@angular/animations": "^6.1.0",
"@angular/cdk": "^6.0.0",
"@angular/common": "^6.1.0",
"@angular/compiler": "^6.1.0",
"@angular/core": "^6.1.0",
"@angular/forms": "^6.1.0",
"@angular/http": "^6.0.0",
"@angular/material": "^6.2.5",
"@angular/platform-browser": "^6.0.0",
"@angular/platform-browser-dynamic": "^6.0.0",
"@angular/router": "^6.0.0",
"@ng-bootstrap/ng-bootstrap": "^1.0.0-beta.7",
"ajv": "^6.10.0",
"angulartics2": "^7.0.1",
"classlist.js": "^1.1.20150312",
"core-js": "^2.4.1",
"ng2-opd-popup": "^1.1.21",
"rxjs": "^6.4.0",
"rxjs-compat": "^6.4.0",
"web-animations-js": "^2.3.1",
"zone.js": "^0.8.14"
},
"devDependencies": {
"@angular-devkit/build-angular": "^0.13.4",
"@angular/cli": "^6.2.3",
"@angular/compiler-cli": "^5.0.0",
"@angular/language-service": "^5.0.0",
"@types/jasmine": "~2.5.53",
"@types/jasminewd2": "~2.0.2",
"@types/node": "~6.0.60",
"codelyzer": "~3.2.0",
"jasmine-core": "~2.6.2",
"jasmine-spec-reporter": "~4.1.0",
"karma": "~1.7.0",
"karma-chrome-launcher": "~2.1.1",
"karma-cli": "~1.0.1",
"karma-coverage-istanbul-reporter": "^1.2.1",
"karma-jasmine": "~1.1.0",
"karma-jasmine-html-reporter": "^0.2.2",
"protractor": "^5.4.2",
"ts-node": "~3.2.0",
"tslint": "~5.7.0",
"typescript": "^2.9.2"
}
}
I think, what you are looking for does not exist. The closest you can have is params:
MyMethod(params object[] args)
{
// if you have to do this, it's quite bad:
int intArg = (int)args[0];
string stringArg = (string)arg[1]:
}
// call with any number (and type) of argument
MyMethod(7, "tr");
There is no compile time type checking, and therefore it is not an all-purpose way to handle arguments. But if your arguments are dynamic, it's probably a solution.
Edit: had another idea:
You need to put all argument manually into a list / dictionary. You can write a helper class to allow the following:
MyMethod(int arg1, string arg2)
{
Arguments.Add(() => arg1);
Arguments.Add(() => arg2);
//
}
The helper looks like this
public static void Add<T>(Expression<Func<T>> expr)
{
// run the expression to get the argument value
object value = expr.Compile()();
// get the argument name from the expression
string argumentName = ((MemberExpression)expr.Body).Member.Name;
// add it to some list:
argumentsDic.Add(argumentName, value);
}
Ваш лучший вариант - сделать это с анонимным типом, как показано в этот пример .
Хороший вопрос (+1). Я думаю, что это то, что вам нужно -
MethodBase mb = MethodBase.GetCurrentMethod();
ParameterInfo[] pi = mb.GetParameters();
Один из способов, который я знаю (не уверен, что в настоящее время это только , но раньше), - это использование аспектно-ориентированного программирования (AOP), и в частности перехват. Немного больно катать его вручную, но на помощь приходят отличные инструменты. Одним из таких инструментов является PostSharp: http://www.postsharp.org/ .
Так как метод использует именованные параметры, почему вы не можете просто явно заполнить словарь их именами и значениями? Нет смысла использовать рефлексию для получения их имен, поскольку вы уже знаете их.
Как уже говорилось, ключевое слово params можно использовать для определения метода с переменным числом параметров, но по определению они безымянные.
Я не уверен, что то, что вы спрашиваете, в том смысле, как вы это объяснили, имеет какой-то смысл. Возможно, вы могли бы уточнить дальше?