手把手教你React,轻松入门

如果我们需要向组件传递参数,可以使用 this.props 对象,实例如下:

&emsp;&emsp;<div id="example"></div>
&emsp;&emsp;&emsp;&emsp;<script type="text/babel">
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;var HelloMessage = React.createClass({
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;render: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return <h1>Hello {this.props.name}</h1>;
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;}
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;});
&emsp;&emsp;&emsp;&emsp;ReactDOM.render(
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<HelloMessage name="前端攻城小牛" />,
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;document.getElementById('example')
&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;</script>
&emsp;&emsp;</body>
<!--&emsp;注意,在添加属性时, class 属性需要写成 className ,for 属性需要写成 htmlFor ,这是因为 class 和 for 是 JavaScript 的保留字。-->
复制代码

如果我们需要向组件传递参数,可以使用 this.props 对象,实例如下:

<body>
&emsp;&emsp;&emsp;&emsp;<div id="example"></div>
&emsp;&emsp;&emsp;&emsp;<script type="text/babel">
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;var WebSite = React.createClass({
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;render: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return (
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<div>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<Name name={this.props.name} />
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<Link site={this.props.site} />
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;</div>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;}
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;});
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;var Name = React.createClass({
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;render: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return (
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<h1>{this.props.name}</h1>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;}
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;});
&emsp;&emsp;&emsp;&emsp; var Link = React.createClass({
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;render: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return (
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<a href={this.props.site}>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;{this.props.site}
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;</a>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;}
&emsp;&emsp;&emsp;&emsp;});
&emsp;&emsp;&emsp;&emsp;React.render(
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<WebSite name="前端攻城小牛" site=" http://www.baidu.com" />,
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;document.getElementById('example')
&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;</script>
&emsp;&emsp;</body>
复制代码

React State(状态)

  React 把组件看成是一个状态机(State Machines)。通过与用户的交互,实现不同状态,然后渲染 UI,让用户界面和数据保持一致。   React 里,只需更新组件的 state,然后根据新的 state 重新渲染用户界面(不要操作 DOM)。   以下实例中创建了 LikeButton 组件,getInitialState 方法用于定义初始状态,也就是一个对象,这个对象可以通过 this.state 属性读取。   当用户点击组件,导致状态变化,this.setState 方法就修改状态值,每次修改以后,自动调用 this.render 方法,再次渲染组件。

<body>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<div id="example"></div>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<script type="text/babel">
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;var LikeButton = React.createClass({
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;getInitialState: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return {liked: false};
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;},
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;handleClick: function(event) {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;this.setState({liked: !this.state.liked});
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;},
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;render: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;var text = this.state.liked ? '找我' : '不找我';
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return (
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<p onClick={this.handleClick}>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;你<b>{text}</b>我。点我加交流扣扣裙:864305860。
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;</p>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;}
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;});

&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;React.render(
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<LikeButton />,
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;document.getElementById('example')
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;</script>
&emsp;&emsp;&emsp;&emsp;</body>
复制代码

React Props

<body>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<div id="example"></div>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<script type="text/babel">
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;var HelloMessage = React.createClass({
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;render: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return <h1>Hello {this.props.name}</h1>;
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;}
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;});

&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;ReactDOM.render(
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<HelloMessage name="前端攻城小牛" />,
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;document.getElementById('example')
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;</script>
</body>
复制代码

通过 getDefaultProps() 方法为 props 设置默认值,实例如下:

<body>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<div id="example"></div>
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<script type="text/babel">
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;var HelloMessage = React.createClass({
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;getDefaultProps: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;name: '前端攻城小牛'
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;};
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;},
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;render: function() {
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;return <h1>Hello {this.props.name}</h1>;
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;}//欢迎加入全栈开发交流圈一起学习交流:864305860
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;});//面向1-3年前端人员
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;ReactDOM.render(//帮助突破技术瓶颈,提升思维能力
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;<HelloMessage />,
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;document.getElementById('example')
&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;&emsp;);
&emsp;&emsp;&emsp;&emsp;</script>
&emsp;&emsp;</body>
复制代码

总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对前端攻城小牛的支持。

本次给大家推荐一个免费的学习群,里面概括移动应用网站开发,css,html,webpack,vue node angular以及面试资源等。 对web开发技术感兴趣的同学,欢迎加入Q群:864305860,不管你是小白还是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时每天更新视频资料。 最后,祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值