如何将 JSON 对象键值对分别绑定到 angular 模板
How to bind JSON object key value pair separately to angular template
我有一个来自 API 的动态 json,如下所示:
{123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra",...}
我在模板中编写了以下 HTML 代码,其中我从资产文件夹中获取图像 1、图像 2 徽标
<div class="row">
<div class="col-6" (click)="cityClick('Bangalore')">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
Bangalore
</div>
</div>
<div class="col-6" col-6 (click)="cityClick('Mumbai')">
<div id="image_block" class="img-2">
// my image-2 logo goes here
</div>
<div id="text_block" class="img-text">
Mumbai
</div>
</div>
</div>
当我点击图片时,如何获取 json 的键,并根据相应的键值显示图片下方的文本。
当我点击时,我应该能够在点击事件中传递密钥和文本。请帮忙,因为我是 Angular 的新手!
首先将这个 JSON 转换成一个 JavaScript/TypeScript 数组,如下所示:
var json = {123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra" };
var jsonToBeUsed = [];
for (var type in json) {
item = {};
item.key = type;
item.value = json[type];
jsonToBeUsed.push(item);
}
这将导致如下数据:
现在在模板中使用NgFor绑定数组。 (NgFor 参考 this)
<div class="row">
<div *ngFor="let item of array">
<div class="col-6" (click)="cityClick(item)">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
{{item.value}}
</div>
</div>
</div>
</div>
我们已经在点击事件中传递了整个对象。您可以从您将在组件中编写的单击事件处理程序中的对象读取任何所需的 属性。
对于您的特殊要求,您可以使用以下标记:
<div class='row' *ngFor='let index of array; let i = index; let even = even'>
<div *ngIf="even" class='col-6' (click)="cityClick(array[i])">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
{{array[i].value}}
</div>
</div>
<div *ngIf="!even" class='col-6' (click)="cityClick(array[i])">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
{{array[i].value}}
</div>
</div>
</div>
在您的代码中使用以下函数:
getKeyByValue(object, value) {
return Object.keys(object).find(key => object[key] === value);
}
并用作
var dynamicJson = {123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra"}
cityClick(value){
var key = this.getKeyByValue(this.dynamicJson, value);
console.log(key);
}
{123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra",...}
你对JSON有影响吗?这对我来说非常像是一个设计问题。我假设这些数字是 id 的。我相信这样的事情应该更好:
[{id: "123", name: "Mumbai"}, {id: "456", name: "Bangalore"}, {id: "789", name: "Chennai"}, {id: "101", name: "Andhra"},...}]
在这种情况下,您会收到一个城市数组,这可能是一个要解析的接口。
export interface City {
id: string;
name: string;
}
并且您可以使用 *ngFor
在 html 中轻松渲染它
<div *ngFor="let city of cities">
<!--do something with city.id and city.name-->
</div>
<div *ngFor let value of json |keyvalue > </div>
我有一个来自 API 的动态 json,如下所示:
{123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra",...}
我在模板中编写了以下 HTML 代码,其中我从资产文件夹中获取图像 1、图像 2 徽标
<div class="row">
<div class="col-6" (click)="cityClick('Bangalore')">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
Bangalore
</div>
</div>
<div class="col-6" col-6 (click)="cityClick('Mumbai')">
<div id="image_block" class="img-2">
// my image-2 logo goes here
</div>
<div id="text_block" class="img-text">
Mumbai
</div>
</div>
</div>
当我点击图片时,如何获取 json 的键,并根据相应的键值显示图片下方的文本。 当我点击时,我应该能够在点击事件中传递密钥和文本。请帮忙,因为我是 Angular 的新手!
首先将这个 JSON 转换成一个 JavaScript/TypeScript 数组,如下所示:
var json = {123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra" };
var jsonToBeUsed = [];
for (var type in json) {
item = {};
item.key = type;
item.value = json[type];
jsonToBeUsed.push(item);
}
这将导致如下数据:
现在在模板中使用NgFor绑定数组。 (NgFor 参考 this)
<div class="row">
<div *ngFor="let item of array">
<div class="col-6" (click)="cityClick(item)">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
{{item.value}}
</div>
</div>
</div>
</div>
我们已经在点击事件中传递了整个对象。您可以从您将在组件中编写的单击事件处理程序中的对象读取任何所需的 属性。
对于您的特殊要求,您可以使用以下标记:
<div class='row' *ngFor='let index of array; let i = index; let even = even'>
<div *ngIf="even" class='col-6' (click)="cityClick(array[i])">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
{{array[i].value}}
</div>
</div>
<div *ngIf="!even" class='col-6' (click)="cityClick(array[i])">
<div class="img-1">
// my image-1 logo goes here
</div>
<div class="img-text">
{{array[i].value}}
</div>
</div>
</div>
在您的代码中使用以下函数:
getKeyByValue(object, value) {
return Object.keys(object).find(key => object[key] === value);
}
并用作
var dynamicJson = {123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra"}
cityClick(value){
var key = this.getKeyByValue(this.dynamicJson, value);
console.log(key);
}
{123: "Mumbai", 456: "Bangalore", 789: "Chennai", 101: "Andhra",...}
你对JSON有影响吗?这对我来说非常像是一个设计问题。我假设这些数字是 id 的。我相信这样的事情应该更好:
[{id: "123", name: "Mumbai"}, {id: "456", name: "Bangalore"}, {id: "789", name: "Chennai"}, {id: "101", name: "Andhra"},...}]
在这种情况下,您会收到一个城市数组,这可能是一个要解析的接口。
export interface City {
id: string;
name: string;
}
并且您可以使用 *ngFor
在 html 中轻松渲染它<div *ngFor="let city of cities">
<!--do something with city.id and city.name-->
</div>
<div *ngFor let value of json |keyvalue > </div>