html有判断条件,react条件判断的几种形式

37bcdbf2bebd91db27151444dc090262.png

react条件判断的几种形式

在React中,一个组件的HTML标签与生成这些标签的代码内在地紧密联系在一起。这意味着你可以轻松的利用javascript强大的魔力,比如循环和条件判断等。

想要在组件中添加条件判断,似乎是件比较困难的事情,因为if/else逻辑很难用HTML标签来表达。直接在JSX中加入if语句会渲染出无效的JavaScript:var IvanIf = React.createClass({

render: function () {

return(

...

);

}

});

解决的办法有以下几种:

1、使用三目运算符

2、设置一个变量,并在属性中引用它

3、将逻辑信息封装到函数中

4、使用 && 运算符

一、三目运算符var IvanIf = React.createClass({

getInitialState:function () {

return { isComplete:true };

},

render: function () {

return(

Hello Ivan .

);

}

});

虽然以上的三目运算符可以正常运行,但如果你想要在其他情况下很好的应用React Component时,可能就显得笨重又麻烦了,所以此方法是不做推荐使用的。

二、使用变量var IvanIf = React.createClass({

getInitialState:function () {

return { isComplete:true };

},

getIsComplete:function(){

return this.state.isComplete ? 'is-complete' : '' ;

},

render: function () {

var isComplete = this.getIsComplete();

return(

Hello Ivan .

);

}

});

其实就是将条件判断单独的抽离出去,在render中使用函数调用的形式来获取条件结果。

三、使用函数var IvanIf = React.createClass({

getInitialState:function () {

return { isComplete:false };

},

getIsComplete:function(){

return this.state.isComplete ? 'is-complete' : '' ;

},

render: function () {

return(

Hello Ivan .

);

}

});

四、使用逻辑与(&&)运算符var IvanIf = React.createClass({

getInitialState:function () {

return { isComplete:false };

},

render: function () {

return(

Hello Ivan .

);

}

});

由于对于null 或 false 值,React不会输出任何内容,因此可以使用一个后面跟随了期望字符串的boolean值来实现条件判断。

如果这个boolean值为true,那么后续的字符串会被使用,反之,则不会被使用

更多React相关技术文章,请访问React答疑栏目进行学习!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值