JS根据生日月份和日期计算星座的简单实现方法


Posted in Javascript onNovember 24, 2016

本文实例讲述了JS根据生日月份和日期计算星座的简单实现方法。分享给大家供大家参考,具体如下:

看到了别人写的一个计算星座的js,冗长的有点儿看不过去,就自己写个了。

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

什么 if 啊 switch 啊 for 啊 通通滚蛋了……

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

// 根据生日的月份和日期,计算星座。
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);
}

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

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

// 根据生日的月份和日期,计算星座。
function getAstro(m,d){
  return "魔羯水瓶双鱼牡羊金牛双子巨蟹狮子处女天秤天蝎射手魔羯".substr(m*2-(d<"102223444433".charAt(m-1)- -19)*2,2);
}

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

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

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

// 根据生日的月份和日期,计算星座。
function getAstro(m,d){
  return m-(d<"102223444433".charAt(m-1)- -19);  //输出0~12的数字,0表示摩羯,1表示水瓶,依此类推,...,11是射手,12是摩羯。
}

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

// 根据生日的月份和日期,计算星座。
function getAstro(m,d){
  return "魔羯水瓶双鱼牡羊金牛双子巨蟹狮子处女天秤天蝎射手魔羯".substr(m*2-(d<"102223444433".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/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)

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
表单内同名元素的控制
Nov 22 Javascript
jQuery :nth-child前有无空格的区别分析
Jul 11 Javascript
重写javascript中window.confirm的行为
Oct 21 Javascript
JS实现屏蔽shift,Ctrl,alt等功能键的方法
Jun 01 Javascript
drag-and-drop实现图片浏览器预览
Aug 06 Javascript
Javascript获取随机数的实现方法
Jun 22 Javascript
微信小程序 传值取值的几种方法总结
Jan 16 Javascript
JS中showModalDialog关闭子窗口刷新主窗口用法详解
Mar 25 Javascript
详解vue axios用post提交的数据格式
Aug 07 Javascript
vue+springboot图片上传和显示的示例代码
Feb 14 Javascript
Element Backtop回到顶部的具体使用
Jul 27 Javascript
在Vue中使用Viser说明(基于AntV-G2可视化引擎)
Oct 28 Javascript
javascript简单进制转换实现方法
Nov 24 #Javascript
JavaScript自定义函数实现查找两个字符串最长公共子串的方法
Nov 24 #Javascript
详解Node.js:events事件模块
Nov 24 #Javascript
详解微信小程序开发之下拉刷新 上拉加载
Nov 24 #Javascript
微信小程序-消息提示框实例
Nov 24 #Javascript
jQuery实现的模拟弹出窗口功能示例
Nov 24 #Javascript
基于JavaScript实现Tab选项卡切换效果
Nov 24 #Javascript
You might like
PHP下利用header()函数设置浏览器缓存的代码
2010/09/01 PHP
php知道与问问的采集插件代码
2010/10/12 PHP
关于IIS php调用com组件的权限问题
2012/01/11 PHP
php switch语句多个值匹配同一代码块应用示例
2014/07/29 PHP
PHP更安全的密码加密机制Bcrypt详解
2017/06/18 PHP
JS 面向对象之神奇的prototype
2011/02/26 Javascript
JS前端框架关于重构的失败经验分享
2013/03/17 Javascript
Javascript Throttle &amp; Debounce应用介绍
2013/03/19 Javascript
javascript 分号总结及详细介绍
2016/09/24 Javascript
Bootstrap3 多选和单选框(checkbox)
2016/12/29 Javascript
AngularJS实现自定义指令与控制器数据交互的方法示例
2017/06/19 Javascript
使用canvas进行图像编辑的实例
2017/08/29 Javascript
JS+HTML5实现获取手机验证码倒计时按钮
2018/08/08 Javascript
基于vue实现一个禅道主页拖拽效果
2019/05/27 Javascript
vue实现固定位置显示功能
2019/05/30 Javascript
如何基于原生javaScript生成带图片的二维码
2019/11/21 Javascript
vue使用recorder.js实现录音功能
2019/11/22 Javascript
微信小程序点击按钮动态切换input的disabled禁用/启用状态功能
2020/03/07 Javascript
js实现石头剪刀布游戏
2020/10/11 Javascript
[01:09]DOTAPLUS——DOTA2的新时代
2018/04/04 DOTA
Python中字符编码简介、方法及使用建议
2015/01/08 Python
安装Python的web.py框架并从hello world开始编程
2015/04/25 Python
Saltstack快速入门简单汇总
2016/03/01 Python
再谈Python中的字符串与字符编码(推荐)
2016/12/14 Python
python实现寻找最长回文子序列的方法
2018/06/02 Python
python爱心表白 每天都是浪漫七夕!
2018/08/18 Python
Python中is和==的区别详解
2018/11/15 Python
TensorFlow基于MNIST数据集实现车牌识别(初步演示版)
2019/08/05 Python
python将邻接矩阵输出成图的实现
2019/11/21 Python
浅谈利用缓存来优化HTML5 Canvas程序的性能
2015/05/12 HTML / CSS
执行总经理岗位职责
2014/02/03 职场文书
乡镇党的群众路线教育实践活动制度建设计划
2014/11/03 职场文书
索赔员岗位职责
2015/02/15 职场文书
2015年五四青年节演讲稿
2015/03/18 职场文书
交通安全宣传标语(100条)
2019/08/22 职场文书
Python使用socket去实现TCP客户端和TCP服务端
2022/04/12 Python