完善代码生成功能

This commit is contained in:
izory 2021-09-10 22:15:01 +08:00
parent f550310b1e
commit 47bc6d5ed9
8 changed files with 61 additions and 92 deletions

View File

@ -12,8 +12,8 @@ using Infrastructure.Enums;
using Infrastructure.Model; using Infrastructure.Model;
using Mapster; using Mapster;
using ZR.Admin.WebApi.Extensions; using ZR.Admin.WebApi.Extensions;
using ZR.Model.Dto; using {ModelsNamespace}.Dto;
using ZR.Model.Models; using {ModelsNamespace}.Models;
namespace ZRAdmin.Controllers namespace ZRAdmin.Controllers
{ {
@ -108,6 +108,7 @@ namespace ZRAdmin.Controllers
var response = _<#=ServiceName#>.Update(w => w.{primaryKey} == updateModel.{primaryKey}, it => new <#=ModelName#>() var response = _<#=ServiceName#>.Update(w => w.{primaryKey} == updateModel.{primaryKey}, it => new <#=ModelName#>()
{ {
//TODO 字段映射 //TODO 字段映射
{updateColumn}
}); });
return SUCCESS(response); return SUCCESS(response);

View File

@ -1,5 +1,5 @@
using System; using System;
using ZR.Model.Models; using {ModelsNamespace}.Models;
namespace {IServicsNamespace}.Business namespace {IServicsNamespace}.Business
{ {

View File

@ -1,6 +1,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using {ModelsNamespace}.Dto; using {ModelsNamespace}.Dto;
using {ModelsNamespace}.Models;
namespace {DtosNamespace}.Dto namespace {DtosNamespace}.Dto
{ {

View File

@ -7,9 +7,9 @@ using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Text; using System.Text;
using ZR.Common; using ZR.Common;
using ZR.Model.Models; using {ModelsNamespace}.Models;
using ZR.Repository; using {IRepositoriesNamespace};
using ZR.Service.IService; using {ServicesNamespace}.IService;
namespace {ServicesNamespace}.Business namespace {ServicesNamespace}.Business
{ {

View File

@ -65,7 +65,7 @@
<!-- 添加或修改菜单对话框 --> <!-- 添加或修改菜单对话框 -->
<el-dialog :title="title" :visible.sync="open" append-to-body> <el-dialog :title="title" :visible.sync="open" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="100px"> <el-form ref="form" :model="form" :rules="rules" label-width="100px">
{VueViewFromContent} {VueViewFormContent}
</el-form> </el-form>
<div slot="footer" class="dialog-footer" v-if="btnSubmitVisible"> <div slot="footer" class="dialog-footer" v-if="btnSubmitVisible">
<el-button type="primary" @click="submitForm">确 定</el-button> <el-button type="primary" @click="submitForm">确 定</el-button>
@ -119,7 +119,7 @@ export default {
btnSubmitVisible: true, btnSubmitVisible: true,
// 表单校验 // 表单校验
rules: { rules: {
{VueViewEditFromRuleContent} {VueViewEditFormRuleContent}
}, },
}; };
}, },
@ -150,7 +150,7 @@ export default {
// 重置数据表单 // 重置数据表单
reset() { reset() {
this.form = { this.form = {
{VueViewEditFromContent} {VueViewEditFormContent}
//需个性化处理内容 //需个性化处理内容
}; };
this.resetForm("form"); this.resetForm("form");
@ -184,7 +184,7 @@ export default {
}, },
/** 删除按钮操作 */ /** 删除按钮操作 */
handleDelete(row) { handleDelete(row) {
del{ModelTypeName}().then((res) => { del{ModelTypeName}(row.{primaryKey}).then((res) => {
this.msgSuccess("删除成功"); this.msgSuccess("删除成功");
this.handleQuery(); this.handleQuery();
}); });
@ -207,7 +207,7 @@ export default {
if (valid) { if (valid) {
console.log(JSON.stringify(this.form)); console.log(JSON.stringify(this.form));
if (this.form.{primaryKey} != undefined) { if (this.form.{primaryKey} != undefined || this.title === '修改数据') {
update{ModelTypeName}(this.form).then((res) => { update{ModelTypeName}(this.form).then((res) => {
this.msgSuccess("修改成功"); this.msgSuccess("修改成功");
this.open = false; this.open = false;

View File

@ -41,6 +41,7 @@ namespace ZR.CodeGenerator
_option.DtosNamespace = "ZR.Model"; _option.DtosNamespace = "ZR.Model";
_option.ModelsNamespace = "ZR.Model"; _option.ModelsNamespace = "ZR.Model";
_option.RepositoriesNamespace = "ZR.Repository"; _option.RepositoriesNamespace = "ZR.Repository";
_option.IRepositoriesNamespace = "ZR.Repository";
_option.IServicsNamespace = "ZR.Service"; _option.IServicsNamespace = "ZR.Service";
_option.ServicesNamespace = "ZR.Service"; _option.ServicesNamespace = "ZR.Service";
_option.ApiControllerNamespace = "ZR.Admin.WebApi"; _option.ApiControllerNamespace = "ZR.Admin.WebApi";
@ -64,7 +65,7 @@ namespace ZR.CodeGenerator
public static void GenerateSingle(List<DbColumnInfo> listField, DbTableInfo tableInfo, GenerateDto dto) public static void GenerateSingle(List<DbColumnInfo> listField, DbTableInfo tableInfo, GenerateDto dto)
{ {
bool ifExsitedCovered = dto.coverd; bool ifExsitedCovered = dto.coverd;
var modelTypeName = GetModelName(tableInfo.Name); var modelTypeName = GetModelClassName(tableInfo.Name);//表名对应C# 实体类名
var modelTypeDesc = tableInfo.Description;//表描述 var modelTypeDesc = tableInfo.Description;//表描述
var primaryKey = "id";//主键 var primaryKey = "id";//主键
@ -72,6 +73,7 @@ namespace ZR.CodeGenerator
string modelContent = "";//数据库模型字段 string modelContent = "";//数据库模型字段
string InputDtoContent = "";//输入模型 string InputDtoContent = "";//输入模型
string outputDtoContent = "";//输出模型 string outputDtoContent = "";//输出模型
string updateColumn = "";//修改数据映射字段
string vueViewListContent = string.Empty;//Vue列表输出内容 string vueViewListContent = string.Empty;//Vue列表输出内容
string vueViewFormContent = string.Empty;//Vue表单输出内容 string vueViewFormContent = string.Empty;//Vue表单输出内容
string vueViewEditFromContent = string.Empty;//Vue变量输出内容 string vueViewEditFromContent = string.Empty;//Vue变量输出内容
@ -86,24 +88,32 @@ namespace ZR.CodeGenerator
if (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint") if (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint")
{ {
vueViewEditFromContent += $" {columnName}: 'true',\n"; vueViewEditFromContent += $" {columnName}: 'true',\n";
vueViewEditFromBindContent += $" this.form.{columnName} = res.data.{0}+''\n"; //vueViewEditFromBindContent += $" this.form.{columnName} = res.data.{0}+''\n";
} }
else else
{ {
vueViewEditFromContent += $" {columnName}: undefined,\n"; vueViewEditFromContent += $" {columnName}: undefined,\n";
vueViewEditFromBindContent += $" {columnName}: row.{columnName},\n"; //vueViewEditFromBindContent += $" {columnName}: row.{columnName},\n";
} }
//vueViewSaveBindContent += string.Format(" '{0}':this.editFrom.{0},\n", columnName); //vueViewSaveBindContent += string.Format(" '{0}':this.editFrom.{0},\n", columnName);
//主键
if (dbFieldInfo.IsIdentity || dbFieldInfo.IsPrimarykey) if (dbFieldInfo.IsIdentity || dbFieldInfo.IsPrimarykey)
{ {
primaryKey = columnName; primaryKey = columnName.Substring(0, 1).ToUpper() + columnName[1..];
keyTypeName = dbFieldInfo.DataType; keyTypeName = dbFieldInfo.DataType;
} }
else
{
var tempColumnName = columnName.Substring(0, 1).ToUpper() + columnName[1..];
updateColumn += $" {tempColumnName} = parm.{tempColumnName},\n";
}
dbFieldInfo.DbColumnName = columnName;
modelContent += GetModelTemplate(dbFieldInfo); modelContent += GetModelTemplate(dbFieldInfo);
vueViewFormContent += GetVueViewFormContent(dbFieldInfo, columnName); vueViewFormContent += GetVueViewFormContent(dbFieldInfo);
vueViewListContent += GetTableColumn(dbFieldInfo, columnName); vueViewListContent += GetTableColumn(dbFieldInfo);
vueViewEditFromRuleContent += GetFormRules(dbFieldInfo, columnName); vueViewEditFromRuleContent += GetFormRules(dbFieldInfo);
InputDtoContent += GetDtoContent(dbFieldInfo, columnName); InputDtoContent += GetDtoContent(dbFieldInfo);
} }
if (dto.genFiles.Contains(1)) if (dto.genFiles.Contains(1))
{ {
@ -124,7 +134,7 @@ namespace ZR.CodeGenerator
} }
if (dto.genFiles.Contains(5)) if (dto.genFiles.Contains(5))
{ {
GenerateControllers(modelTypeName, primaryKey, modelTypeDesc, keyTypeName, ifExsitedCovered); GenerateControllers(modelTypeName, primaryKey, modelTypeDesc, keyTypeName, updateColumn, ifExsitedCovered);
} }
if (dto.genFiles.Contains(6)) if (dto.genFiles.Contains(6))
{ {
@ -137,13 +147,13 @@ namespace ZR.CodeGenerator
#region Template #region Template
//rules //rules
private static string GetFormRules(DbColumnInfo dbFieldInfo, string columnName) private static string GetFormRules(DbColumnInfo dbFieldInfo)
{ {
string vueViewEditFromRuleContent = ""; string vueViewEditFromRuleContent = "";
//Rule 规则验证 //Rule 规则验证
if (!dbFieldInfo.IsNullable && !dbFieldInfo.IsIdentity) if (!dbFieldInfo.IsNullable && !dbFieldInfo.IsIdentity)
{ {
vueViewEditFromRuleContent += $" {columnName}: [\n"; vueViewEditFromRuleContent += $" {dbFieldInfo.DbColumnName}: [\n";
vueViewEditFromRuleContent += $" {{ required: true, message:\"{dbFieldInfo.ColumnDescription}\", trigger: \"blur\"}},\n"; vueViewEditFromRuleContent += $" {{ required: true, message:\"{dbFieldInfo.ColumnDescription}\", trigger: \"blur\"}},\n";
//vueViewEditFromRuleContent += " { min: 2, max: 50, message: \"长度在 2 到 50 个字符\", trigger:\"blur\" }\n"; //vueViewEditFromRuleContent += " { min: 2, max: 50, message: \"长度在 2 到 50 个字符\", trigger:\"blur\" }\n";
vueViewEditFromRuleContent += " ],\n"; vueViewEditFromRuleContent += " ],\n";
@ -155,7 +165,7 @@ namespace ZR.CodeGenerator
//model 属性 //model 属性
private static string GetModelTemplate(DbColumnInfo dbFieldInfo) private static string GetModelTemplate(DbColumnInfo dbFieldInfo)
{ {
string columnName = dbFieldInfo.DbColumnName.Substring(0, 1).ToUpper() + dbFieldInfo.DbColumnName.Substring(1); string columnName = dbFieldInfo.DbColumnName.Substring(0, 1).ToUpper() + dbFieldInfo.DbColumnName[1..];
var modelcontent = ""; var modelcontent = "";
modelcontent += " /// <summary>\n"; modelcontent += " /// <summary>\n";
modelcontent += $" /// 描述 :{dbFieldInfo.ColumnDescription}\n"; modelcontent += $" /// 描述 :{dbFieldInfo.ColumnDescription}\n";
@ -170,26 +180,22 @@ namespace ZR.CodeGenerator
return modelcontent; return modelcontent;
} }
//DTO model //DTO model
private static string GetDtoContent(DbColumnInfo dbFieldInfo, string columnName) private static string GetDtoContent(DbColumnInfo dbFieldInfo)
{ {
string columnName = dbFieldInfo.DbColumnName.Substring(0, 1).ToUpper() + dbFieldInfo.DbColumnName[1..];
string InputDtoContent = ""; string InputDtoContent = "";
if (!inputDtoNoField.Any(x => x.ToLower().Contains(columnName)) || !dbFieldInfo.IsIdentity) InputDtoContent += $" public {TableMappingHelper.GetPropertyDatatype(dbFieldInfo.DataType)} {columnName} {{ get; set; }}\n\r";
{
InputDtoContent += " /// <summary>\n";
InputDtoContent += $" /// 设置或获取{dbFieldInfo.ColumnDescription}\n";
InputDtoContent += " /// </summary>\n";
InputDtoContent += $" public {TableMappingHelper.GetPropertyDatatype(dbFieldInfo.DataType)} {columnName} {{ get; set; }}\n\r";
}
return InputDtoContent; return InputDtoContent;
} }
//form-item //form-item
private static string GetVueViewFormContent(DbColumnInfo dbFieldInfo, string columnName) private static string GetVueViewFormContent(DbColumnInfo dbFieldInfo)
{ {
columnName = FirstLowerCase(columnName); string columnName = FirstLowerCase(dbFieldInfo.DbColumnName);
string labelName = GetLabelName(dbFieldInfo.ColumnDescription, columnName); string labelName = GetLabelName(dbFieldInfo.ColumnDescription, columnName);
string vueViewFromContent = ""; string vueViewFromContent = "";
string labelDisabled = dbFieldInfo.IsIdentity ? ":disabled=\"true\"" : "";
if (dbFieldInfo.DataType == "datetime") if (dbFieldInfo.DataType == "datetime")
{ {
vueViewFromContent += ""; vueViewFromContent += "";
@ -198,7 +204,7 @@ namespace ZR.CodeGenerator
{ {
//TODO 图片 //TODO 图片
} }
else if (radioFiled.Any(f => columnName.Contains(f)) && (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint")) else if (radioFiled.Any(f => columnName.Contains(f)) && (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint" || dbFieldInfo.DataType == "int"))
{ {
vueViewFromContent += $" <el-col :span=\"12\">\n"; vueViewFromContent += $" <el-col :span=\"12\">\n";
vueViewFromContent += $" <el-form-item label=\"{labelName}\" :label-width=\"labelWidth\" prop=\"{columnName}\">"; vueViewFromContent += $" <el-form-item label=\"{labelName}\" :label-width=\"labelWidth\" prop=\"{columnName}\">";
@ -212,7 +218,7 @@ namespace ZR.CodeGenerator
{ {
vueViewFromContent += $" <el-col :span=\"12\">\n"; vueViewFromContent += $" <el-col :span=\"12\">\n";
vueViewFromContent += $" <el-form-item label=\"{ GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" :label-width=\"labelWidth\" prop=\"{FirstLowerCase(columnName)}\">\n"; vueViewFromContent += $" <el-form-item label=\"{ GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" :label-width=\"labelWidth\" prop=\"{FirstLowerCase(columnName)}\">\n";
vueViewFromContent += $" <el-input v-model=\"form.{FirstLowerCase(columnName)}\" placeholder=\"请输入{GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" />\n"; vueViewFromContent += $" <el-input v-model=\"form.{FirstLowerCase(columnName)}\" placeholder=\"请输入{GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" {labelDisabled}/>\n";
vueViewFromContent += " </el-form-item>\n"; vueViewFromContent += " </el-form-item>\n";
vueViewFromContent += " </el-col>\n"; vueViewFromContent += " </el-col>\n";
} }
@ -221,9 +227,9 @@ namespace ZR.CodeGenerator
} }
//table-column //table-column
private static string GetTableColumn(DbColumnInfo dbFieldInfo, string columnName) private static string GetTableColumn(DbColumnInfo dbFieldInfo)
{ {
columnName = FirstLowerCase(columnName); string columnName = FirstLowerCase(dbFieldInfo.DbColumnName);
string label = GetLabelName(dbFieldInfo.ColumnDescription, columnName); string label = GetLabelName(dbFieldInfo.ColumnDescription, columnName);
string vueViewListContent = ""; string vueViewListContent = "";
string showToolTip = dbFieldInfo.DataType.Contains("varchar") ? ":show-overflow-tooltip=\"true\"" : ""; string showToolTip = dbFieldInfo.DataType.Contains("varchar") ? ":show-overflow-tooltip=\"true\"" : "";
@ -384,9 +390,10 @@ namespace ZR.CodeGenerator
return; return;
var content = ReadTemplate("IServiceTemplate.txt"); var content = ReadTemplate("IServiceTemplate.txt");
content = content.Replace("{ModelsNamespace}", modelsNamespace) content = content.Replace("{ModelsNamespace}", modelsNamespace)
.Replace("{DtosNamespace}", _option.DtosNamespace)
.Replace("{TableNameDesc}", modelTypeDesc) .Replace("{TableNameDesc}", modelTypeDesc)
.Replace("{DtosNamespace}", _option.DtosNamespace)
.Replace("{IServicsNamespace}", _option.IServicsNamespace) .Replace("{IServicsNamespace}", _option.IServicsNamespace)
.Replace("{RepositoriesNamespace}", _option.RepositoriesNamespace)
.Replace("{ModelTypeName}", modelTypeName) .Replace("{ModelTypeName}", modelTypeName)
.Replace("{KeyTypeName}", keyTypeName); .Replace("{KeyTypeName}", keyTypeName);
WriteAndSave(fullPath, content); WriteAndSave(fullPath, content);
@ -436,7 +443,7 @@ namespace ZR.CodeGenerator
/// <param name="modelTypeDesc">实体描述</param> /// <param name="modelTypeDesc">实体描述</param>
/// <param name="keyTypeName"></param> /// <param name="keyTypeName"></param>
/// <param name="ifExsitedCovered">如果目标文件存在是否覆盖。默认为false</param> /// <param name="ifExsitedCovered">如果目标文件存在是否覆盖。默认为false</param>
private static void GenerateControllers(string modelTypeName, string primaryKey, string modelTypeDesc, string keyTypeName, bool ifExsitedCovered = false) private static void GenerateControllers(string modelTypeName, string primaryKey, string modelTypeDesc, string keyTypeName, string updateColumn, bool ifExsitedCovered = false)
{ {
var parentPath = ".."; var parentPath = "..";
var servicesPath = parentPath + "\\" + _option.ApiControllerNamespace + "\\Controllers\\business\\"; var servicesPath = parentPath + "\\" + _option.ApiControllerNamespace + "\\Controllers\\business\\";
@ -452,12 +459,13 @@ namespace ZR.CodeGenerator
content = content content = content
//.Replace("{DtosNamespace}", _option.DtosNamespace) //.Replace("{DtosNamespace}", _option.DtosNamespace)
.Replace("<#=ControllerName#>", modelTypeName) .Replace("<#=ControllerName#>", modelTypeName)
//.Replace("{ModelsNamespace}", _option.ModelsNamespace) .Replace("{ModelsNamespace}", _option.ModelsNamespace)
.Replace("<#=FileName#>", modelTypeDesc) .Replace("<#=FileName#>", modelTypeDesc)
.Replace("<#=ServiceName#>", modelTypeName + "Service") .Replace("<#=ServiceName#>", modelTypeName + "Service")
.Replace("<#=ModelName#>", modelTypeName) .Replace("<#=ModelName#>", modelTypeName)
.Replace("<#=Permission#>", modelTypeName.ToLower()) .Replace("<#=Permission#>", modelTypeName.ToLower())
.Replace("{primaryKey}", primaryKey) .Replace("{primaryKey}", primaryKey)
.Replace("{updateColumn}", updateColumn)
.Replace("{KeyTypeName}", keyTypeName); .Replace("{KeyTypeName}", keyTypeName);
WriteAndSave(fullPath, content); WriteAndSave(fullPath, content);
} }
@ -478,7 +486,8 @@ namespace ZR.CodeGenerator
/// <param name="ifExsitedCovered">如果目标文件存在是否覆盖。默认为false</param> /// <param name="ifExsitedCovered">如果目标文件存在是否覆盖。默认为false</param>
private static void GenerateVueViews(string modelTypeName, string primaryKey, string modelTypeDesc, string vueViewListContent, string vueViewFromContent, string vueViewEditFromContent, string vueViewEditFromBindContent, string vueViewSaveBindContent, string vueViewEditFromRuleContent, bool ifExsitedCovered = false) private static void GenerateVueViews(string modelTypeName, string primaryKey, string modelTypeDesc, string vueViewListContent, string vueViewFromContent, string vueViewEditFromContent, string vueViewEditFromBindContent, string vueViewSaveBindContent, string vueViewEditFromRuleContent, bool ifExsitedCovered = false)
{ {
var parentPath = "..\\CodeGenerate";//若要生成到项目中将路径改成 “..\\ZR.Vue\\src” //var parentPath = "..\\CodeGenerate";//若要生成到项目中将路径改成 “..\\ZR.Vue\\src”
var parentPath = "..\\ZR.Vue\\src";
var servicesPath = parentPath + "\\views\\" + FirstLowerCase(modelTypeName); var servicesPath = parentPath + "\\views\\" + FirstLowerCase(modelTypeName);
if (!Directory.Exists(servicesPath)) if (!Directory.Exists(servicesPath))
{ {
@ -491,15 +500,15 @@ namespace ZR.CodeGenerator
var content = ReadTemplate("VueTemplate.txt"); var content = ReadTemplate("VueTemplate.txt");
content = content content = content
.Replace("{fileClassName}", FirstLowerCase(modelTypeName)) .Replace("{fileClassName}", FirstLowerCase(modelTypeName))
.Replace("{VueViewListContent}", vueViewListContent) .Replace("{VueViewListContent}", vueViewListContent)//查询 table列
.Replace("{VueViewFromContent}", vueViewFromContent) .Replace("{VueViewFormContent}", vueViewFromContent)//添加、修改表单
.Replace("{ModelTypeName}", modelTypeName) .Replace("{ModelTypeName}", modelTypeName)
.Replace("{Permission}", modelTypeName.ToLower()) .Replace("{Permission}", modelTypeName.ToLower())
.Replace("{VueViewEditFromContent}", vueViewEditFromContent) .Replace("{VueViewEditFormContent}", vueViewEditFromContent)//重置表单
.Replace("{VueViewEditFromBindContent}", vueViewEditFromBindContent) //.Replace("{VueViewEditFromBindContent}", vueViewEditFromBindContent)
.Replace("{VueViewSaveBindContent}", vueViewSaveBindContent) //.Replace("{VueViewSaveBindContent}", vueViewSaveBindContent)
.Replace("{primaryKey}", primaryKey) .Replace("{primaryKey}", FirstLowerCase(primaryKey))
.Replace("{VueViewEditFromRuleContent}", vueViewEditFromRuleContent); .Replace("{VueViewEditFormRuleContent}", vueViewEditFromRuleContent);//添加、修改表单验证规则
WriteAndSave(fullPath, content); WriteAndSave(fullPath, content);
//api js //api js
@ -512,7 +521,6 @@ namespace ZR.CodeGenerator
content = ReadTemplate("VueJsTemplate.txt"); content = ReadTemplate("VueJsTemplate.txt");
content = content content = content
.Replace("{ModelTypeName}", modelTypeName) .Replace("{ModelTypeName}", modelTypeName)
.Replace("{ModelName}", GetModelName(modelTypeName))
.Replace("{ModelTypeDesc}", modelTypeDesc); .Replace("{ModelTypeDesc}", modelTypeDesc);
//.Replace("{fileClassName}", fileClassName) //.Replace("{fileClassName}", fileClassName)
WriteAndSave(fullPath, content); WriteAndSave(fullPath, content);
@ -528,7 +536,7 @@ namespace ZR.CodeGenerator
/// </summary> /// </summary>
/// <param name="modelTypeName"></param> /// <param name="modelTypeName"></param>
/// <returns></returns> /// <returns></returns>
private static string GetModelName(string modelTypeName) private static string GetModelClassName(string modelTypeName)
{ {
if (!string.IsNullOrEmpty(_option.ReplaceTableNameStr)) if (!string.IsNullOrEmpty(_option.ReplaceTableNameStr))
{ {

View File

@ -44,7 +44,7 @@ export const constantRoutes = [
}, },
{ {
path: '/demo', path: '/demo',
component: (resolve) => require(['@/views/userInfo/index'], resolve), component: (resolve) => require(['@/views/gendemo/index'], resolve),
hidden: true hidden: true
}, },
{ {

View File

@ -920,46 +920,5 @@
</summary> </summary>
<param name="services"></param> <param name="services"></param>
</member> </member>
<member name="T:ZRAdmin.Controllers.UserInfoController">
<summary>
代码自动生成
</summary>
</member>
<member name="F:ZRAdmin.Controllers.UserInfoController._UserInfoService">
<summary>
接口
</summary>
</member>
<member name="M:ZRAdmin.Controllers.UserInfoController.Query(ZR.Model.Dto.UserInfoQueryDto)">
<summary>
查询列表
</summary>
<returns></returns>
</member>
<member name="M:ZRAdmin.Controllers.UserInfoController.Get(System.Int32)">
<summary>
查询详情
</summary>
<param name="luid"></param>
<returns></returns>
</member>
<member name="M:ZRAdmin.Controllers.UserInfoController.Create(ZR.Model.Dto.UserInfoDto)">
<summary>
添加
</summary>
<returns></returns>
</member>
<member name="M:ZRAdmin.Controllers.UserInfoController.Update(ZR.Model.Dto.UserInfoDto)">
<summary>
更新
</summary>
<returns></returns>
</member>
<member name="M:ZRAdmin.Controllers.UserInfoController.Delete(System.Int32)">
<summary>
删除
</summary>
<returns></returns>
</member>
</members> </members>
</doc> </doc>