来源:web前端开发
React 是一个目前流行的前端框架之一,可以帮助我们高效地构建用户界面。
但是在使用React进行开发时,我们却不能正确使用&&,很容易导致UI错误。
因此,我们需要知道,&&运算符导致的React UI界面错误。
(相关资料图)
如何工作?我们应该用什么代替&&?
1.&&运算符导致的React UI界面错误我经常需要编写需要从服务器端获取数据的页面,这些数据用于呈现列表。如果数据的长度为0,则不应显示。
const App = () => { const [list, setList] = React.useState([]); const fetchList = () => { // Simulate fetching data from the server via setTimeout setTimeout(() => { setList([]) }, 1000) } React.useEffect(() => { fetchList() }, []) return ( list.length && ( {list.map((name) => { return {name}; })} ) );};ReactDOM.render( , document.getElementById("app"))
眼见为实,我的朋友们,所以请点击此Codepen的链接进行查看。
地址:https://codepen.io/qianlong/pen/BarvKbW?editors=1010
你会注意到,当 list 是一个空数组时,页面将呈现 0 而不是什么都没有。
我的天哪,这到底是怎么回事?
2.&& 是如何工作的?这是一个 React 错误吗?值得庆幸的是,这个问题的原因不是因为 React 犯了错误,而是与 Javascript 本身的工作方式有关。
来自 MDN的解释:当且仅当所有操作数都为真时,一组布尔操作数的逻辑与 (&&) 运算符(逻辑合取)才为真。否则就是假的。
一般运算符返回从左到右计算时遇到的第一个假操作数的值,或者如果它们都是真值,则返回最后一个操作数的值。
让我们学习一个非常简单的例子,我想你会很快理解的。
const a = 0const b = "React"const c = 1const d = "Javascript"console.log(a && b) // 0console.log(c && d) // Javascript
当你在代码中使用a && b时,如果a为0,则直接返回,不再计算b的值。
你一定明白为什么上面的 React 例子显示 0 了。
3.我们应该用什么来代替&&?&& 运算符很容易出错,我们是否应该放弃使用它呢?
不,我们不应该那样做。我们可以尝试这3种方式来避免这个问题。
3.1 使用!!list.length我们可以把数组的长度转成布尔值,就不会再出现这个错误了。
// 1. Convert list.length to boolean!!list.length &&
3.2 使用 list.length >= 1和上面的原理一样,我们用另一种方式将其转为布尔值。
// 2. Controlled by specific logiclist.length >= 1 && ;
3.3 使用三元表达式如果您的应用程序不是特别复杂并且仅使用 1 或 2 个三元表达式即可解决,我会推荐它。
// 3. Use ternary expressions and nulllist.length ? : null;
结尾以上这就是这篇文章的全部内容!如果你觉得有用的话,请点赞我,关注我,你将会阅读到更多的优质文章。
最后,感谢你的阅读。
关键词:
拜仁关注拉比奥?记者:他和图赫尔在巴黎共事时存在问题 环球短讯
据德国天空体育记者普莱腾贝格的消息,拉比奥和图赫尔在巴黎时期存在问题。据此前媒体报道称,拜仁正在关注
怀特:我们会为了赢球拼尽一切 只要能赢做什么都行|世界短讯
怀特:我们会为了赢球拼尽一切只要能赢做什么都行,热火队,德里克,科学家,法学家,拜伦·怀特,美国政治人物,
世界速递!曹德旺拒绝在藏区投资,宗庆后嘲讽其“太小气” 曹德旺一句话让宗庆后颜面扫地
在一档电视节目中,主持人向曹德旺提出了一个问题:“作为一位成功的企业家,您是否愿意在藏区投资1 5亿?
即时看!合力营造杜绝粮食浪费环境
一段时间以来,宣称提供海量美食,成为不少自助餐厅的营销方式。但同时很多人也注意到,大部分餐厅并没有对
5月24至25日库尔勒市四价、九价疫苗预约公告 焦点速读
为满足群众健康需求,我中心定于2023年5月24-25日进行四价、九价HPV疫苗网上预约,为便于本市群众了解疫苗
关于我们 加入我们 联系我们 商务合作 粤ICP备18023326号-32
中国创氪网 www.chuanganwang.cn 版权所有
投稿投诉联系邮箱:85 572 98@qq.com