RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1028934
Accepted
F. Tomas
F. Tomas
Asked:2020-09-28 19:28:40 +0000 UTC2020-09-28 19:28:40 +0000 UTC 2020-09-28 19:28:40 +0000 UTC

Vue:getter 无法与 vuex 中的 find 一起使用

  • 772

大家好,刚刚在vue中练习。我在 vuex 中遇到了 getter 的一种奇怪行为——如果将 find 方法应用于其中的数组,代码将无法工作。

所以这是我来自 Vuex 的 products.js 模块:

export default {
  namespaced: true,
  state: {
    items: getProducts()
  },
  getters: {
    items(state){
      return state.items;
    },

    mapProducts(state){
      let mapArr = [];

      for(let i = 0; i < state.items.length; i++){
        mapArr[state.items[i].id_product] = state.items[i];
      }
      return mapArr;
    },

    get_product_by_id: (state, getters) => (id) => {
      return getters.items.find((elem) => {
        return elem.id_product === id;
      })
    },

    item: (state, getters) => (id) => {
      return getters.mapProducts[id];
    }
  }
}

function getProducts(){
  return [
    {
      id_product: 14,
      name: "Xiaomi Mi 9T Pro",
      desc: "Android, экран 6.39\" AMOLED (1080x2340), Qualcomm Snapdragon 855, ОЗУ 6 ГБ, флэш-память 128 ГБ, камера 48 Мп, аккумулятор 4000 мАч, 2 SIM",
      price: 520,
      img: require('../../assets/img/id14.jpg')

    },
    {
      id_product: 17,
      name: "HONOR 20",
      desc: "Android, экран 6.26\" IPS (1080x2340), HiSilicon Kirin 980, ОЗУ 6 ГБ, флэш-память 128 ГБ, камера 48 Мп, аккумулятор 3750 мАч, 2 SIM",
      img: require('../../assets/img/id17.jpeg'),
      price: 350
    }
  ]
}

这是我的 Product.vue 组件,我试图通过其 id 获取产品对象:

<template>
<div>
  <h1>{{ get_product }} - {{ get_product_id }}</h1>
</div>
</template>

<script>
  import {mapGetters} from 'vuex';

    export default {
        name: "Product",
        data() {
            return { }
        },
        computed: {
            ...mapGetters("products", {
                get_product_by_id: "get_product_by_id",
                item: "item"
            }),
            get_product_id(){
                return this.$route.params.id;
            },
            get_product(){
                console.log(this.get_product_by_id(this.get_product_id)); // В консоли undefined
                return this.get_product_by_id(this.get_product_id); // Не работает и все тут
                //return this.get_product_by_id(19); // Так работает!!!
                //return this.item(this.get_product_id); // Так тоже работает!!!
            }

        },
        methods: { }
    }
</script>

正如您从评论中看到的那样,在计算中,在 get_product 方法中,行

return this.get_product_by_id(this.get_product_id);

断然拒绝工作,当您尝试将结果输出到控制台时,它会写入未定义。

但是,如果您致电:

return this.get_product_by_id(19);

然后我成功获得了产品对象。还成功返回我一个产品对象调用:

return this.item(this.get_product_id);

解释调用问题

return this.get_product_by_id(this.get_product_id);

为什么应该工作的时候却不工作!!!

javascript
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Алексей
    2020-09-29T19:15:22Z2020-09-29T19:15:22Z

    问题是从查询字符串中, id 路由参数以字符串形式出现。这可以通过在 id 和输出到 console.log() 之前添加 typeof 运算符来检查 - 我们得到一个字符串。而 this.get_product_by_id() 方法需要 id 作为数字。该问题可以通过将 id 转换为数字来解决,如下所示:

    return parseInt(this.$route.params.id);
    
    • 2

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    根据浏览器窗口的大小调整背景图案的大小

    • 2 个回答
  • Marko Smith

    理解for循环的执行逻辑

    • 1 个回答
  • Marko Smith

    复制动态数组时出错(C++)

    • 1 个回答
  • Marko Smith

    Or and If,elif,else 构造[重复]

    • 1 个回答
  • Marko Smith

    如何构建支持 x64 的 APK

    • 1 个回答
  • Marko Smith

    如何使按钮的输入宽度?

    • 2 个回答
  • Marko Smith

    如何显示对象变量的名称?

    • 3 个回答
  • Marko Smith

    如何循环一个函数?

    • 1 个回答
  • Marko Smith

    LOWORD 宏有什么作用?

    • 2 个回答
  • Marko Smith

    从字符串的开头删除直到并包括一个字符

    • 2 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5