有很好的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';