Create a List of Object Data Structures
recipe.service.ts
import { Injectable } from '@angular/core';
import { RecipeModel } from '../components/recipe';
@Injectable({
providedIn: 'root'
})
export class RecipeService {
private recipes: RecipeModel[] = [
{
id: 1,
name: "Adobo",
ingredients: `Chicken or pork braised in soy sauce, vinegar, and garlic`,
imageUrl: "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTmww5jTG0tVGxjPAoMtgYndRrcCm-NtAjyOQ&s"
},
{
id: 2,
name: "Sinigang",
ingredients: `Tamarind-based sour soup with pork.`,
imageUrl: ""
},
{
id: 3,
name: "Lechon Manok",
ingredients: `Filipino-style roasted chicken marinated with spices, cooked over charcoal for flavorful tenderness.`,
imageUrl: "https://www.unileverfoodsolutions.com.ph/dam/global-ufs/mcos/SEA/calcmenu/recipes/PH-recipes/chicken-&-other-poultry-dishes/lechon-manok/lechon-manok-main.jpg"
},
{
id: 4,
name: "Kare Kare",
ingredients: `Peanut stew with oxtail, tripe, and vegetables.`,
imageUrl: "https://www.unileverfoodsolutions.com.ph/dam/global-ufs/mcos/SEA/calcmenu/recipes/PH-recipes/red-meats-&-red-meat-dishes/kare-kare/kare-kare-main.jpg"
},
{
id: 5,
name: "Pansit Canton",
ingredients: `Stir-fried noodles with vegetables, shrimp, and meat.`,
imageUrl: "https://thefoodietakesflight.com/wp-content/uploads/2021/03/vegan-filipino-stir-fried-noodles-or-pancit-canton-recipe-2-682x1024.png"
},
{
id: 6,
name: "Chicken Inasal",
ingredients: `Grilled chicken marinated in vinegar and spices`,
imageUrl: "https://pinoybites.com/wp-content/uploads/2021/08/File_000-22-scaled.jpeg"
},
{
id: 7,
name: "Tinola",
ingredients: ` Chicken soup with green papaya, malunggay, and ginger.`,
imageUrl: "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQSTOfPBLx7vK2vNhqjPhaZxlByrY65PS9MgA&s"
},
{
id: 8,
name: "Bicol Express",
ingredients: `Spicy pork stew with coconut milk and chili peppers.`,
imageUrl: ""
},
{
id: 9,
name: "Bibingka",
ingredients: `rice cake made from rice flour, coconut milk, sugar, and topped with salted eggs and cheese, baked in banana leaves`,
imageUrl: "https://www.foxyfolksy.com/wp-content/uploads/2017/12/bibingka-t-500x500.jpg"
},
{
id: 10,
name: "Tocino",
ingredients: `sweet cured meat, usually pork, marinated with sugar, pineapple juice, and annatto for color.`,
imageUrl: "https://norecipes.com/wp-content/uploads/2018/05/filipino-tocino-recipe_010.jpg "
}
];
getRecipe(): RecipeModel[] {
return this.recipes;
}
}
recipe.model.ts
export interface RecipeModel{
id: number;
name: string;
ingredients: string;
imageUrl: string;
}
recipe.component.ts
import { RecipeService } from './../../services/recipe.service';
import { Component, OnInit } from '@angular/core';
import { RecipeModel } from '../recipe';
@Component({
selector: 'app-recipe',
templateUrl: './recipe.component.html',
styleUrl: './recipe.component.css'
})
export class RecipeComponent implements OnInit{
recipeList: RecipeModel[] = [];
constructor(private recipeService: RecipeService) {}
ngOnInit(): void {
this.recipeList = this.recipeService.getRecipe();
}
}
recipe.component.html
<!DOCTYPE html>
<html>
<head>
<title>Angular Recipe Grid</title>
</head>
<body>
<div class="recipe-grid">
<div *ngFor="let recipe of recipeList" class="recipe-grid__item">
<img
class="recipe-grid__image"
[src]="recipe.imageUrl"
/>
<h2 class="recipe-grid__name">{{ recipe.name }}</h2>
<p class="recipe-grid__author">{{ recipe.ingredients }}</p>
</div>
</div>
</body>
</html>
OUTPUT: