ReactJS return 条件判断的几种形式

原文地址:http://blog.csdn.net/yf275908654/article/details/51078215

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

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

var IvanIf = React.createClass({
    render: function () {
        return(
        <!--会渲染出无效的js的-->
            <div className={if(true){ 'is-complete' }}> ... </div>
        );
    }
});
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

解决的办法有以下几种:

  • 使用三目运算符
  • 设置一个变量,并在属性中引用它
  • 讲逻辑信息封装到函数中
  • 使用 && 运算符

  • 三目运算符
var IvanIf = React.createClass({
    getInitialState:function () {
        return { isComplete:true };
    },
    render: function () {
        return(
            <div className={ this.state.isComplete ? 'is-complete' : '' }> Hello Ivan .</div>
        );
    }
});
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

虽然以上的三目运算符可以正常运行,但如果你想要在其他情况下很好的应用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(
            <div className={ isComplete }> Hello Ivan .</div>
        );
    }
});
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

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


  • 使用函数
var IvanIf = React.createClass({
    getInitialState:function () {
        return { isComplete:false };
    },
    getIsComplete:function(){
      return this.state.isComplete ? 'is-complete' : '' ;
    },
    render: function () {
        return(
            <div className={ this.getIsComplete() }> Hello Ivan .</div>
        );
    }
});
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

有种然并卵的赶脚


  • 使用逻辑与(&&)运算符
var IvanIf = React.createClass({
    getInitialState:function () {
        return { isComplete:false };
    },
    render: function () {
        return(
            <div className={ this.state.isComplete && 'is-complete' }> Hello Ivan .</div>
        );
    }
});
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

由于对于null 或 false 值,React不会输出任何内容,因此可以使用一个后面跟随了期望字符串的boolean值来实现条件判断。 
如果这个boolean值为true,那么后续的字符串会被使用,反之,则不会被使用

判断是否是素数的代码有很多种写法,以下是其中几种常见的写法: 1. 基本判断法:从2到n-1逐个判断n是否能被整除,如果都不能整除,则n为素数。 ```python def is_prime(n): if n < 2: return False for i in range(2, n): if n % i == 0: return False return True ``` 2. 优化判断法1:只需要从2到n的平方根进行判断即可,因为如果n可以被大于它平方根的数整除,那么一定可以被小于它平方根的数整除。 ```python import math def is_prime(n): if n < 2: return False for i in range(2, int(math.sqrt(n)) + 1): if n % i == 0: return False return True ``` 3. 优化判断法2:对于偶数可以直接判断,因为偶数中只有2是素数,其他都是合数。 ```python import math def is_prime(n): if n < 2: return False if n == 2: return True if n % 2 == 0: return False for i in range(3, int(math.sqrt(n)) + 1, 2): if n % i == 0: return False return True ``` 4. 埃拉托斯特尼筛法:从2开始,将每个素数的倍数都标记成合数,直到筛完所有小于n的素数,剩下的就是素数。 ```python def eratosthenes(n): is_prime = [True] * (n + 1) is_prime[0] = False is_prime[1] = False for i in range(2, int(n ** 0.5) + 1): if is_prime[i]: for j in range(i * i, n + 1, i): is_prime[j] = False return [i for i in range(n + 1) if is_prime[i]] print(eratosthenes(100)) ``` 5. 线性筛法:相比于埃拉托斯特尼筛法,可以将每个合数只筛选一次,时间复杂度更低。 ```python def linear_sieve(n): is_prime = [True] * (n + 1) primes = [] for i in range(2, n + 1): if is_prime[i]: primes.append(i) for j in range(len(primes)): if i * primes[j] > n: break is_prime[i * primes[j]] = False if i % primes[j] == 0: break return primes print(linear_sieve(100)) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值