React入门学习笔记

React 基础 组件

1.创建的类需要在别的类中使用,则建立的时候需要添加export default ,另外return里面只能有一个节点,下图就是一个简单的组件

组件的创建

2.使用时以标签的形式使用,并以导包的方式引入进来即可(组件的使用)

组件的使用

3.组件也可以通过参数的方式传递使用

以参数的方式传递

4.同样的,react中也可以使用三目表达式

三目表达式

5.组件中参数传递不在需要单引号,直接{}就可以

参数传递

5.组件中注释,当使用 “//注释”时html上也会显示这个注释内容,但页面上并不会显示,当使用“{/* 注释 */}”注释时,html和页面都不会显示这个注释。

6.组件的生命周期

React生命周期

componentWillMount():页面将要加载之前会先走这个函数,可以在这个函数里面加载一些页面的数据,以及实现一些逻辑等等。

componentDidMount():页面加载之后会走这个函数。


React属性与事件

1.constructor构造方法: 

            在一个类中只能有一个名为 “constructor” 的特殊方法。 一个类中出现多次构造函数 (constructor)方法将会抛出一个 SyntaxError 错误。在一个构造方法中可以使用super关键字来调用一个父类的构造方法。如果没有显式指定构造方法,则会添加默认的 constructor 方法。如果不指定一个构造函数(constructor)方法, 则使用一个默认的构造函数(constructor)。

constructor解释

React中使用constructor构造方法更改 state 的时候会立即引起值得变更,但不会刷新整个页面,效率非常的高,而且不会影响其他组件的state的值,只影响本身。state对于模块来说属于自身的属性。

4秒之后更改页面的值,会刷新页面,但是不会刷新整个页面的值,只会恒爱state中的值

2.React之props属性:组件之间进行传值,对于模块属于外来的属性

向BodyIndex中传值
BodyIndex中使用props接受值

3.事件与数据的双向绑定

     事件的绑定

    点击"提交"按钮之后年龄会由原来20,改为50

点击更改年龄

当然也可以在绑定的时候传一个值过去,这样点击"提交"按钮之后年龄会由原来的20变为99

点击传值


子页面向父页面传递参数的方法

在子页面中通过调用父页面传过来的事件 props 进行组件的参数传递,通过onChange获取子页面输入的值,父组件中绑定并接受子组件传过来的值,并更改父组件中的值。

时随着输入框的输入值实时触发 onChange 事件,从而实时更新 p 中的值

子类组件
父类组件

4.可复用组件

当父组件给子组件传的值不是一个数字时,则会报错,子组件中添加了一个约束,使子组件只接收所有父组件传过来的数字类型,其他都不接收。

父组件
子组件中规定userid的类型为数字类型  

如果number后面加一个 ".isRequired "则父组件引用子组件必须要传这个参数,如果添加上

"BodyIndex.defaultProps = defaultProps; "这个约束,那么当父组件没有传username这个值时则会给他一个默认值,就是上图中的 defaultProps。

如果说父传子属性 子在传子属性 书写方法 "{...this.props} id={4}","...this.props"是拿到所有的参数,"id={4}"是又另外传了一个值过去。


5.组件的refs

当使用ref时,使用 this.refs.submitButton.style.color = 'red' 可以直接更改input中的颜色

ref

Refs 是访问到组件内部 DOM 节点唯一可靠的方法

Refs 会自动摧毁对子组件的引用

不要在 render 或 render 之前对 Refs 进行调用

不要滥用 Refs


React 样式

1.内联样式

其中的header只会影响本类,不会对其他的类进行污染

样式需要使用驼峰写法属性也是需要引起来,如果样式要使用html中的则也需要用引号引起来

注意标签中给他一个class属性需要改为className否则会与react中的class冲突

缺点是动画、伪类(hover)等不能使用

内联样式

2.内联样式中的表达式

当前 padding-top 和 paddingBottom 的高度为15px,当触发了点击事件之后会给minHeader的值取反,这样他们的值为3px,样式会实时更改,不用刷新页面

实时改变样式

3.CSS 模块化

css文件可以以require的方式导入进来,在下面直引用即可

这里可以使用 class 是因为使用了一个插件 "babel-plugin-react-html-attrs"

footer.css只会影响引入的类,不会影响其他的类

使用的插件
css模块化



React Router 路由

1.Router 基础

首先需要引入路由,并把程序的入口改为<Root/>

其中的 "/" 和 "list" 是平级的,都是一个单独的页面

而其中的 "details" 为嵌套路由,"details"不是一个单独的页面,他会显示在他所嵌套的路由的页面上,而在路由上只要简单的使用this.props.children即可引用子路由

路由
引用子路由

2.参数传递

参数传递时可以通过 "list/123" 写死,也可以通过 "list/:id" 的方式占位,页面url上拼上就可以

而在对应的页面上只需要使用 "this.props.params.id" 就可以接收到url上的值

参数传递
页面接收参数
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容