如何在PHP中编写好的if/else-if结构



有很好的PHP技能的人可以帮助我纠正这段代码吗?我有一个问题,如果level大于 10,它就会卡在else if(level >= 10)

var level = m.level;
if(level < 10)
{
    level = '<span class="levelco">' + level + '</span>';
} 
else if(level >= 10)
{
    level = '<span class="levelco10">' + level + '</span>';
}        
else if(level >= 30)
{
    level = '<span class="levelco30">' + level + '</span>';
}            
else if(level >= 50)
{
    level = '<span class="levelco50">' + level + '</span>';
} 
else if(level >= 80)
{
    level = '<span class="levelco80">' + level + '</span>';
}

你也应该给出上层并使用elseif,如果是 PHP,因为这看起来像 JavaScript:

var level = m.level;
if (level < 10) {
    level = '<span class="levelco">' + level + '</span>';
} else if (level >= 10 && level < 30) {
    level = '<span class="levelco10">' + level + '</span>';
} else if (level >= 30 && level < 50) {
    level = '<span class="levelco30">' + level + '</span>';
} else if (level >= 50 && level < 80) {
    level = '<span class="levelco50">' + level + '</span>';
} else if (level >= 80) {
    level = '<span class="levelco80">' + level + '</span>';
}

如果无法做到这一点,请反转条件:

var level = m.level;
if (level < 10) {
    level = '<span class="levelco">' + level + '</span>';
} else if (level >= 80) {
    level = '<span class="levelco80">' + level + '</span>';
} else if (level >= 50) {
    level = '<span class="levelco50">' + level + '</span>';
} else if (level >= 30) {
    level = '<span class="levelco30">' + level + '</span>';
} else if (level >= 10) {
    level = '<span class="levelco10">' + level + '</span>';
}

解决此问题的两种方法,但基本上归结为第二种 if 将捕获以下所有条件(级别>= 10 将匹配以下所有条件(。

解决方案 1 只是重新排序条件。

level = m.level;

if(level < 10)
{
    level = '<span class="levelco">' + level + '</span>';
} 
else if(level >= 80)
{
    level = '<span class="levelco80">' + level + '</span>';
}
else if(level >= 50)
{
    level = '<span class="levelco50">' + level + '</span>';
} 
else if(level >= 30)
{
    level = '<span class="levelco30">' + level + '</span>';
}    
else if(level >= 10)
{
    level = '<span class="levelco10">' + level + '</span>';
}        

选项 2 是对每个如果...

level = m.level;

if(level < 10)
{
    level = '<span class="levelco">' + level + '</span>';
} 
else if(level >= 10 && level <30)
{
    level = '<span class="levelco10">' + level + '</span>';
}        
else if(level >= 30 && level < 50)
{
    level = '<span class="levelco30">' + level + '</span>';
}            
else if(level >= 50 && level < 80)
{
    level = '<span class="levelco50">' + level + '</span>';
} 
else if(level >= 80)
{
    level = '<span class="levelco80">' + level + '</span>';
}

一种方法是:

var level = m.level;
var levelclass = 'levelco';
if(level >= 10) levelclass = 'levelco10';
if(level >= 30) levelclass = 'levelco30';
if(level >= 50) levelclass = 'levelco50';
if(level >= 80) levelclass = 'levelco80';
level = '<span class="' + levelclass + '">' + level + '</span>';

反转它并使用else if可以提高效率,因为一旦满足条件,它就会停止执行:

if(level >= 80) levelclass = 'levelco80';
else if(level >= 50) levelclass = 'levelco50';
else if(level >= 30) levelclass = 'levelco30';
else if(level >= 10) levelclass = 'levelco10';

最新更新