if(cjuli<0)
大于也一样
if(cjuli>0)
等于
if(cjuli==0)
完全等于
if(cjuli===0)
不等于
if(cjuli!=0)
大于等于
if(cjuli>=0)
小于等于
if(cjuli<=0)
只用一个等于号是赋值,是语句,不是表达式!
var cjuli=0
你自己百度一下 “js逻辑运算符”就明白啦!
// 按照你所说的,3种情况互斥,是只会成立一种情况的话,而你这样写,那么肯定会出现各种情况都交互存在了,例如当你的第一个值大于40的时候,之后应该就只显示大于等于40的了,而你的最后一个else if判断会导致 >=30 且 <40 的在循环中被显示出来,所以当然是错的。如果你确定你的Array中一定是多少个值的话,可以写死,为了简单,假设有3个值,可以如下:<script type="text/javascript">
// 既然你用了 jp[0] - jp[n] ,那也就不用在最外层循环了
// 第一次判断,其中一个大于 40 ,则
if(jp[0] >= 40 || jp[1] >=40 || jp[2] >=40){
for(var i=0i<3i++){
if(jp[i]>=40){
document.getElementById("tz_"+jp[i]).style.display="block"
}
}
}else if(jp[0]<30 && jp[1]<30 && jp[2]<30){
// 这里是全部小于 30 的话,显示你的 id="ph" 的 div
document.getElementById("ph").style.display = "block"
}else{
// 如果全部小于 40 且不全部小于 30 的话
for(var i=0i<3i++){
// 则把所有大于等于 30 的显示出来
if(jp[i]>=30){
document.getElementById("tz_"+jp[i]).style.display="block"
}
}
}
</script>
// 当然,可以使用循环的方式,这样以后维护也好一点,循环判断代码如下:
<script type="text/javascript">
var zhph = "00"
var jp = new Array(27, 28, 23, 24)
// gt40 判断是否有大于等于40 的,lt30 判断是否全部小于 30
var gt40 = false, mi34 = false
window.onload = function() {
for (var zh in jp) {
var value = jp[zh]
// 如果有一个超过 40 ,则 gt40=true,直接可以 break
if (value >= 40) {
gt40 = true
break
} else {
// 如果有 30<= x < 40 的,则 mi34 = true
if (value >= 30) {
mi34 = true
}
}
}
if (gt40) { // 如果有大于40的,则显示所有大于 40 的 div
for (var zh in jp) {
var value = jp[zh]
if (value >= 40) {
var myid = "tz_" + value.toString()
if (document.getElementById(myid)) {
document.getElementById(myid).style.display = "block"
}
}
}
} else if (!mi34) { // 如果不存在 30-40 的数,则是全部小于 30 的 div
var myid = "tz_" + zhph
if (document.getElementById(myid)) {
document.getElementById(myid).style.display = "block"
}
} else { // 否则,显示 30-40 的 div
for (var zh in jp) {
var value = jp[zh]
if (value < 40 && value >= 30) {
var myid = "tz_" + value.toString()
if (document.getElementById(myid)) {
document.getElementById(myid).style.display = "block"
}
}
}
}
}
</script>