Показать конкретные данные из базы данных после нажатия на этот элемент - PullRequest
0 голосов
/ 11 марта 2019

Как я могу перечислить всех пользователей, которые были назначены на роль.Вот моя модель.

namespace Comtrex_ICU.Models
{
  public class UsersContext : DbContext
  {
    public UsersContext()
      : base("DefaultConnection")
    {
    }

    public DbSet<UserProfile> UserProfiles { get; set; }
    public DbSet<Membership> Membership { get; set; }
    public DbSet<Role> Roles { get; set; }
  }

  [Table("UserProfile")]
  public class UserProfile
  {
    [Key]
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
    public int UserId { get; set; }
    public string UserName { get; set; }
    public string Email { get; set; }
  }

  [Table("webpages_Roles")]
  public class Role
  {
    [Key]
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
    public int RoleId { get; set; }
    public string RoleName { get; set; }
  }

Вот мой контроллер на данный момент: когда я нажимаю на роль, он возвращает представление с правильным названием роли в этом представлении:

//List all users for a role
[HttpGet]

public ActionResult List(string UserName, string RoleName)
{
    using (UsersContext db = new UsersContext())
    {
        var roleSelect = db.Roles.Where(r => r.RoleName.Equals(RoleName)).FirstOrDefault();

        return View(roleSelect);
    }
}

Это представление, которое отображает список всех ролей, сохраненных со ссылкой для редактирования, удаления и перечисления этой конкретной роли.

@{
    ViewBag.Title = "RoleIndex";
    Layout = "~/Views/Shared/_Layout.cshtml";
}

    <div class="spacerBody">
        <h2 class="admin-home-link">@Html.ActionLink("Roles", "AdminIndex")</h2>
        @Html.ActionLink("Create New Role", "RoleCreate") | 
        @Html.ActionLink("Manage User Roles", "RoleAddToUser") 
        <p>&nbsp;</p>
        <div>


            @foreach (string s in Model)
            {

                <div id="userRolesList">
                    <p class="role-p">
                        @s
                    |<span onclick="return confirm('Are you sure to 
                    delete?')">
                       <a href="/Account/RoleDelete?RoleName=@s" 
                     class="delLink"> <span style="color: 
                    #f05322">Delete</span> 
                     </a>
                     </span>
                    |<a href="/Account/Edit?RoleName=@s">Edit</a>   
                    |<a href="/Account/List?RoleName=@s">List</a>

                    </p>
                </div>
                <div>

                </div>

            }
        </div>
    </div>


Then when I click the List link it takes me to this view: 

    @model Comtrex_ICU.Models.Role
    @{
        ViewBag.Title = "List";
        Layout = "~/Views/Shared/_Layout.cshtml";
    }

    <h2 class="admin-home-link">@Html.ActionLink("List", "AdminIndex")</h2>

    <hr/>

    @using (Html.BeginForm())
    {
        @Html.AntiForgeryToken()
        @Html.ValidationSummary(true)
        @Html.HiddenFor(m => m.RoleId)





        <p>
            @Model.RoleName
        </p>
    }


How will i be able to list the specific users that corresponds to the right role?

1 Ответ

1 голос
/ 11 марта 2019

Используя метод @Html.TexboBoxFor, вы запрашиваете бритвенный движок для рендеринга текстового поля для этого поля и значения привязки.Если вам нужно просто отобразить текст для поля, просто используйте значение свойства модели в теге p:

<p>
    @Model.RoleName
</p>

Обновление: Для просмотра списка ролей вы можете использовать @foreach,Для получения дополнительной информации о синтаксисе бритвы Вы можете ознакомиться с документацией Microsoft .Есть примеры для основных операций и синтаксиса бритвы.

...