学习笔记:关于对象属性获取问题

关于对象属性获取问题

在前端开发的过程中,学到一个新知识点,直接上代码:

Html:
                <form onSubmit={this.handleSubmit}>
                    <select value={this.state.optionValue} onChange={this.handleSelect}>
                        <option value="xy">西柚</option>
                        <option value="pt">葡萄</option>
                        <option value="mg">芒果</option>
                        <option value="yz">椰子</option>
                        <option value="xc">香橙</option>
                    </select>
                    <input type="submit" />
                </form>


   JS:
   
    handleSubmit(event) {
        console.log('you choose:', this.handleOutput(this.state.optionValue));
        event.preventDefault();
    };

    handleOutput(param) {
        const arrOption = {
            xy: '西柚',
            pt: '葡萄',
            mg: '芒果',
            yz: '椰子',
            xc: '香橙',
        };
        return arrOption.param
        // log: Undefined
    }

select调用handleSubmit方法吧value值传递过去,控制台打印出的是Undefined,eslin提示我param是未使用的。看了一下才发现,这里的arrOption.param找的是arrOption里的param属性,而其实这个对象里是没有这个属性的,所以才出现Undefined。它并没有管param的形参。
解决的方法也很简单,使用es6的方法:

		// 将 return arrOption.param改为:
        return arrOption[param]

这样控制台就能打印出内容了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值