⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sterm.js

📁 1、激活企业硬件投资
💻 JS
字号:
//节气子类
function sTerm(year,month,date){
   var monthLength=D0(year,month+1,date) - D0(year,month,date);
   
   var sN0=2*month-2;
   var sDt0=S(year,sN0,1);
   var sD0=revD0(year,floor(sDt0));
   var sM0=floor(sD0/100);
   sDate0=sD0%100;

   var sN1=2*month-1;
   var sDt1=S(year,sN1,1);
   var sD1=revD0(year,floor(sDt1));
   var sM1=floor(sD1/100);
   var sDate1=sD1%100;

   var sN2=2*month;
   var sDt2=S(year,sN2,1);
   var sD2=revD0(year,floor(sDt2));
   var sM2=floor(sD2/100);
   var sDate2=sD2%100;

   var sN3=2*month+1;
   if(sN3>24)
      sN3-=24;
   var sDt3=S(year,sN3,1);
   var sD3=revD0(year,floor(sDt3));
   var sM3=floor(sD3/100);
   var sDate3=sD3%100;

   if(sM0==month){
     sN2=sN1; sN1=sN0;
     sDt2=sDt1; sDt1=sDt0;
     sDate2=sDate1; sDate1=sDate0;
   }

   if(sM3==month){
     sN1=sN2; sN2=sN3;
     sDt1=sDt2; sDt2=sDt3;
     sDate1=sDate2; sDate2=sDate3;
   }

   sN1=rem(sN1-1,24)+1;
   sN2=rem(sN2-1,24)+1;

   if(sDate2>monthLength){
     sDate2-=monthLength;
   }

   if(date==sDate1)
     return sStr(sN1);
   else if(date==sDate2)
     return sStr(sN2);
   else
     return '';
}

//节气函数
function S(y,n,pd){  //pd取值为0或1,分别表示平气和定气,该函数返回节气的D0值
  var juD=y*(365.2423112-6.4e-14*(y-100)*(y-100)-3.047e-8*(y-100))+15.218427*n+1721050.71301;//儒略日
  var tht=3e-4*y-0.372781384-0.2617913325*n;//角度
  var yrD=(1.945*sin(tht)-0.01206*sin(2*tht))*(1.048994-2.583e-5*y);//年差实均数
  var shuoD=-18e-4*sin(2.313908653*y-0.439822951-3.0443*n);//朔差实均数
  var vs=(pd)?(juD+yrD+shuoD-ESD(y,1,0)-1721425):(juD-ESD(y,1,0)-1721425);
  return vs;
}

//节气
function sStr(v){
  return '小寒大寒立春雨水惊蛰春分清明谷雨立夏小满芒种夏至小暑大暑立秋处暑白露秋分寒露霜降立冬小雪大雪冬至'.substring(2*v-2,2*v);
}

//判断Gregorian历还是Julian历
function ifGr(y,m,d){  //阳历y年m月(1,2,..,12,下同)d日=1,2,3分别表示标准日历,Gregorge历和Julian历,下同,其中所谓“标准日历是指:1582-10-4之前采用Julian,1582-10-15以后采用Gregorian,1582-10-5 ~ 1582-10-14为空”
   if(y>1582||(y==1582&&m>10)||(y==1582&&m==10&&d>14))
     return 1;  //Gregorian
   else
     if(y==1582&&m==10&&d>=5&&d<=14)
       return -1;  //空
     else
       return 0;  //Julian
}

//日差天数
function D0(y,m,d){
  var ifG=ifGr(y,m,d);
  var monL=new Array(0,31,28,31,30,31,30,31,31,30,31,30,31);

  if(ifG==-1){
    return Infinity;
  }

  if(ifG==1){
    if((y%100!=0&&y%4==0)||(y%400==0)){
      monL[2]+=1;
    }
    else ;
  }
  else{
    if(y%4==0){
      monL[2]+=1;
    }
    else ;
  }

  var v=0;
  for(var i=0;i<=m-1;i++){
    v+=monL[i];
  }
  v+=d;

  return v;
}

//反日差天数
function revD0(y,x){  // y年日差天数D0为x
  var j,m,mL;

  for(j=1;j<=12;j++){
    mL=D0(y,j+1,1)-D0(y,j,1);

    if(x<=mL||j==12){
      m=j;
      break;
    }
    else{
       x-=mL;
    }

  }

  if(y==1582&&m==10&&x>=5&&x<=14){
    return Infinity;
  }

  return 100*m+x;
}

//标准天数(Standard Days)(y年m月d日距该历制的1年1月0日的天数)
function SD(y,m,d){
  if(ifGr(y,m,d)==-1)
    return Infinity;

  if(ifGr(y,m,d)==1)
    return (y-1)*365+floor((y-1)/4)-floor((y-1)/100)+floor((y-1)/400)+D0(y,m,d);   //Gregorian的标准天数

  else
    return (y-1)*365+floor((y-1)/4)+D0(y,m,d);                                     //Julian的标准天数

}

//等效标准天数(Equivalent Standard Days)(y年m月d日距该历制的1年1月0日的天数)
function ESD(y,m,d){
  if(ifGr(y,m,d)==-1)
    return Infinity;

  if(ifGr(y,m,d)==1)
    return SD(y,m,d);   //Gregorian的标准天数

  else
    return SD(y,m,d)-2;   //Julian的标准天数

}

function tail(x){
  return x-floor(x);
}
//广义求余
function rem(x,w){
  return tail(x/w)*w;
}

function sin(x){
  return Math.sin(x);
}

function floor(x){
  return Math.floor(x);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -