首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法将target.value传递给状态钩子返回未定义的- React.js反应

无法将target.value传递给状态钩子返回未定义的- React.js反应
EN

Stack Overflow用户
提问于 2021-12-25 10:44:28
回答 1查看 309关注 0票数 1

单击时,我希望将名称支柱传递给状态钩子,但它返回未定义的

代码语言:javascript
复制
    const [fav, setFav ] = useState([]); 
    
         useEffect(() => {
        dispatch(fetchProfileAction(user));
        dispatch(fetchReposAction(user));
      }, [user, dispatch]);
    
            {reposList?.name !== "Error" &&
          reposList?.map(repo => (
            <>
                <div className="col-6 g-3 ">
                <div className="border rounded-pill px-3 py-2 bg-secondary  ">
                <i 
                class="far fa-star pe-2" role={ 'button'}
                name={repo?.name} role={'button'}
                onClick={e => setFav(...fav, e.target.name)}
                ></i> 
                <a
                    target="_blank"
                    href={repo?.html_url}
                    className="text-light"
                    name={repo?.name} role={'button'}
                    onClick={e => setFav(...fav, e.target.name)}
                  >
                    {repo?.name} 
                  </a>
                  <strong className="text-light ps-2">({repo?.language})</strong>
              </div>
            </div>
                  
                
            </>
          ))}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-25 11:30:59

根据https://docs.w3cub.com/dom/element/name,名称正式只适用于以下元素:<a>, <applet>, <button>, <form>, <frame>, <iframe>, <img>, <input>, <map>, <meta>, <object>, <param>, <select>, and <textarea>

因此,既然您在i标记上使用了name属性,您应该尝试通过getAtrribute获取名称值,如下所示:

代码语言:javascript
复制
 <i 
   class="far fa-star pe-2" role={ 'button'}
   name={repo?.name}
   role={'button'}
   onClick={e => setFav( [...fav, e.target.getAttribute('name')] )}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70479471

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档