0

0

react遇到的问题的有哪些?react的问题总结

寻∝梦

寻∝梦

发布时间:2018-09-11 14:49:40

|

2895人浏览过

|

来源于php中文网

原创

本篇文章主要讲述的是关于react的应用,还有一些问题的原因总结。现在让我们一起来看看这篇文章吧

   react项目中的遇到的问题:

1、新建了一个子组件,插入到父组件中,子组件渲染出的结果为以子组件命名的XML标签,而不是子组件中render方法的return结果。

    在正常情况下,子组件渲染出的结果为,子组件中render方法的return结果,即p标签。

    问题原因:react组件的命名规则,首字母必须大写。

    React的JSX语法使用大、小写的约定来区分本地组件的类和 HTML 标签。但注意两点:JSX语法中,HTML标签和组件标签的class和for属性必须使用className和htmlFor来做对应的属性。

2、react构建的应用,input元素和textarea元素的值如何取到,如何实时更新到元素的属性(value)中。

    如果像HTML页面那样不做任何处理,去向这两个元素写入数据,然后通过$(input).val();或this.refs.input01.value;两种方法去读取(拿)数据,结果为空。

    因为肉眼看到input元素和textarea元素已经键入内容,但是react中的元素属性(value)并没有实时更新,需要对input元素和textarea元素做特殊处理。如下:

     
        emailChange(event){                this.setState({email: event.target.value})        }

    在元素上需要绑定onChange事件,然后通过event.target.value方法获取到值,再更新组件状态state,组件状态改变,组件会重新渲染调用render方法,元素通过value={this.state.email}更新value属性,即可取到数据。

   this.state.email || $(input).val() || this.refs.input.value,取数据没有区别,但是写入数据有区别:

        写入不可见数据,可以用this.refs.input.value="sometext",或,$(input).val("sometext"),通过refs属性操作元素,不调用render方法,不重新渲染页面;

        写入可见数据必须用react的状态属性state控制:


    this.setState({email: event.target.value})

3、写好了一个页面,渲染出空页面,没有任何结果。

    问题原因:组件中render方法返回值的编码规范,return关键字的同一行必须有代码,或者为左p,或者为左括号。(相关问题:有一次另一个问题报错,官网解释,rerun返回值不能为花括号{}包围的变量,编码规范为,最外层必须为XML标签,并且只能有一个,不能有兄弟XML标签)

4、父子组件传递参数

    情景一:父组件A需要向子组件B传递参数

        父组件调用子组件B的时候,在元素上加入需要传递的参数,同时,在B组件的props属性中声明并初始化相同名称的属性this.props.isdisplay

        子组件B本身封装(暴露)了很多props属性,在父组件A调用B时,可以直接向相应的props属性传入数据。

    情景二:父组件A需要向孙子组件C传递参数,中间有子组件B存在,B调用了C组件

        A调用C的时候,需要传入属性isdisplay,此时需要在B组件的props属性中声明并初始化isdisplay属性,同时在B组件调用C组件时,在C组件的属性中传入isdisplay属性。

5、写好一个组件页面,浏览器没有渲染出任何结果,显示空白页面。

    问题原因:react的render方法语法格式错误

        render(){}方法中的return返回内容格式要求,和return同一行必须有内容,并且返回的标签元素最外层只能有一个元素,形如:

return (

...

eclipse搭建SSH框架详解 中文WORD版
eclipse搭建SSH框架详解 中文WORD版

SSH框架是最常用的框架之一,在搭建SSH框架的时候总有人遇到这样,那样的问题。本文档将介绍一下SSH框架搭建的全过程。有需要的朋友可以下载看看

下载
) retuern

...

6、组件的setState方法,传入参数详解,什么时候需要用回调函数?

    this.setStete({},()=>{});//组件状态量,回调函数

    如下情况,由于setStete方法是异步执行,所以直接在setStete方法后取重置的state状态量,有可能取到的是重置之前的值,因此需要用到回调函数,保证了state状态量重置成功后再取值,肯定取到的是重置后的值。(想看更多就到PHP中文网React参考手册栏目中学习)

this.setState({    pageNum: this.state.pageNum + 1});
console.log(pageNum);//pageNum || pageNum + 1

    改造如下:

this.setState({
pageNum: this.state.pageNum + 1
},()=>{
console.log(
pageNum
);
});

    总结:回调函数存在的功能,异步方法执行成功后再执行回调函数内容,即“异步方法同步化”。

7、组件状态量的初始化两种方法:

    ES6语法中,可以在constructor方法中初始化,如下:

constructor(super){
    props(super);
    this.state({
        name: "nickname",
    });
}

    react原生语法如下:

getInitialState() {    return {
        name: "nickname",
    };}

8、react组件的结构与数据和逻辑无关

    选用react框架搭建的web应用,最高效的事情就是,组件可以一次封装,多次调用,也就是说开发的所有组件都是可复用高复用度组件。

    因此,需要理清一个思路,数据与逻辑和组件结构无关,对于具体需求的页面,可以用多个组件拼装而成,每个组件没有具体的数据和逻辑,页面的数据和逻辑在所有组件布局成功之后再添加。

9、对于list页面的路由配置

    场景:比如员工信息列表,每一项对应一个人的详情页面,详情页面的布局完全相同

    这种情况下需要用到react-router的路由参数功能,在路由配置的时候,增加一条参数配置

path: 'employee'//列表页路由配置
path: 'detail/:employeeId'//详情页路由配置,path 属性中的 :employeeId就是该路由的参数params

employeeId}>//列表每项跳转路径
this.props.params.employeeId;//详情页路由具体实现,React Router 将路由的数据都通过 props传递给了页面组件,从而可以访问路由相关数据了。

10、遇到Maximum call stack size exceeded栈溢出问题总结

    案例一:语法逻辑错误

11、组件状态变量个数的控制:由已经定义的state经过运算得到的值不能再定义为state变量

本篇文章到这就结束了(想看更多就到PHP中文网React使用手册栏目中学习),有问题的可以在下方留言提问。

相关专题

更多
Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

37

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

37

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

9

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

golang socket 编程
golang socket 编程

共2课时 | 0.1万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号