请勿执行的操作以及如何解决的方法,这部分内容是针对React的新手开发人员提供的。
创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都做网站、网站建设、外贸营销网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的周至网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
1. 忘记大写React组件
考虑一下这段代码,它创建一个简单的div,其中包含父组件的标题。里面有一个子组件,其中包含带有一些文本的div。
- class childComponent extends React.Component {
- render() {
- return (
Child Component
- );
- }
- }
- class ParentComponent extends React.Component {
- render() {
- return (
Parent Component
- );
- }
- }
- export default ParentComponent;
您认为代码运行时会出现什么?
childComponent 未渲染。它去哪儿了?代码编译成功,终端也没有错误。
再次查看子组件的代码。注意组件的名称,你注意到什么不同了吗?
在浏览器中打开控制台,浏览器控制台警告的大小写不正确
事实证明,React将小写组件视为DOM标记。如果你是React的新手,你可能已经错过了React文档中的这个小细节。
如果不了解这一点,初学者常常会陷入这样的困惑:即他们的代码编译没有任何错误,到底哪里出了问题?
解决方法很简单,大写您的组件。
2. 错误地调用收到的props
要访问由父组件传入的prop,子组件必须确保它们调用了正确的prop名称。
还可以使用另一个变量名将Props传递给子组件。考虑以下代码片段:
- class ChildComponent extends React.Component {
- render() {
- const { randomString } = this.props;
- return (
{randomString}
- );
- }
- }
- class ParentComponent extends React.Component {
- render() {
- const randomString = 'lorem ipsum';
- return (
Parent Component
- );
- }
- }
尽管此代码可以编译并运行无误,但 ChildComponent内不会渲染任何文本。
仔细看看这一行代码,在 ParentComponent 中声明的变量 randomString 作为名为 mainText 的prop传递给 ChildComponent。
然而,ChildComponent 试图从它收到的prop中访问 randomString。由于它仅接收 mainText 作为prop,因此将导致未定义的值分配给在 ChildComponent 中声明的 randomString。结果,其
标记内未呈现任何内容。
注意哪些prop被传递到您的组件中,并相应地访问它们。这将在调试期间为您节省一些不必要的麻烦。
3. 传递不正确的Props类型
如果所接收的prop不是预期的类型,那么依赖于这些接收prop的组件可能会有不同的行为。
- class ChildComponent extends React.Component {
- render() {
- const { showIntro, showBody } = this.props;
- return (
- {showIntro &&
Hello!
}- {showBody &&
Spot the mistake!
}- );
- }
- }
考虑这个有两个prop的 ChildComponent:showIntro 和 showBody。它显示“你好!和“发现错误!”只有当showIntro 和 showBody 分别设置为 true 时才会这样。
ChildComponent 希望将两个布尔值作为prop传递。如果在父组件中执行类似的操作,会发生什么情况?
在prop中使用了不同的引号和大括号。但是,它们的行为将不同。看看这个:
前两个 ChildComponent 都渲染了两个
标记,而最后一个 ChildComponent 没有渲染。
作为prop传递的 'false' 和 {'false'} 会导致无意中为 showIntro 和 showBody 分配了一个值为 false 的字符串,而不是布尔值 false。
对于前两个 ChildComponent,将 showIntro 和 showBody 都计算为 true。
这是由于 && 运算符的隐式强制类型转换。当 && 运算符检查 showIntro 或 showBody(均为字符串)时,两个字符串都将强制为 true。
最后一个 ChildComponent 接收到布尔值 false,因此它没有正确渲染任何内容。
- console.log(`showIntro type: ${typeof showIntro}`);
- console.log(`showIntro evaluated to: ${showIntro && true}`);
- console.log(`showBody type: ${typeof showBody}`);
- console.log(`showBody evaluated to: ${showBody && true}`);
为了确认这一点,我们运行 console.log() 来检查每个 ChildComponent 中prop的运行结果。
正如这里所演示的,初学者在将prop传递给其他组件时能够区分使用引号和花括号之间的区别是非常重要的。
您可以使用引号来传递字符串文字。
// passing in a String
花括号用于传递JavaScript表达式。
// passing in a Number // passing in a Boolean
以下是Reac文档中的一些注意事项:
将JavaScript表达式嵌入属性中时,请勿在大括号周围加上引号。您应该使用引号(用于字符串值)或大括号(用于表达式),但不要在同一属性中都使用引号。 |
4. 在render()内部调用setState()
下图无限循环错误消息
尽管您的组件中没有 componentWillUpdate() 或 componentWillUpdate(),您仍可能遇到此错误。当您在 render() 函数中调用 setState() 时也会发生此错误。
为什么会这样?每次调用 setState() 时,React将通过调用 render() 重新渲染。您的 render() 函数内部是什么?setState()。你看到结果了吗?一个无限循环。
只需将 setState() 调用移到 render() 函数之外即可。
如果在组件挂载后必须初始化状态(也许是从API端点提取数据),请在 componentDidMoun() 中进行。
如果可以在组件挂载之前初始化状态,也可以使用构造函数来完成。
5. setState()的异步性
在调试时,通常使用 console.log() 打印值。但是,当代码异步运行时,这不能很好地工作。
- handleCounterIncrement = () => {
- const { counter } = this.state;
- console.log(`Before update: ${counter}`);
- this.setState({ counter: counter + 1 });
- console.log(`After update: ${counter}`);
- };
你以前试过这样做吗?坏消息——setState() 调用是异步的。不能保证给定的代码将按顺序执行。它可能导致如下输出:
在执行 setState() 之前执行了两个 console.log() 调用。因此,它两次打印前一个状态的值。
如果希望在调用 setState() 之前和之后检查状态的值,请在 setState() 中将回调作为第二个参数传递。
- handleCounterIncrement = () => {
- const { counter } = this.state;
- console.log(`before update: ${counter}`);
- this.setState({ counter: counter + 1 }, () => {
- console.log(`after update: ${this.state.counter}`);
- });
- };
回调将在 setState() 完成后执行,从而为 console.log() 提供同步行为。
标题名称:新手React开发人员容易做错的5件事
网站地址:http://www.shufengxianlan.com/qtweb/news36/62636.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联