ABP進階教程3 - 優化編輯


點這里進入ABP進階教程目錄 

我們嘗試在新增/編輯界面增加一個下拉框用來代替輸入框編輯Status
  

添加實體

打開領域層(即JD.CRS.Core)的Entitys目錄 //用以存放實體對象
添加一個類StatusCode.cs //狀態信息

using System;
using System.Collections.Generic;
using System.Text;

namespace JD.CRS.Entitys
{
    public enum StatusCode : byte
    {
        Enabled = 0,
        Disabled = 1
    }
}

更新模型

更新查詢視圖模型

打開展示層(即JD.CRS.Web.Mvc)的Models/Course/CourseListViewModel.cs //Course查詢視圖模型

新增GetStatusList方法 //獲取狀態列表

 1 public StatusCode? Status { get; set; }
 2 
 3 public List<SelectListItem> GetStatusList(ILocalizationManager localizationManager)
 4 {
 5     var list = new List<SelectListItem>
 6     {
 7         new SelectListItem
 8         {
 9             Text = localizationManager.GetString(CRSConsts.LocalizationSourceName, "PleaseSelect"),
10             Value = "",
11             Selected = Status == null
12         }
13     };
14 
15     list.AddRange(Enum.GetValues(typeof(StatusCode))
16         .Cast<StatusCode>()
17         .Select(status =>
18             new SelectListItem
19             {
20                 Text = localizationManager.GetString(CRSConsts.LocalizationSourceName, $"StatusCode_{status}"),
21                 Value = status.ToString(),
22                 Selected = status == Status
23             })
24     );
25 
26     return list;
27 }
View Code

更新編輯視圖模型

打開展示層(即JD.CRS.Web.Mvc)的Models/Course/EditCourseModalViewModel.cs //Course編輯視圖模型

新增GetStatusList方法 //獲取狀態列表

 1 public List<SelectListItem> GetStatusList(ILocalizationManager localizationManager)
 2 {
 3     var list = new List<SelectListItem>
 4     {
 5     };
 6 
 7     list.AddRange(Enum.GetValues(typeof(StatusCode))
 8         .Cast<StatusCode>()
 9         .Select(status =>
10             new SelectListItem
11             {
12                 Text = localizationManager.GetString(CRSConsts.LocalizationSourceName, $"StatusCode_{status}"),
13                 Value = status.ToString(),
14                 Selected = status == Status
15             })
16     );
17 
18     return list;
19 }
View Code

更新控制器

打開展示層(即JD.CRS.Web.Mvc)的Controllers/CourseController.cs //Course控制器

更新EditCourseModal方法 //向EditCourseModalViewModel傳參數Status

public async Task<ActionResult> EditCourseModal(int courseId)
{
    var course = await _courseAppService.Get(new EntityDto<int>(courseId));
    var model = new EditCourseModalViewModel
    {
        Course = course,
        Status = course.Status
    };
    return View("_EditCourseModal", model);
}

更新創建視圖

打開展示層(即JD.CRS.Web.Mvc)的Views/Course/Index.cshtml //Course查詢視圖

添加下拉框Status //以替代輸入框Status

<div class="row clearfix">
    <div class="col-sm-12">
        <div class="form-line">
            <label class="form-label">@L("Status")</label>
            @Html.DropDownListFor(
            model => model.Status,
            Model.GetStatusList(LocalizationManager),
            new
            {
                @class = "form-control",
                id = "Status"
            })
            @*<input name="Status" type="text" class="form-control" />*@
        </div>
    </div>
</div>

更新編輯視圖

打開展示層(即JD.CRS.Web.Mvc)的Views/Course/_EditCourseModal.cshtml //Course編輯視圖

添加下拉框Status //以替代輸入框Status

<div class="row clearfix">
    <div class="col-sm-12">
        <div class="form-line">
            <label class="form-label">@L("Status")</label>
            @Html.DropDownListFor(
            model => model.Status,
            Model.GetStatusList(LocalizationManager),
            new
            {
                @class = "form-control",
                id = "Status"
            })
            @*<input name="Status" type="text" value="@Model.Course.Status" class="form-control" />*@
        </div>
    </div>
</div>

更新腳本

打開展示層(即JD.CRS.Web.Mvc)的\wwwroot\view-resources\Views\Course\_EditCourseModal.js //用以存放Course編輯相關腳本

在初始化Form時給下拉框傳值

//Initial form
_$modal.on('shown.bs.modal', function () {
    _$form.find('input[type=text]:first').focus();//focus first input
    _$status.val() = status;//Status value
});

預覽效果

創建課程

 

編輯課程

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM