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 相关文章推荐
Display SQL Server Login Mode
Jun 21 Javascript
用js读、写、删除Cookie代码分享及详细注释说明
Jun 05 Javascript
JavaScript利用正则表达式去除日期中的“-”
Jul 01 Javascript
node.js中的fs.truncateSync方法使用说明
Dec 15 Javascript
jQuery获取剪贴板内容的方法
Jun 16 Javascript
详解基于javascript实现的苹果系统底部菜单
Dec 02 Javascript
详解vue-Resource(与后端数据交互)
Jan 16 Javascript
解决Extjs下拉框不显示的问题
Jun 21 Javascript
vue-cli3.0 环境变量与模式配置方法
Nov 08 Javascript
五分钟搞懂Vuex实用知识(小结)
Aug 12 Javascript
js实现省级联动(数据结构优化)
Jul 17 Javascript
Openlayers绘制地图标注
Sep 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
windows下升级PHP到5.3.3的过程及注意事项
2010/10/12 PHP
php printf输出格式使用说明
2010/12/05 PHP
php通过session防url攻击方法
2014/12/10 PHP
php实现用于验证所有类型的信用卡类
2015/03/24 PHP
PHP实现基于栈的后缀表达式求值功能
2017/11/10 PHP
JavaScript 动态改变图片大小
2009/06/11 Javascript
node.js中的fs.read方法使用说明
2014/12/17 Javascript
JavaScript类继承及实例化的方法
2015/07/25 Javascript
JavaScript的React框架中的JSX语法学习入门教程
2016/03/05 Javascript
JS功能代码集锦
2016/05/04 Javascript
jQuery验证插件validate使用详解
2016/05/11 Javascript
Vue实现双向绑定的方法
2016/12/22 Javascript
javascript数据结构之串的概念与用法分析
2017/04/12 Javascript
ionic实现底部分享功能
2017/05/11 Javascript
基于javascript中的typeof和类型判断(详解)
2017/10/27 Javascript
详解Nuxt.js部署及踩过的坑
2018/08/07 Javascript
微信小程序自定义toast组件的方法详解【含动画】
2019/05/11 Javascript
JS面向对象编程实现的Tab选项卡案例详解
2020/03/03 Javascript
基于vue和bootstrap实现简单留言板功能
2020/05/30 Javascript
Python内置函数的用法实例教程
2014/09/08 Python
Python2.7环境Flask框架安装简明教程【已测试】
2018/07/13 Python
Django框架自定义模型管理器与元选项用法分析
2019/07/22 Python
Python解析json时提示“string indices must be integers”问题解决方法
2019/07/31 Python
Java文件与类动手动脑实例详解
2019/11/10 Python
Python操作MySQL数据库实例详解【安装、连接、增删改查等】
2020/01/17 Python
使用tensorflow框架在Colab上跑通猫狗识别代码
2020/04/26 Python
Keras构建神经网络踩坑(解决model.predict预测值全为0.0的问题)
2020/07/07 Python
Python 带星号(* 或 **)的函数参数详解
2021/02/23 Python
纯CSS改变webkit内核浏览器的滚动条样式
2014/04/17 HTML / CSS
html5 移动端视频video的android兼容(去除播放控件、全屏)
2020/03/26 HTML / CSS
解释i节点在文件系统中的作用
2013/11/26 面试题
大一军训感言
2014/01/09 职场文书
要账委托书范本
2014/09/15 职场文书
2015年小学开学寄语
2015/02/27 职场文书
小学英语新课改心得体会
2016/01/22 职场文书
Sleuth+logback 设置traceid 及自定义信息方式
2021/07/26 Java/Android