У меня есть ToggleActive в C #, и обычно я могу назвать его как ToggleActive, где Person - это объект ссылки 2 sql в пространстве имен MyProject.Data.
Как я могу сделать что-то вроде этого: ToggleActive <"MyProject.Data.Person">? Возможно ли что-то подобное? Я как-то использую typeof?
Спасибо!
ОБНОВЛЕНИЕ - позвольте мне перефразировать все это. У меня есть сайт администратора, где пользователи могут нажать «удалить» для нескольких записей из разных таблиц linq в sql.
Html ...
<table class="persons">
<tr><td>Eric Davis</td><td><a href="/person/delete/14">delete</a></td></tr>
<tr><td>Tamara Davis</td><td><a href="/person/delete/15">delete</a></td></tr>
</table>
<table class="orders">
<tr><td>PB & J Sandwich</td><td><a href="/order/delete/6442">delete</a></td></tr>
<tr><td>Brat Sandwich</td><td><a href="/order/delete/6443">delete</a></td></tr>
</table>
Маршрут в PersonController ...
public ActionResult Delete(int id)
{
var repository = new MyLinq2SqlRepository();
repository.DeleteRecord<MyProject.Data.Person>; // MyProject.Data.Person is a linq to sql type
return redirect("~/"); // return home view
}
Маршрут в OrderController ...
public ActionResult Delete(int id)
{
var repository = new MyLinq2SqlRepository();
repository.DeleteRecord<Order>; // this is the only thing different from above action
return redirect("~/"); // return home view
}
Что я хочу в новом, ObjectController ...
public ActionResult Delete(int id, string type) {
var repository = new MyLinq2SqlRepository();
Type linq2SqlType = Type.GetType(type); // where type = "MyProject.Data.Person" or "MyProject.Data.Order"
repository.DeleteRecord<linq2SqlType>(id);
return redirect("~/");
}
Таким образом, я могу иметь для столов ...
<table class="persons">
<tr><td>Eric Davis</td><td><a href="/object/delete/14/MyProject.Data.Person">delete</a></td></tr>
<tr><td>Tamara Davis</td><td><a href="/object/delete/15/MyProject.Data.Person">delete</a></td></tr>
</table>
И таблица Order будет выглядеть очень похоже, но ссылки будут выглядеть так:
<a href="/object/delete/6442/MyProject.Data.Order">delete</a>
Надеюсь, это более понятно, что я пытаюсь сделать! Способ объединить эти действия маршрута в одно.
ОБНОВЛЕНИЕ: так я в итоге и сделал это ...
Html ...
<table typeName="@typeof(MyProject.Data.Person)">
@foreach (var p in this.Model.Persons) {
<tr id="@p.PersonId"><td>@p.FirstName</td><td><a href="#" class="deleteObjLink">delete</a></td></tr>
}
</table>
JS / Ajax ...
$(".deleteObjLink").on('click', function(e) {
e.preventDefault();
var link = $(this);
var id = link.closest("tr").attr("id");
var typeName = link.closest("table").attr("typeName");
$.ajax({
url: '/object/delete', type: 'post',
data: JSON.stringify({ id: id, typeName = typeName }),
contentType: 'application/json',
successFunc
});
});
В контроллере объектов MVC ...
[HttpPost]
public JsonResult Delete(int id, string typeName)
{
Assembly asm = typeof(MyProject.Data.Order).Assembly; // get assembly of any object w/in MyProject.Data.Order namespace (NS). all obj's in that NS share the same assembly
Type targetEntityType = asm.GetType(typeName);
MethodInfo genericMethodDefinition = typeof(MyRepository).GetMethod("Delete");
MethodInfo genericMethod = genericMethodDefinition.MakeGenericMethod(targetEntityType);
bool success = (bool)genericMethod.Invoke(myRepo, new object[] { id });
return this.Json(new { Success = success }, JsonRequestBehavior.DenyGet);
}
В классе MyRepository есть метод Delete (int id).