2

Dateオブジェクトを3つの異なる目的で使用する必要がありますが、これを次のように行うことはできますか?

私はJavaScriptを初めて使用するので、次の定義がすべてのブラウザーで問題ないかどうかはわかりません。

Date.prototype.yyyymmdd = function() 
{
  var yyyy = this.getFullYear().toString();    
  var mm = (this.getMonth()+1).toString(); 
  var dd  = this.getDate().toString();    
  return yyyy+"-" + (mm[1]?mm:"0"+mm[0])+"-" + (dd[1]?dd:"0"+dd[0]); 

}; 

Date.prototype.mmddyyyy = function() 
{
  var yyyy = this.getFullYear().toString();    
  var mm = (this.getMonth()+1).toString(); 
  var dd  = this.getDate().toString();    

  return (mm[1]?mm:"0"+mm[0])+"-" + (dd[1]?dd:"0"+dd[0])+"-" + yyyy; 
}; 

Date.prototype.mmdd = function() 
{
   var yyyy = this.getFullYear().toString();    
   var mm = (this.getMonth()+1).toString(); 
   var dd  = this.getDate().toString();    
   return (mm[1]?mm:mm[0])+"/" + (dd[1]?dd:dd[0]);
};


var d0 = new Date();
console.log(d0.mmddyyyy);

var d1 = new Date();
console.log(d1.yyyymmdd);

var d2 = new Date();
console.log(d2.mmdd);
4

1 に答える 1

1

角かっこを見逃しただけです-どのブラウザでも実行できるはずです(ただし、コンソールがサポートされていない場合、またはIE8で開いている場合は、現在失敗します)

デモ

var d0 = new Date();
console.log(d0.mmddyyyy());

var d1 = new Date();
console.log(d1.yyyymmdd());

var d2 = new Date();
console.log(d2.mmdd());

私は個人的に1つのプロトタイプを好みます

デモ

Date.prototype.formatDate=function(fmt) {
  fmt = fmt || "yyyymmdd";
  var yyyy = this.getFullYear();    
  var mm = this.getMonth()+1;
  if (mm<10) mm="0"+mm;
  var dd  = this.getDate();    
  if (dd<10) dd="0"+dd;  
  if (fmt==="yyyymmdd") return yyyy+"-" + mm+"-" + dd;
  if (fmt==="mmddyyyy") return ""+mm+"-" + dd +"-" + yyyy;
  if (fmt==="mmdd")  return ""+mm+"/"+dd;
};


var d0 = new Date();
console.log(d0.formatDate("mmddyyyy"));
console.log(d0.formatDate("yyyymmdd"));
console.log(d0.formatDate("mmdd"));
于 2012-07-27T04:54:47.683 に答える