这里是转载其他朋友的,然后其中数字代码我稍稍调了一下。

我想,这个函数应该足够精简了:)

什么 if 啊 switch 啊 for 啊 太多冗余

传入参数:month [int] 1~12;  day [int] 1~31。


//  根据生日的月份和日期,计算星座。​


function  getAstro(month,day){    


var  s = "魔羯水瓶双鱼牡羊金牛双子巨蟹狮子处女天秤天蝎射手魔羯" ;


var  arr = [ 21 , 19 , 21 , 20 , 21 , 22 , 23 , 23 , 23 , 23 , 22 , 22 ];


return  s.substr(month * 2 - (day < arr[month - 1 ] ? 2 : 0 ), 2 );

}

如果你在网上搜“日期 星座 函数”,除了我的或转载我的代码之外,几乎都是长长的代码,恐怕不能找到比上面更简洁的代码了。


不过这上面3行代码仍然可以进一步精简,再来改进一下:


// 根据生日的月份和日期,计算星座。 function

 getAstro(m,d){          return   "魔羯水瓶双鱼牡羊金牛双子巨蟹狮子处女天秤天蝎射手魔羯" .substr(m*2-(d< "102123444543" .charAt(m-1)- -19)*2,2);

}

是不是很酷呢,只有一行代码了,而且最大限度的精简了。

上面用到了一个substr函数和一个charAt函数,如果不考虑IE,那么.charAt(m-1)甚至可以精简为[m-1]

如果不需要输出星座名称而只需要星座数字索引,前面的字符串也可以省去,看起来就像这样:



// 根据生日的月份和日期,计算星座。​

function

 getAstro(m,d){          return   m-(d< "102123444543" .charAt(m-1)- -19);   //输出0~12的数字,0表示摩羯,1表示水瓶,依此类推,...,11是射手,12是摩羯。

}



下面写一段测试代码来验证:


// 根据生日的月份和日期,计算星座。​

function

 getAstro(m,d){          return   "魔羯水瓶双鱼牡羊金牛双子巨蟹狮子处女天秤天蝎射手魔羯" .substr(m*2-(d< "102123444543" .charAt(m-1)- -19)*2,2);

}


//下面写一个测试函数 function test(m,d){

document.writeln(m+ "月"+d+ "日 "+getAstro(m,d));

}


//测试 test(12,21);   //输出: 12月21日 射手

test(12,22);  

//输出: 12月22日 魔羯

test(1,1);     

//输出: 1月1日 魔羯

test(2,18);   

//输出: 2月18日 水瓶

test(2,19);   

//输出: 2月19日 双鱼



附十二星座日期对照:

魔羯座(12/22 - 1/20)、水瓶座(1/20 - 2/18)、双鱼座(2/19 - 3/20)、白羊座(3/21 - 4/19)、


金牛座(4/21 - 5/20)、双子座(5/21 - 6/21)、巨蟹座(6/22 - 7/22)、狮子座(7/23 - 8/22)、


处女座(8/23 - 9/22)、天秤座(9/23 - 10/23)、天蝎座(10/24 - 11/22)、射手座(11/23 - 12/21)