JS根據(jù)生日月份和日期計(jì)算星座的簡單實(shí)現(xiàn)方法
本文實(shí)例講述了JS根據(jù)生日月份和日期計(jì)算星座的簡單實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
看到了別人寫的一個(gè)計(jì)算星座的js,冗長的有點(diǎn)兒看不過去,就自己寫個(gè)了。
我想,這個(gè)函數(shù)應(yīng)該足夠精簡了:)
什么 if 啊 switch 啊 for 啊 通通滾蛋了……
傳入?yún)?shù):month [int] 1~12; day [int] 1~31。
// 根據(jù)生日的月份和日期,計(jì)算星座。 function getAstro(month,day){ var s="魔羯水瓶雙魚牡羊金牛雙子巨蟹獅子處女天秤天蝎射手魔羯"; var arr=[20,19,21,21,21,22,23,23,23,23,22,22]; return s.substr(month*2-(day<arr[month-1]?2:0),2); }
如果你在網(wǎng)上搜“日期 星座 函數(shù)”,除了我的或轉(zhuǎn)載我的代碼之外,幾乎都是長長的代碼,恐怕不能找到比上面更簡潔的代碼了。
不過這上面3行代碼仍然可以進(jìn)一步精簡,再來改進(jìn)一下:
// 根據(jù)生日的月份和日期,計(jì)算星座。 function getAstro(m,d){ return "魔羯水瓶雙魚牡羊金牛雙子巨蟹獅子處女天秤天蝎射手魔羯".substr(m*2-(d<"102223444433".charAt(m-1)- -19)*2,2); }
是不是很酷呢,只有一行代碼了,而且最大限度的精簡了。
上面用到了一個(gè)substr函數(shù)和一個(gè)charAt函數(shù),如果不考慮IE,那么.charAt(m-1)甚至可以精簡為[m-1]
如果不需要輸出星座名稱而只需要星座數(shù)字索引,前面的字符串也可以省去,看起來就像這樣:
// 根據(jù)生日的月份和日期,計(jì)算星座。 function getAstro(m,d){ return m-(d<"102223444433".charAt(m-1)- -19); //輸出0~12的數(shù)字,0表示摩羯,1表示水瓶,依此類推,...,11是射手,12是摩羯。 }
下面寫一段測試代碼來驗(yàn)證:
// 根據(jù)生日的月份和日期,計(jì)算星座。 function getAstro(m,d){ return "魔羯水瓶雙魚牡羊金牛雙子巨蟹獅子處女天秤天蝎射手魔羯".substr(m*2-(d<"102223444433".charAt(m-1)- -19)*2,2); } //下面寫一個(gè)測試函數(shù) 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/19)、水瓶座(1/20 - 2/18)、雙魚座(2/19 - 3/20)、牡羊座(3/21 - 4/20)、
金牛座(4/21 - 5/20)、雙子座(5/21 - 6/21)、巨蟹座(6/22 - 7/22)、獅子座(7/23 - 8/22)、
處女座(8/23 - 9/22)、天秤座(9/23 - 10/22)、天蝎座(10/23 - 11/21)、射手座(11/22 - 12/21)
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript時(shí)間與日期操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
Typescript的三種運(yùn)行方式(小結(jié))
這篇文章主要介紹了Typescript的三種運(yùn)行方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的查找算法示例
這篇文章主要介紹了JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的查找算法,結(jié)合具體實(shí)例形式分析了javascript針對二叉樹節(jié)點(diǎn)最小值、最大值的相關(guān)查找操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-04-04探索瀏覽器頁面關(guān)閉window.close()的使用詳解
這篇文章主要介紹了探索瀏覽器頁面關(guān)閉window.close()的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08element-ui 上傳圖片后標(biāo)注坐標(biāo)點(diǎn)
有個(gè)組件庫的名稱叫做element-ui,基于Vue2.0開發(fā),提供了豐富的PC端組件,本文通過實(shí)例代碼給大家介紹element-ui 上傳圖片后標(biāo)注坐標(biāo)點(diǎn)的示例代碼,感興趣的朋友跟隨小編一起看看吧2021-07-07js模擬jquery的slide和fadeIn和fadeOut功能
以前用過jquery的slideUp,slideDown,等許多很不錯(cuò)的方法,感覺很容易就能實(shí)現(xiàn)頁面元素的動畫效果!2010-07-07javascript用正則表達(dá)式過濾空格的實(shí)現(xiàn)代碼
下面小編就為大家?guī)硪黄猨avascript用正則表達(dá)式過濾空格的實(shí)現(xiàn)代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06JavaScript數(shù)組push方法使用注意事項(xiàng)
push() 方法可向數(shù)組的末尾添加一個(gè)或多個(gè)元素,并返回新的長度。這篇文章主要介紹了JavaScript數(shù)組push方法使用注意,需要的朋友可以參考下2017-10-10