今天写一个组件,遇到了一个很常见的骚操作的,就是这样的模式,父组件的一个子组件,它是下拉菜单,里面是一个数组遍历制作出来的li元素,[a,b,c,d]数组遍历的时候,li上面加上点击事件,onChange,它这里,我的需求是,,,先等一下,
数组遍历时,map里的主函数的自变量命名为key,我在这里,要的就是把key就是指代abcd么,对吧!onchange里,一个箭头函数,函数内,首先判断key是不是等于cd那两个值,那两个值要被过滤掉,不能加手动输入操作来改变state的,而key是ab的话,声明了一个obj,obj[key]等于e.target.value,再setState(obj),就是这样的逻辑了。如果没有过滤的代码,其实我是可以直接在onChange里写的,很简单的代码的,但是有了的话,写那里就不好看了哦!这部分代码抽离出来,变成组件的一个函数w
所以那里我需要写个箭头函数,返回this.w就可以了吧,,,结果出问题了哦!因为我需要传参数,这里的参数有两个一个是e一个是key。
我当时,明白key必须要让w运行时,从词法作用域那里出发,才对的,e是onChange本身回调函数默认的第一个参数,这个很容易的!当时,我其实是蒙了的,虽然有key的出处的感的,但是,onChange={ }里,我要如何写了,,,
我试