Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/vue.js/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 过滤vue中的JSON对象以计算新对象_Javascript_Vue.js_Computed Properties - Fatal编程技术网

Javascript 过滤vue中的JSON对象以计算新对象

Javascript 过滤vue中的JSON对象以计算新对象,javascript,vue.js,computed-properties,Javascript,Vue.js,Computed Properties,我有一个来自我的服务器的JSON对象 [ { "id":1, "tag":"Cooking", "weight":null, "deleted_at":null, "created_at":null, "updated_at":null, "listi

我有一个来自我的服务器的JSON对象

    [
   {
      "id":1,
      "tag":"Cooking",
      "weight":null,
      "deleted_at":null,
      "created_at":null,
      "updated_at":null,
      "listings":[
         {
            "id":5,
            "name":"Learn how to make the perfect hotpot with",
            "slug":"learn-how-to-make-the-perfect-hotpot-with",
            "description":"We live in a unique and wonderful time where electric guitars are things that we can rock on. \n\nIn this lesson, I want to be blown away by what you do. And I can reveal my story. And how I went from a woman who had no idea what she was doing to making sounds and songs that felt that they were very honest to me and pushed boundaries that I didn’t even know existed. And I want to try to be a wind in your sails and a steel in your spine as you’re trying to go from being a good guitar player to not just being a great guitar player, but being someone who really finds themselves in their instrument.\n\nI’d like to teach a class that makes your guitar playing meaningful to you. Whatever it is that you want to do in it. If you want to play exactly like me, well, you’re going to figure that out in this lesson. If you want to play guitar playing that feels exactly like you, hopefully, we will - I’ll reveal the building blocks of how you can do that to create an authentic, artistic self on the electric guitar that’s going to be something that is going to give you a lifetime of awesome rockin’.",
            "booking_details":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.",
            "cost":"25.00",
            "active":1,
            "moderated":1,
            "user_id":3,
            "category_id":null,
            "deleted_at":null,
            "created_at":"2020-06-18T13:41:05.000000Z",
            "updated_at":"2020-06-24T22:50:48.000000Z",
            "tagsList":"Cooking",
            "pivot":{
               "tag_id":1,
               "listing_id":5
            },
            "primary_image":[
               {
                  "id":5,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/learn-how-to-make-the-perfect-hotpot-with/primary-image-lg.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":5,
                  "desktop":1,
                  "mobile":null,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:41:07.000000Z",
                  "updated_at":"2020-06-18T13:41:07.000000Z"
               },
               {
                  "id":6,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/learn-how-to-make-the-perfect-hotpot-with/primary-image-sm.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":5,
                  "desktop":null,
                  "mobile":1,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:41:07.000000Z",
                  "updated_at":"2020-06-18T13:41:07.000000Z"
               }
            ],
            "tags":[
               {
                  "id":1,
                  "tag":"Cooking",
                  "weight":null,
                  "deleted_at":null,
                  "created_at":null,
                  "updated_at":null,
                  "pivot":{
                     "listing_id":5,
                     "tag_id":1
                  }
               }
            ]
         }
      ]
   },
   {
      "id":2,
      "tag":"Fitness",
      "weight":null,
      "deleted_at":null,
      "created_at":null,
      "updated_at":null,
      "listings":[
         {
            "id":6,
            "name":"Bodyweight fitness workouts made",
            "slug":"bodyweight-fitness-workouts-made",
            "description":"We live in a unique and wonderful time where electric guitars are things that we can rock on. \n\nIn this lesson, I want to be blown away by what you do. And I can reveal my story. And how I went from a woman who had no idea what she was doing to making sounds and songs that felt that they were very honest to me and pushed boundaries that I didn’t even know existed. And I want to try to be a wind in your sails and a steel in your spine as you’re trying to go from being a good guitar player to not just being a great guitar player, but being someone who really finds themselves in their instrument.\n\nI’d like to teach a class that makes your guitar playing meaningful to you. Whatever it is that you want to do in it. If you want to play exactly like me, well, you’re going to figure that out in this lesson. If you want to play guitar playing that feels exactly like you, hopefully, we will - I’ll reveal the building blocks of how you can do that to create an authentic, artistic self on the electric guitar that’s going to be something that is going to give you a lifetime of awesome rockin’.",
            "booking_details":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.",
            "cost":"10.00",
            "active":1,
            "moderated":1,
            "user_id":3,
            "category_id":null,
            "deleted_at":null,
            "created_at":"2020-06-18T13:41:49.000000Z",
            "updated_at":"2020-06-18T13:41:49.000000Z",
            "tagsList":"Fitness",
            "pivot":{
               "tag_id":2,
               "listing_id":6
            },
            "primary_image":[
               {
                  "id":7,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/bodyweight-fitness-workouts-made/primary-image-lg.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":6,
                  "desktop":1,
                  "mobile":null,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:41:50.000000Z",
                  "updated_at":"2020-06-18T13:41:50.000000Z"
               },
               {
                  "id":8,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/bodyweight-fitness-workouts-made/primary-image-sm.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":6,
                  "desktop":null,
                  "mobile":1,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:41:50.000000Z",
                  "updated_at":"2020-06-18T13:41:50.000000Z"
               }
            ],
            "tags":[
               {
                  "id":2,
                  "tag":"Fitness",
                  "weight":null,
                  "deleted_at":null,
                  "created_at":null,
                  "updated_at":null,
                  "pivot":{
                     "listing_id":6,
                     "tag_id":2
                  }
               }
            ]
         },
         {
            "id":7,
            "name":"Learn how to use TRX bands with",
            "slug":"learn-how-to-use-trx-bands-with",
            "description":"We live in a unique and wonderful time where electric guitars are things that we can rock on. \n\nIn this lesson, I want to be blown away by what you do. And I can reveal my story. And how I went from a woman who had no idea what she was doing to making sounds and songs that felt that they were very honest to me and pushed boundaries that I didn’t even know existed. And I want to try to be a wind in your sails and a steel in your spine as you’re trying to go from being a good guitar player to not just being a great guitar player, but being someone who really finds themselves in their instrument.\n\nI’d like to teach a class that makes your guitar playing meaningful to you. Whatever it is that you want to do in it. If you want to play exactly like me, well, you’re going to figure that out in this lesson. If you want to play guitar playing that feels exactly like you, hopefully, we will - I’ll reveal the building blocks of how you can do that to create an authentic, artistic self on the electric guitar that’s going to be something that is going to give you a lifetime of awesome rockin’.",
            "booking_details":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.",
            "cost":"10.00",
            "active":1,
            "moderated":1,
            "user_id":3,
            "category_id":null,
            "deleted_at":null,
            "created_at":"2020-06-18T13:42:15.000000Z",
            "updated_at":"2020-06-18T13:42:15.000000Z",
            "tagsList":"Fitness",
            "pivot":{
               "tag_id":2,
               "listing_id":7
            },
            "primary_image":[
               {
                  "id":9,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/learn-how-to-use-trx-bands-with/primary-image-lg.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":7,
                  "desktop":1,
                  "mobile":null,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:42:16.000000Z",
                  "updated_at":"2020-06-18T13:42:16.000000Z"
               },
               {
                  "id":10,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/learn-how-to-use-trx-bands-with/primary-image-sm.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":7,
                  "desktop":null,
                  "mobile":1,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:42:16.000000Z",
                  "updated_at":"2020-06-18T13:42:16.000000Z"
               }
            ],
            "tags":[
               {
                  "id":2,
                  "tag":"Fitness",
                  "weight":null,
                  "deleted_at":null,
                  "created_at":null,
                  "updated_at":null,
                  "pivot":{
                     "listing_id":7,
                     "tag_id":2
                  }
               }
            ]
         }
      ]
   },
   {
      "id":3,
      "tag":"Music",
      "weight":null,
      "deleted_at":null,
      "created_at":null,
      "updated_at":null,
      "listings":[
         {
            "id":3,
            "name":"Learn the basics of the guitar  from the anatomy of the  guitar to scales, chords",
            "slug":"learn-the-basics-of-the-guitar-from-the-anatomy-of-the-guitar-to-scales-chords",
            "description":"We live in a unique and wonderful time where electric guitars are things that we can rock on. \n\nIn this lesson, I want to be blown away by what you do. And I can reveal my story. And how I went from a woman who had no idea what she was doing to making sounds and songs that felt that they were very honest to me and pushed boundaries that I didn’t even know existed. And I want to try to be a wind in your sails and a steel in your spine as you’re trying to go from being a good guitar player to not just being a great guitar player, but being someone who really finds themselves in their instrument.\n\nI’d like to teach a class that makes your guitar playing meaningful to you. Whatever it is that you want to do in it. If you want to play exactly like me, well, you’re going to figure that out in this lesson. If you want to play guitar playing that feels exactly like you, hopefully, we will - I’ll reveal the building blocks of how you can do that to create an authentic, artistic self on the electric guitar that’s going to be something that is going to give you a lifetime of awesome rockin’.",
            "booking_details":"undefined",
            "cost":"25.00",
            "active":1,
            "moderated":1,
            "user_id":3,
            "category_id":null,
            "deleted_at":null,
            "created_at":"2020-06-18T13:27:35.000000Z",
            "updated_at":"2020-06-24T10:41:46.000000Z",
            "tagsList":"Music",
            "pivot":{
               "tag_id":3,
               "listing_id":3
            },
            "primary_image":[
               {
                  "id":1,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/learn-the-basics-of-the-guitar-from-the-anatomy-of-the-guitar-to-scales-chords/primary-image-lg.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":3,
                  "desktop":1,
                  "mobile":null,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:27:36.000000Z",
                  "updated_at":"2020-06-18T13:27:36.000000Z"
               },
               {
                  "id":2,
                  "type":"image",
                  "url":"https://at-home-club-1.s3.eu-west-2.amazonaws.com/learn-the-basics-of-the-guitar-from-the-anatomy-of-the-guitar-to-scales-chords/primary-image-sm.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":3,
                  "desktop":null,
                  "mobile":1,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:27:37.000000Z",
                  "updated_at":"2020-06-18T13:27:37.000000Z"
               }
            ],
            "tags":[
               {
                  "id":3,
                  "tag":"Music",
                  "weight":null,
                  "deleted_at":null,
                  "created_at":null,
                  "updated_at":null,
                  "pivot":{
                     "listing_id":3,
                     "tag_id":3
                  }
               }
            ]
         },
         {
            "id":8,
            "name":"Advanced guitar skills with William Topa",
            "slug":"advanced-guitar-skills-with-william-topa",
            "description":"We live in a unique and wonderful time where electric guitars are things that we can rock on. \n\nIn this lesson, I want to be blown away by what you do. And I can reveal my story. And how I went from a woman who had no idea what she was doing to making sounds and songs that felt that they were very honest to me and pushed boundaries that I didn’t even know existed. And I want to try to be a wind in your sails and a steel in your spine as you’re trying to go from being a good guitar player to not just being a great guitar player, but being someone who really finds themselves in their instrument.\n\nI’d like to teach a class that makes your guitar playing meaningful to you. Whatever it is that you want to do in it. If you want to play exactly like me, well, you’re going to figure that out in this lesson. If you want to play guitar playing that feels exactly like you, hopefully, we will - I’ll reveal the building blocks of how you can do that to create an authentic, artistic self on the electric guitar that’s going to be something that is going to give you a lifetime of awesome rockin’.",
            "booking_details":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.",
            "cost":"0.00",
            "active":1,
            "moderated":1,
            "user_id":3,
            "category_id":null,
            "deleted_at":null,
            "created_at":"2020-06-18T13:42:44.000000Z",
            "updated_at":"2020-06-18T13:42:44.000000Z",
            "tagsList":"Music",
            "pivot":{
               "tag_id":3,
               "listing_id":8
            },
            "primary_image":[
               {
                  "id":11,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/advanced-guitar-skills-with-william-topa/primary-image-lg.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":8,
                  "desktop":1,
                  "mobile":null,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:42:45.000000Z",
                  "updated_at":"2020-06-18T13:42:45.000000Z"
               },
               {
                  "id":12,
                  "type":"image",
                  "url":"https://at-home-club-1.s3.eu-west-2.amazonaws.com/advanced-guitar-skills-with-william-topa/primary-image-sm.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":8,
                  "desktop":null,
                  "mobile":1,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:42:46.000000Z",
                  "updated_at":"2020-06-18T13:42:46.000000Z"
               }
            ],
            "tags":[
               {
                  "id":3,
                  "tag":"Music",
                  "weight":null,
                  "deleted_at":null,
                  "created_at":null,
                  "updated_at":null,
                  "pivot":{
                     "listing_id":8,
                     "tag_id":3
                  }
               }
            ]
         },
         {
            "id":9,
            "name":"Music production simplified",
            "slug":"music-production-simplified",
            "description":"We live in a unique and wonderful time where electric guitars are things that we can rock on. \n\nIn this lesson, I want to be blown away by what you do. And I can reveal my story. And how I went from a woman who had no idea what she was doing to making sounds and songs that felt that they were very honest to me and pushed boundaries that I didn’t even know existed. And I want to try to be a wind in your sails and a steel in your spine as you’re trying to go from being a good guitar player to not just being a great guitar player, but being someone who really finds themselves in their instrument.\n\nI’d like to teach a class that makes your guitar playing meaningful to you. Whatever it is that you want to do in it. If you want to play exactly like me, well, you’re going to figure that out in this lesson. If you want to play guitar playing that feels exactly like you, hopefully, we will - I’ll reveal the building blocks of how you can do that to create an authentic, artistic self on the electric guitar that’s going to be something that is going to give you a lifetime of awesome rockin’.",
            "booking_details":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.",
            "cost":"10.00",
            "active":1,
            "moderated":1,
            "user_id":3,
            "category_id":null,
            "deleted_at":null,
            "created_at":"2020-06-18T13:43:15.000000Z",
            "updated_at":"2020-06-18T13:43:15.000000Z",
            "tagsList":"Music",
            "pivot":{
               "tag_id":3,
               "listing_id":9
            },
            "primary_image":[
               {
                  "id":13,
                  "type":"image",
                  "url":"https://xxxxxxx.s3.eu-west-2.amazonaws.com/music-production-simplified/primary-image-lg.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":9,
                  "desktop":1,
                  "mobile":null,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:43:16.000000Z",
                  "updated_at":"2020-06-18T13:43:16.000000Z"
               },
               {
                  "id":14,
                  "type":"image",
                  "url":"https://at-home-club-1.s3.eu-west-2.amazonaws.com/music-production-simplified/primary-image-sm.jpg",
                  "is_primary":1,
                  "assetable_type":"App\\Listing",
                  "assetable_id":9,
                  "desktop":null,
                  "mobile":1,
                  "user_id":3,
                  "deleted_at":null,
                  "created_at":"2020-06-18T13:43:16.000000Z",
                  "updated_at":"2020-06-18T13:43:16.000000Z"
               }
            ],
            "tags":[
               {
                  "id":3,
                  "tag":"Music",
                  "weight":null,
                  "deleted_at":null,
                  "created_at":null,
                  "updated_at":null,
                  "pivot":{
                     "listing_id":9,
                     "tag_id":3
                  }
               }
            ]
         }
      ]
   }
]
正如您所看到的,每个对象都有listings数组,其中有许多对象,每个对象都有一个price属性,我想过滤掉任何价格不为“0.00”的列表对象,这样我就可以只显示那些价格为“0.00”但我的尝试无效的列表对象,我想知道这是不是因为我得从几件东西上下来

这是我的尝试

filteredListings() {
            return this.tags.filter((listings) => {
                return listings.filter((l) => {
                    console.log(l.cost);
                })

            })
        }

这里的一些帮助将是非常棒的。

这是我的尝试,我使用了
map
并在其中应用了
过滤器。让我知道这是否解决了您的问题:

givenArray.map(({listings, ...rest})=>{
    listings = listings.filter(p=>Number(p.cost)!==0);
    return {...rest, listings};
});

这是我的尝试,我使用了
map
并在其中应用了
filter
。让我知道这是否解决了您的问题:

givenArray.map(({listings, ...rest})=>{
    listings = listings.filter(p=>Number(p.cost)!==0);
    return {...rest, listings};
});
试试这个:

filteredTags() {
    return this.tags.map({ listings, ...rest } => 
        ({ ...rest, listings: listings.filter(listing => listing.cost === '0.00' })
    )
}
说明: 您试图做的是过滤标签,而您想过滤标签中的列表。因此,您必须首先映射标记并过滤每个标记中的列表。

尝试以下操作:

filteredTags() {
    return this.tags.map({ listings, ...rest } => 
        ({ ...rest, listings: listings.filter(listing => listing.cost === '0.00' })
    )
}
说明:
您试图做的是过滤标签,而您想过滤标签中的列表。因此,您必须首先映射标签并过滤每个标签中的列表。

这太棒了,谢谢。是否可以通过&&或| | |对多个元素运行检查?当然,您只需在过滤器中添加
listing.cost==“0.00”| | listing.name==“test”
。这太棒了,谢谢。是否可以通过&&或| |对多个元素运行检查?当然,您只需在筛选器中添加
listing.cost==“0.00”| | listing.name==“test”