如何在模板驱动的方法中保存没有NGMODEL的数据
我陷入了必须将数据保存到Angular UI到数据库的情况。我正在显示表格数据(表标头和表值)根据某些下拉选择更改的表格格式数据。
如果没有一个模型,该模型被定义了将数据绑定到的属性,那么一个人如何将数据保存到数据库中?
我想到创建模型类并将所有属性保留在其中,以便每当下拉列表选择时,当我们从数据库中获取数据时,我可以选择数据并将其绑定到这些属性。但是这些信息为一百。创建100多个属性可以吗?当我们不知道UI中将显示多少个值时。
例如,下拉列表具有4个值A,B,C,D。在选择A,15行(包括表标头和数据)时,返回了B,30。选择C,50,50。 。
然后以表格格式显示这些值 (即15、30、50 ..列)
用于显示,我正在使用以下代码:
.ts
async ngOnInit() {
try {
this.equipmentTypeInfo = await this.parameterService.getEquipmentTypes().toPromise();
this.onEquipmentTypeSelectionChange(this.equipmentTypeInfo.length > 0 ? this.equipmentTypeInfo[0] : undefined);
} catch (error) {
this.errorService.handlePageError(error);
}
}
async onEquipmentTypeSelectionChange(equipment: any) {
if (this.demoheader.length > 0)
this.demoheader = [];
this.solverData = new Map<string, string>();
//this.clearComponentVariables();
try {
if (equipment) {
this.selectedEquipmentType = equipment;
}
this.searchModel.templateUrn = equipment;
this.searchModel.maxRows = 76;
this.isLoading = true;
//this.errorComponent.clearError();
this.parameterModels = await this.parameterService.getEquipmentTypeSearchResults(equipment).toPromise();
const groups = this.parameterModels.reduce((groups, param) => {
groups[param.entityName] = groups[param.entityName] || [];
groups[param.entityName].push(param);
return groups;
}, {});
//Adding in the Dictionary format
const groupArrays = Object.keys(groups).map((entityName) => {
return {
entityName,
solverParameterData: groups[entityName]
};
});
for (var i = 0; i < groupArrays.length; ++i) {
this.solverData.set("Equipment Name", groupArrays[i].entityName);
groupArrays[i].solverParameterData.forEach(y => {
//since the column would be same for the data, therefore, getting the first set and then breaking.
this.solverData.set(y.attributeUrn, y.value);
});
break;
}
this.groupDataInfo = groupArrays;
this.solverData.forEach((item, key) => {
this.demoheader.push(key);
this.demoValue.push(item);
});
} catch (error) {
this.errorService.handlePageError(error);
} finally {
this.isLoading = false;
}
}
.html
<table class="tableInfo">
<thead *ngIf="parameterModels?.length > 0">
<tr>
<th class="tableheaders" *ngFor="let paramType of demoheader; let i = index">
{{paramType}}
</th>
</tr>
</thead>
<tbody>
<tr *ngFor="let paramTypes of groupDataInfo; let i = index">
<td>
<div class="tabledataEquipmentNameInfo">
<input id="entityName" type="text" name="{{paramTypes.entityName}}{{i}}" value="{{paramTypes.entityName}}" class="form-control" disabled>
</div>
</td>
<td *ngFor="let paramType of paramTypes.solverParameterData; let ii = index">
<div class="tabledataEquipmentNameInfo">
<input id="entityName" type="text" name="{{paramTypes.entityName}}{{i}}" value="{{paramType.value}}" class="form-control" disabled>
</div>
</td>
</tr>
</tbody>
</table>
我能够显示数据。但是现在出现的问题,我将如何保存数据。我没有创建任何模型。另外,可以有1行以上,我可以编辑任何行信息。我们确实有肮脏的属性,但这也可以在模型上工作。任何实现节省的方法。还是我必须创建一个模型类,然后使用NGMODEL?
I am stuck in a situation where I have to save data to the database from Angular UI. I am showing a tabular format data where the table data (table header and table value) changes based on some dropdown selection.
Without having a model where properties are defined to which the data will be bind to, how can one save the data to the database?
I thought of creating a model class and keeping all the properties into it so that whenever on the dropdown selection, when we fetch data from the database, I can select the data and bind it to those properties. But that information is in hundred. Creating 100+ properties would be okay? When we dont know how many values will be displayed in the UI.
For example the dropdown has 4 values A, B, C, D. On the selection of A, 15 rows(including the table header and data) are returned, On selection of B, 30. On selection of C, 50, etc..
These values are then displayed in the tabular format. (i.e. 15, 30, 50.. columns,)
For displaying, I am using the following code:
.ts
async ngOnInit() {
try {
this.equipmentTypeInfo = await this.parameterService.getEquipmentTypes().toPromise();
this.onEquipmentTypeSelectionChange(this.equipmentTypeInfo.length > 0 ? this.equipmentTypeInfo[0] : undefined);
} catch (error) {
this.errorService.handlePageError(error);
}
}
async onEquipmentTypeSelectionChange(equipment: any) {
if (this.demoheader.length > 0)
this.demoheader = [];
this.solverData = new Map<string, string>();
//this.clearComponentVariables();
try {
if (equipment) {
this.selectedEquipmentType = equipment;
}
this.searchModel.templateUrn = equipment;
this.searchModel.maxRows = 76;
this.isLoading = true;
//this.errorComponent.clearError();
this.parameterModels = await this.parameterService.getEquipmentTypeSearchResults(equipment).toPromise();
const groups = this.parameterModels.reduce((groups, param) => {
groups[param.entityName] = groups[param.entityName] || [];
groups[param.entityName].push(param);
return groups;
}, {});
//Adding in the Dictionary format
const groupArrays = Object.keys(groups).map((entityName) => {
return {
entityName,
solverParameterData: groups[entityName]
};
});
for (var i = 0; i < groupArrays.length; ++i) {
this.solverData.set("Equipment Name", groupArrays[i].entityName);
groupArrays[i].solverParameterData.forEach(y => {
//since the column would be same for the data, therefore, getting the first set and then breaking.
this.solverData.set(y.attributeUrn, y.value);
});
break;
}
this.groupDataInfo = groupArrays;
this.solverData.forEach((item, key) => {
this.demoheader.push(key);
this.demoValue.push(item);
});
} catch (error) {
this.errorService.handlePageError(error);
} finally {
this.isLoading = false;
}
}
.html
<table class="tableInfo">
<thead *ngIf="parameterModels?.length > 0">
<tr>
<th class="tableheaders" *ngFor="let paramType of demoheader; let i = index">
{{paramType}}
</th>
</tr>
</thead>
<tbody>
<tr *ngFor="let paramTypes of groupDataInfo; let i = index">
<td>
<div class="tabledataEquipmentNameInfo">
<input id="entityName" type="text" name="{{paramTypes.entityName}}{{i}}" value="{{paramTypes.entityName}}" class="form-control" disabled>
</div>
</td>
<td *ngFor="let paramType of paramTypes.solverParameterData; let ii = index">
<div class="tabledataEquipmentNameInfo">
<input id="entityName" type="text" name="{{paramTypes.entityName}}{{i}}" value="{{paramType.value}}" class="form-control" disabled>
</div>
</td>
</tr>
</tbody>
</table>
I am able to show the data. But the question now arises, How will I save the data. I have not created any model. Also, there can be more than 1 rows and I can edit any row information. We do have dirty property but that would also work on model. Any way to achieve the save. or I have to create a model class and then use the ngmodel?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
简单的方法是使用反应性形式,或者只是具有数据模型 - 一系列行模型,但是由于您想以困难的方式进行。...
您可以将所有内容包装到
&lt; form&gt; 并执行普通的旧html表单提交。
如果您需要在提交事先提交的表单/数据的情况下进行一些处理,则可以始终将其连接到
onsubmit
表单中。The easy way would be either to use ReactiveForms or just have data model - an array of row models, but since you want to do it the hard way....
You can wrap everything into a
<form>
and do plain old HTML form submission.if you need to so something about that form/data prior submission, you can always hook into
onsubmit
form.