zoukankan      html  css  js  c++  java
  • 自动构建表单

    方式一:通过类构建

    1. 第一步定义类
       /// <summary>
          /// 链接
          /// </summary>
          public class Link : WidgetBase {
              /// <summary>
              /// 链接名称
              /// </summary>
              [Display(Name = "链接名称")]
              [Field(ListShow = true, EditShow = true, ControlsType = ControlsType.TextBox)]
              [Required(ErrorMessage = "链接名称不能为空")]
              [StringLength(20, ErrorMessage = "链接名称不能操作20个字符")]
              public string Name { get; set; }
              /// <summary>
              /// 链接URL
              /// </summary>
              [Display(Name = "URL")]
              [Field(ListShow = true, EditShow = true, ControlsType = ControlsType.TextBox)]
              [Required(ErrorMessage = "链接不能为空")]
              public string Url { get; set; }
              /// <summary>
              /// 图标
              /// </summary>
              [Display(Name = "图标")]
              [Field(ListShow = false, EditShow = true, ControlsType = ControlsType.TextBox)]
              public string Icon { get; set; }
              /// <summary>
              /// 打开方式
              /// </summary>
              /// 
              [Display(Name = "打开方式")]
              [Field(ListShow = true, EditShow = true, ControlsType = ControlsType.DropdownList, DataSource = "ZKCloud.Core.Theme.Domain.Enums.Target")]
              public Target Target { get; set; }
              /// <summary>
              /// 链接字体颜色
              /// </summary>
              [Display(Name = "颜色")]
              [Field(ListShow = false, EditShow = true, ControlsType = ControlsType.Color)]
              public string Color { get; set; } = "#666666";
              /// <summary>
              /// 链接标题
              /// </summary>
              [Display(Name = "链接标题")]
              [Field(ListShow = false, EditShow = true, ControlsType = ControlsType.TextBox)]
              public string Title { get; set; }
      
           
          }
      }
      View Code
    2. 在cshtml文件中设置 ViewData["propertys"]
        Type t = Type.GetType(ViewData["Type"].ToString());
          ClassPropertyAttribute typeclassProperty = t.GetTypeInfo().GetCustomAttribute<ClassPropertyAttribute>();
      
          ClassDescription configDescription = new ClassDescription(t);
          var propertys = configDescription.Propertys.Where(r => r.PropertyAttribute.EditShow == true);

    3. 引用ClassControl
      ViewData["propertys"] = propertys;
      @await Html.AdminWidget("Core", "Common/ClassControl", ViewData)

    方式二:通过数据库DataField构建

  • 相关阅读:
    JS-记住用户名【cookie封装引申】
    JS-cookie封装
    JS-比较函数中嵌套函数,可以排序【对象数组】
    JS-随机div颜色
    JS-过滤敏感词【RegExp】
    JS-提取字符串—>>普通方法VS正则表达式
    CSS- ie6,ie7,ie8 兼容性写法,CSS hack写法
    JS-【同页面多次调用】轮播特效封装-json传多个参数
    JS-【同页面多次调用】tab选项卡封装
    Redis主从同步
  • 原文地址:https://www.cnblogs.com/zkcloud/p/5662299.html
Copyright © 2011-2022 走看看