ASP.NET Core 如何在不同的地方使用视图组件的视图?
How to use views of View Component in different places in ASP.NET Core?
我在我的项目中使用视图组件。有时,我需要使用相同的视图组件作为各种样式。我研究了很多,但没有找到解决方案。
下面的代码工作正常,但当我这样做时,我无法按我想要的方式使用它。
查看组件class:
public IViewComponentResult Invoke(BlogSidebarViewModel vm)
{
vm.BlogTags = _uow.BlogTag.GetAllByPriority(true,vm.LangId,vm.WebsiteId);
vm.BlogCategories = _uow.BlogCategory.GetAllByPriority(true,vm.LangId,vm.WebsiteId).Include(p=>p.BlogTag);
vm.RecentBlogs = _uow.Blog.GetAllByEnabledDate(true,vm.LangId,vm.WebsiteId);
//return View(vm); //For Default Blog Sidebar View Component
//return View("RedComponent", vm); //For Red Blog Sidebar View Component
//return View("GreenComponent",vm);//For Green Blog Sidebar View Component
}
但是,当我写下面的代码时,我得到一个错误。
@await Component.InvokeAsync("BlogSidebar/RedComponent");
或
@await Component.InvokeAsync("~/Views/Shared/Components/BlogSidebar/GreenComponent.cshtml");
我想在各种视图中使用视图组件。我能怎么做?我可以吗?
编辑
我可以同时使用视图组件的视图吗?例如,当我在“Blogs/ABC.cshtml”视图中使用“GreenComponent”时,我想在“Blogs/XYZ.cshtml”视图中使用“RedComponent”视图。
请按照以下步骤使用视图组件:
1.Create GreenComponent.cshtml
在文件夹中:Views/Shared/Components/BlogSidebar
.
2.Create 查看名为 BlogSidebar
的组件:
public class BlogSidebar : ViewComponent
{
public IViewComponentResult Invoke(BlogSidebarViewModel vm)
{
vm.Id = 1;
vm.Name = "aaa";
return View("GreenComponent",vm);
}
}
3.GreenComponent.cshtml:
@model BlogSidebarViewModel
Name: @Model.Name
4.Index.cshtml:
@model BlogSidebarViewModel
@await Component.InvokeAsync("BlogSidebar",new BlogSidebarViewModel())
结果:
我在我的项目中使用视图组件。有时,我需要使用相同的视图组件作为各种样式。我研究了很多,但没有找到解决方案。
下面的代码工作正常,但当我这样做时,我无法按我想要的方式使用它。
查看组件class:
public IViewComponentResult Invoke(BlogSidebarViewModel vm)
{
vm.BlogTags = _uow.BlogTag.GetAllByPriority(true,vm.LangId,vm.WebsiteId);
vm.BlogCategories = _uow.BlogCategory.GetAllByPriority(true,vm.LangId,vm.WebsiteId).Include(p=>p.BlogTag);
vm.RecentBlogs = _uow.Blog.GetAllByEnabledDate(true,vm.LangId,vm.WebsiteId);
//return View(vm); //For Default Blog Sidebar View Component
//return View("RedComponent", vm); //For Red Blog Sidebar View Component
//return View("GreenComponent",vm);//For Green Blog Sidebar View Component
}
但是,当我写下面的代码时,我得到一个错误。
@await Component.InvokeAsync("BlogSidebar/RedComponent");
或
@await Component.InvokeAsync("~/Views/Shared/Components/BlogSidebar/GreenComponent.cshtml");
我想在各种视图中使用视图组件。我能怎么做?我可以吗?
编辑
我可以同时使用视图组件的视图吗?例如,当我在“Blogs/ABC.cshtml”视图中使用“GreenComponent”时,我想在“Blogs/XYZ.cshtml”视图中使用“RedComponent”视图。
请按照以下步骤使用视图组件:
1.Create GreenComponent.cshtml
在文件夹中:Views/Shared/Components/BlogSidebar
.
2.Create 查看名为 BlogSidebar
的组件:
public class BlogSidebar : ViewComponent
{
public IViewComponentResult Invoke(BlogSidebarViewModel vm)
{
vm.Id = 1;
vm.Name = "aaa";
return View("GreenComponent",vm);
}
}
3.GreenComponent.cshtml:
@model BlogSidebarViewModel
Name: @Model.Name
4.Index.cshtml:
@model BlogSidebarViewModel
@await Component.InvokeAsync("BlogSidebar",new BlogSidebarViewModel())
结果: