sql >> Databasteknik >  >> NoSQL >> MongoDB

Hur man kommer åt kapslade filer med Pick<> typscript

map funktion är för arrayer, så jag utgår från dina products nyckeln i ditt exempel är en array och inte ett objekt.

Först skulle jag föreslå att du skriver typdefinitioner för ditt produktsvar om du inte redan har gjort det

interface IProduct {
  _id: string,
  category: number,
  gender: number,
  title: string,
  description: string,
  price: number,
  imageFileName: string,
  createdAt: string,
  updatedAt: string,
  __v: number
}

interface IResponse {
  _id: string;
  products: IProduct[];
}

Sedan för att få Pick arbetar med en enda product objekt, kan du indexera IResponse gränssnitt genom att använda Indexerade åtkomsttyper . Du vill ha products egenskap vid ett index eftersom det är en array.

/*

Indexed Access Types

type Person = { age: number, name: string }[];
type Age = Person[number]["age"];

*/

type Products = ReadonlyArray<
  Pick<
    IResponse["products"][number],
    "_id" | "gender" | "title" | "description" | "price" | "imageFileName"
  >
>;

Om du skulle göra något som Pick<IResponse["products"], '_id'...> du skulle försöka använda Pick för att extrahera egenskaper från en array, vilket skulle resultera i ett fel.

Och det enda som återstår är att kartlägga produkterna från respons till önskad objektform.


// Query your products

const { products }: IResponse = {
  _id: "611e2febb863ce74ac448220",
  products: [
    {
      _id: "6116a9ecc3e98d500c5e523d",
      category: 5,
      gender: 1,
      title: 'sivdosi',
      description: 'oisbdvoi',
      price: 2394,
      imageFileName: 'http://localhost:3000/images/1628875244435-3564.png',
      createdAt: "2021-08-13T17:20:44.472Z",
      updatedAt: "2021-08-13T17:20:44.472Z",
      __v: 0
    }
  ]
}

// Get the desired object

const pickedProducts: Products = products.map(({ _id, gender, title, description, price, imageFileName }) => ({
  _id,
  gender,
  title,
  description,
  price,
  imageFileName
}));

Det slutliga resultatet ser ut ungefär som följande

interface IProduct {
  _id: string,
  category: number,
  gender: number,
  title: string,
  description: string,
  price: number,
  imageFileName: string,
  createdAt: string,
  updatedAt: string,
  __v: number
}

interface IResponse {
  _id: string;
  products: IProduct[];
}

type Products = ReadonlyArray<
  Pick<
    IResponse["products"][number],
    "_id" | "gender" | "title" | "description" | "price" | "imageFileName"
  >
>;

// Query your products

const { products }: IResponse = {
  _id: "611e2febb863ce74ac448220",
  products: [
    {
      _id: "6116a9ecc3e98d500c5e523d",
      category: 5,
      gender: 1,
      title: 'sivdosi',
      description: 'oisbdvoi',
      price: 2394,
      imageFileName: 'http://localhost:3000/images/1628875244435-3564.png',
      createdAt: "2021-08-13T17:20:44.472Z",
      updatedAt: "2021-08-13T17:20:44.472Z",
      __v: 0
    }
  ]
}

// Get the desired object

const pickedProducts: Products = products.map(({ _id, gender, title, description, price, imageFileName }) => ({
  _id,
  gender,
  title,
  description,
  price,
  imageFileName
}));



  1. Ta bort inbäddade dokument i en kapslad uppsättning dokument

  2. Meteor:Spara RegExp-objekt till session

  3. Infoga json-filen i mongodb

  4. Hur kvarstår MongoDB - data från en körande Docker-behållare i en ny bild?