Javascript เพิ่มเลขศูนย์นำหน้าจนถึงปัจจุบัน


437

ฉันได้สร้างสคริปต์นี้เพื่อคำนวณวันล่วงหน้า 10 วันในรูปแบบของวว / ดด / ปปปป:

var MyDate = new Date();
var MyDateString = new Date();
MyDate.setDate(MyDate.getDate()+10);
MyDateString = MyDate.getDate() + '/' + (MyDate.getMonth()+1) + '/' + MyDate.getFullYear();

ฉันต้องการให้วันที่ปรากฏขึ้นพร้อมเลขศูนย์นำหน้าในองค์ประกอบวันและเดือนด้วยการเพิ่มกฎเหล่านี้ลงในสคริปต์ ฉันไม่สามารถทำงานได้

if (MyDate.getMonth < 10)getMonth = '0' + getMonth;

และ

if (MyDate.getDate <10)get.Date = '0' + getDate;

หากใครบางคนสามารถแสดงให้ฉันเห็นว่าจะแทรกสิ่งเหล่านี้ลงในสคริปต์ได้ที่ไหนฉันจะรู้สึกขอบคุณจริงๆ


6
ตามแบบแผนที่ดีคุณควรพิมพ์อักขระตัวแรกในชื่อตัวแปรและสำรองอูฐกล่องสำหรับวัตถุ / ต้นแบบ
zykadelic

หากรูปแบบ YYYY-MM-DD เป็นที่ยอมรับนี่จะเป็นคำตอบที่ดีมาก: stackoverflow.com/a/28431880/1717535
Fabien Snauwaert

คำตอบ:


1352

ลองนี้: http://jsfiddle.net/xA5B7/

var MyDate = new Date();
var MyDateString;

MyDate.setDate(MyDate.getDate() + 20);

MyDateString = ('0' + MyDate.getDate()).slice(-2) + '/'
             + ('0' + (MyDate.getMonth()+1)).slice(-2) + '/'
             + MyDate.getFullYear();

แก้ไข:

เพื่ออธิบาย.slice(-2)ให้เราสองตัวอักษรสุดท้ายของสตริง

ดังนั้นไม่ว่าเราจะเพิ่มอะไร "0"วันหรือเดือนและขอสองอันสุดท้ายเพราะนั่นคือสองที่เราต้องการเสมอ

ดังนั้นหากMyDate.getMonth()ผลตอบแทน9มันจะเป็น:

("0" + "9") // Giving us "09"

ดังนั้นการเพิ่ม.slice(-2)ที่ให้เราสองตัวอักษรสุดท้ายซึ่งก็คือ:

("0" + "9").slice(-2)
"09"

แต่ถ้าMyDate.getMonth()ผลตอบแทน10มันจะเป็น:

("0" + "10") // Giving us "010"

ดังนั้นการเพิ่ม.slice(-2)ทำให้เรามีอักขระสองตัวสุดท้ายหรือ:

("0" + "10").slice(-2)
"10"

27
รูปแบบแยกส่วน - วันที่ YYYY-MM-DD jsfiddle.net/j6qJp/1 มันอาจจะมีประโยชน์สำหรับใครบางคน ขอบคุณ
tomexx

3
บางคนสามารถอธิบายได้ว่าทำไมถึงดีกว่าคำตอบที่ @Aleross ให้ไว้ด้านล่าง ไม่ชัดเจนในทันทีว่ามันทำอะไรกับฟังก์ชั่นแผ่นซึ่งชัดเจนอย่างชัดเจน
claudio

2
ไม่พูดถึงว่าวันนี้ตัวอย่างนี้ให้ฉัน 26/06/2014 แทน 06/06/2014
DazManCat

3
@DazManCat: นั่นคือสิ่งที่ควรจะทำ รหัสเริ่มต้นด้วยการเพิ่ม 20 วันถึงวันที่ปัจจุบัน MyDate.setDate(MyDate.getDate() + 20);
มอนสเตอร์คุกกี้

3
@ n00b และ @Phil Cooper โดยไม่ต้องหยุดการพูดคุยเกี่ยวกับ ins และ outs of time JavaScript JavaScript ฉันพบว่าslice()เทคนิคในคำตอบที่ยอมรับนั้นใช้เวลาประมาณ 1/10 วินาทีที่เร็วกว่าpad()เทคนิคของ @Aleross ซ้ำ 1 ล้าน jsFiddle "จ่ายเงินเอาสิ่งที่คุณเลือก"
คาร์ล

105

นี่คือตัวอย่างจากเอกสารวันที่ของวัตถุบน Mozilla Developer Network โดยใช้ฟังก์ชัน "pad" ที่กำหนดเองโดยไม่ต้องขยายต้นแบบหมายเลขของ Javascript ฟังก์ชั่นที่ใช้งานง่ายที่พวกเขาให้เป็นตัวอย่างคือ

function pad(n){return n<10 ? '0'+n : n}

และด้านล่างคือมันถูกใช้ในบริบท

/* use a function for the exact format desired... */
function ISODateString(d){
    function pad(n){return n<10 ? '0'+n : n}
    return d.getUTCFullYear()+'-'
    + pad(d.getUTCMonth()+1)+'-'
    + pad(d.getUTCDate())+'T'
    + pad(d.getUTCHours())+':'
    + pad(d.getUTCMinutes())+':'
    + pad(d.getUTCSeconds())+'Z'
}

var d = new Date();
console.log(ISODateString(d)); // prints something like 2009-09-28T19:03:12Z

3
วิธีที่ดีมากในการทำมัน ฉันคิดว่าคำตอบที่ยอมรับนั้นดีมาก แต่สิ่งนี้ก็ดีกว่าในความคิดของฉัน
Binke

1
สิ่งนี้อาจนำไปสู่ข้อผิดพลาดที่ไม่คาดคิดทำให้มันส่งออกสตริงสำหรับ <10 และตัวเลขสำหรับ> = 10
David Fregoli

@DavidFregoli ทุกวันที่ฟังก์ชั่นสตริงกลับสตริงดังนั้นถ้าคุณใส่สตริงpadจะส่งออกเฉพาะสตริง
Rohmer

56

วิธีการที่ทันสมัยในการทำเช่นนี้คือการใช้งานtoLocaleDateStringเพราะมันไม่เพียง แต่ช่วยให้คุณสามารถจัดรูปแบบวันที่ด้วยการแปลที่เหมาะสมคุณยังสามารถส่งตัวเลือกรูปแบบเพื่อเก็บผลลัพธ์ที่ต้องการ:

var date = new Date(2018, 2, 1);
var result = date.toLocaleDateString("en-GB", { // you can skip the first argument
  year: "numeric",
  month: "2-digit",
  day: "2-digit",
});
console.log(result);

เมื่อคุณข้ามอาร์กิวเมนต์แรกมันจะตรวจจับภาษาของเบราว์เซอร์แทน หรือคุณสามารถใช้2-digitตัวเลือกปีก็ได้เช่นกัน

หากคุณไม่ต้องการสนับสนุนเบราว์เซอร์รุ่นเก่าเช่น IE10 นี่เป็นวิธีที่สะอาดที่สุดในการทำงาน IE10 และเวอร์ชันต่ำกว่าจะไม่เข้าใจอาร์กิวเมนต์ตัวเลือก

หมายเหตุ: นอกจากนี้ยังมีtoLocaleTimeStringหากคุณต้องการแปลหรือจัดรูปแบบเวลาของวันที่


3
นี่คือสิ่งที่ฉันกำลังมองหาขอบคุณ ข้อมูลเพิ่มเติมเกี่ยวกับตัวเลือกสำหรับ toLocaleDateString ที่นี่: developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/
......

1
@JoseLinares สวัสดีค่ะขอบคุณที่ใส่ลิงค์นี้กลับไปในอีกไม่กี่วันข้างหน้า ฉันเพิ่งตัดสินใจปรับปรุงคำตอบของฉันเพื่อให้โซลูชันน่าสนใจยิ่งขึ้นสำหรับสถานการณ์ทั่วไปเนื่องจากคุณสามารถข้ามอาร์กิวเมนต์แรกและ IE10 ไม่เกี่ยวข้องอีกต่อไป เมื่อคำนึงถึงสิ่งนั้นฉันได้รวมลิงก์ของคุณไว้ในคำตอบของฉันด้วย
Martin Braun

@modiX ขอโทษมันเป็นความผิดพลาดของฉันในรหัสและผมเอาวิธีที่ผิดคำอธิบายใช่สถานที่ (ตัวแปรแรก) เป็นตัวเลือก
Kanhaiya lal

@Kanhaiyalal ไม่ต้องกังวลความผิดพลาดสามารถเกิดขึ้นได้ ฉันประหลาดใจเพียงว่า 2 ใน 3 ผู้ตรวจสอบอนุมัติการแก้ไขที่ผิดเช่นกัน
Martin Braun

51

คุณสามารถกำหนดฟังก์ชั่น "str_pad" (เหมือนใน php):

function str_pad(n) {
    return String("00" + n).slice(-2);
}

9
"0" แทนที่จะเป็น "00" ก็เพียงพอแล้ว
David Fregoli

คำตอบที่ดีที่สุดโดยไกล
Lucas Andrade

30

สำหรับคนที่คุณจากอนาคต (ECMAScript 2017 ขึ้นไป)

สารละลาย

"use strict"

const today = new Date()

const year = today.getFullYear()

const month = `${today.getMonth() + 1}`.padStart(2, "0")

const day = `${today.getDate()}`.padStart(2, "0")

const stringDate = [day, month, year].join("/") // 13/12/2017

ชี้แจง

String.prototype.padStart(targetLength[, padString])เพิ่มให้มากที่สุดเท่าที่เป็นไปได้padStringในเป้าหมายเพื่อให้ความยาวของเป้าหมายคือString.prototypetargetLength

ตัวอย่าง

"use strict"

let month = "9"

month = month.padStart(2, "0") // "09"

let byte = "00000100"

byte = byte.padStart(8, "0") // "00000100"

4
นี่เป็นส่วนหนึ่งของ ES2017 หรือ ES8 ดังนั้นจึงไม่ถูกต้องที่จะพูดว่า "ES6 +" เนื่องจากไม่ใช่ส่วนหนึ่งของ ES6 และ ES7
Noel Llevares

1
เทคนิคนี้น่าจะเป็น.padStart(2, '0')เพราะพารามิเตอร์ตัวที่สองคือสตริงแม้ว่ามันอาจจะไม่สำคัญจนกว่าคุณจะใช้ TypeScript
bmaupin

คุณถูกต้องฉันจะแก้ไขคำตอบของฉัน
Amin NAIRI

11
Number.prototype.padZero= function(len){
 var s= String(this), c= '0';
 len= len || 2;
 while(s.length < len) s= c + s;
 return s;
}

// ในการใช้งาน:

(function(){
 var myDate= new Date(), myDateString;
 myDate.setDate(myDate.getDate()+10);

 myDateString= [myDate.getDate().padZero(),
 (myDate.getMonth()+1).padZero(),
 myDate.getFullYear()].join('/');

 alert(myDateString);
})()

/*  value: (String)
09/09/2010
*/

10

ฉันพบวิธีที่สั้นกว่าในการทำสิ่งนี้:

 MyDateString.replace(/(^|\D)(\d)(?!\d)/g, '$10$2');

จะเพิ่มศูนย์นำหน้าให้กับทุกหลักเดียว


ฉันชอบโซลูชันนี้คุณช่วยอธิบายให้ชัดเจนหน่อยได้ไหมว่าเกิดอะไรขึ้นที่นั่น
Gobliins

7
var MyDate = new Date();
var MyDateString = '';
MyDate.setDate(MyDate.getDate());
var tempoMonth = (MyDate.getMonth()+1);
var tempoDate = (MyDate.getDate());
if (tempoMonth < 10) tempoMonth = '0' + tempoMonth;
if (tempoDate < 10) tempoDate = '0' + tempoDate;
MyDateString = tempoDate + '/' + tempoMonth + '/' + MyDate.getFullYear();

5

คุณสามารถใช้โอเปอเรเตอร์ ternary เพื่อจัดรูปแบบวันที่เช่นคำสั่ง "if"

ตัวอย่างเช่น:

var MyDate = new Date();
MyDate.setDate(MyDate.getDate()+10);
var MyDateString = (MyDate.getDate() < 10 ? '0' + MyDate.getDate() : MyDate.getDate()) + '/' + ((d.getMonth()+1) < 10 ? '0' + (d.getMonth()+1) : (d.getMonth()+1)) + '/' + MyDate.getFullYear();

ดังนั้น

(MyDate.getDate() < 10 ? '0' + MyDate.getDate() : MyDate.getDate())

จะคล้ายกับคำสั่ง if ที่ถ้า getDate () ส่งคืนค่าน้อยกว่า 10 แล้วส่งกลับ '0' + วันที่หรืออื่น ๆ คืนวันที่ถ้ามากกว่า 10 (เนื่องจากเราไม่จำเป็นต้องเพิ่มผู้นำ 0) เหมือนกันสำหรับเดือน

แก้ไข: ลืมว่า getMonth เริ่มต้นด้วย 0 ดังนั้นเพิ่ม +1 เข้าไปในบัญชี แน่นอนคุณสามารถพูด d.getMonth () <9: แต่ฉันคิดว่าการใช้ +1 จะช่วยให้เข้าใจได้ง่ายขึ้น


ขอบคุณที่อธิบาย +1
Bryan A

5

มีวิธีอื่นในการแก้ปัญหานี้โดยใช้sliceใน JavaScript

var d = new Date();
var datestring = d.getFullYear() + "-" + ("0"+(d.getMonth()+1)).slice(-2) +"-"+("0" + d.getDate()).slice(-2);

datestringวันกลับมีรูปแบบตามที่คุณคาดหวัง: 2019/09/01

อีกวิธีคือการใช้dateformatไลบรารี่: https://github.com/felixge/node-dateformat


ระวังการสะกด "JavaScript"
Basil Bourque

3

ทำให้ชีวิตของคุณง่ายขึ้นและใช้Moment.jsโค้ดตัวอย่างบางส่วน:

var beginDateTime = moment()
  .format('DD-MM-YYYY HH:mm')
  .toString();

// Now will print 30-06-2015 17:55
console.log(beginDateTime);

4
moment.js -> ไม่ใช่โซลูชันที่ดี bcos รหัส 19.8k เมื่อเทียบกับโซลูชั่นขนาด 0.3k ที่นี่
MarcoZen

3
function formatDate(jsDate){
  // add leading zeroes to jsDate when days or months are < 10.. 
  // i.e.
  //     formatDate(new Date("1/3/2013")); 
  // returns
  //    "01/03/2103"
  ////////////////////
  return (jsDate.getDate()<10?("0"+jsDate.getDate()):jsDate.getDate()) + "/" + 
      ((jsDate.getMonth()+1)<10?("0"+(jsDate.getMonth()+1)):(jsDate.getMonth()+1)) + "/" + 
      jsDate.getFullYear();
}

3

คุณสามารถให้ตัวเลือกเป็นพารามิเตอร์ในการจัดรูปแบบวันที่ พารามิเตอร์แรกนั้นใช้สำหรับโลแคลซึ่งคุณอาจไม่ต้องการและอย่างที่สองคือสำหรับตัวเลือก สำหรับข้อมูลเพิ่มเติมโปรดไปที่ https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toLocaleDateString

var date = new Date(Date.UTC(2012, 1, 1, 3, 0, 0));
var options = { year: 'numeric', month: '2-digit', day: '2-digit' };
console.log(date.toLocaleDateString(undefined,options));

1
ขอบคุณสำหรับคำแนะนำ
MJ55

2

ฉันหุ้มคำตอบที่ถูกต้องของคำถามนี้ในฟังก์ชั่นที่สามารถเพิ่มศูนย์นำหน้าหลายศูนย์ แต่ค่าเริ่มต้นคือเพิ่ม 1 ศูนย์

function zeroFill(nr, depth){
  depth = (depth === undefined)? 1 : depth;

  var zero = "0";
  for (var i = 0; i < depth; ++i) {
    zero += "0";
  }

  return (zero + nr).slice(-(depth + 1));
}

สำหรับการทำงานกับตัวเลขเท่านั้นและไม่เกิน 2 หลักนี่เป็นวิธีการ:

function zeroFill(i) {
    return (i < 10 ? '0' : '') + i
  }

1

ตัวเลือกอื่นโดยใช้ฟังก์ชั่นในตัวเพื่อทำแพ็ดดิ้ง (แต่ส่งผลให้รหัสยาวมาก!):

myDateString = myDate.getDate().toLocaleString('en-US', {minimumIntegerDigits: 2})
  + '/' + (myDate.getMonth()+1).toLocaleString('en-US', {minimumIntegerDigits: 2})
  + '/' + myDate.getFullYear();

// '12/06/2017'

และอีกวิธีจัดการกับสตริงด้วยนิพจน์ทั่วไป:

var myDateString = myDate.toISOString().replace(/T.*/, '').replace(/-/g, '/');

// '2017/06/12'

แต่ทราบว่าใครจะแสดงปีที่เริ่มต้นและวันที่สิ้นสุด


ชอบสิ่งนี้มากที่สุด: myDate.getDate (). toLocaleString ('en-US', {MinimumIntegerDigits: 2})
Max Alexander Hanna

1

การเพิ่มคำตอบไปยัง @modiX นี่คือสิ่งที่ใช้งานได้ ... อย่าปล่อยให้มันว่างเปล่า

today.toLocaleDateString("default", {year: "numeric", month: "2-digit", day: "2-digit"})

1

นี่คือตัวอย่างง่ายๆที่คุณสามารถรับมือกับสถานการณ์นี้ได้

var mydate = new Date();

var month = (mydate.getMonth().toString().length < 2 ? "0"+mydate.getMonth().toString() :mydate.getMonth());

var date = (mydate.getDate().toString().length < 2 ? "0"+mydate.getDate().toString() :mydate.getDate());

var year = mydate.getFullYear();

console.log("Format Y-m-d : ",year+"-"+month+"-" + date);

console.log("Format Y/m/d : ",year+"/"+month+"/" + date);


0

ต่อไปนี้มีจุดมุ่งหมายเพื่อแยกการกำหนดค่าเบ็ดเข้าDate.protoypeและใช้การกำหนดค่า

ฉันเคยใช้ในการArrayเก็บชิ้นเวลาและเมื่อฉันpush() thisเป็นDateวัตถุมันคืนความยาวให้ฉันย้ำ เมื่อฉันทำเสร็จแล้วฉันสามารถใช้joinกับreturnค่า

ดูเหมือนว่าจะใช้งานได้เร็ว: 0.016 มิลลิวินาที

// Date protoype
Date.prototype.formatTime = function (options) {
    var i = 0,
        time = [],
        len = time.push(this.getHours(), this.getMinutes(), this.getSeconds());

    for (; i < len; i += 1) {
        var tick = time[i];
        time[i] = tick < 10 ? options.pad + tick : tick;
    }

    return time.join(options.separator);
};

// Setup output
var cfg = {
    fieldClock: "#fieldClock",
    options: {
        pad: "0",
        separator: ":",
        tick: 1000
    }
};

// Define functionality
function startTime() {
    var clock = $(cfg.fieldClock),
        now = new Date().formatTime(cfg.options);

    clock.val(now);
    setTimeout(startTime, cfg.options.tick);
}

// Run once
startTime();

ตัวอย่าง: http://jsfiddle.net/tive/U4MZ3/


0

สิ่งที่ฉันจะทำคือสร้างตัวช่วย Date ที่กำหนดเองซึ่งมีลักษณะดังนี้:

var DateHelper = {
    addDays : function(aDate, numberOfDays) {
        aDate.setDate(aDate.getDate() + numberOfDays); // Add numberOfDays
        return aDate;                                  // Return the date
    },
    format : function format(date) {
        return [
           ("0" + date.getDate()).slice(-2),           // Get day and pad it with zeroes
           ("0" + (date.getMonth()+1)).slice(-2),      // Get month and pad it with zeroes
           date.getFullYear()                          // Get full year
        ].join('/');                                   // Glue the pieces together
    }
}

// With this helper, you can now just use one line of readable code to :
// ---------------------------------------------------------------------
// 1. Get the current date
// 2. Add 20 days
// 3. Format it
// 4. Output it
// ---------------------------------------------------------------------
document.body.innerHTML = DateHelper.format(DateHelper.addDays(new Date(), 20));

(ดูซอนี้ )


0

เพิ่มช่องว่างภายในเพื่อให้ศูนย์นำหน้า - เมื่อต้องการ - และต่อกันโดยใช้ตัวคั่นที่คุณเลือกเป็นสตริง

Number.prototype.padLeft = function(base,chr){
        var  len = (String(base || 10).length - String(this).length)+1;
        return len > 0? new Array(len).join(chr || '0')+this : this;
    }

var d = new Date(my_date);
var dformatted = [(d.getMonth()+1).padLeft(), d.getDate().padLeft(), d.getFullYear()].join('/');

0

ดังที่ @John Henckel แนะนำการเริ่มใช้วิธีtoISOString ()ทำให้ทุกอย่างง่ายขึ้น

const dateString = new Date().toISOString().split('-');
const year = dateString[0];
const month = dateString[1];
const day = dateString[2].split('T')[0];

console.log(`${year}-${month}-${day}`);


0
 let date = new Date();
 let dd = date.getDate();//day of month

 let mm = date.getMonth();// month
 let yyyy = date.getFullYear();//day of week
 if (dd < 10) {//if less then 10 add a leading zero
     dd = "0" + dd;
   }
 if (mm < 10) {
    mm = "0" + mm;//if less then 10 add a leading zero
  }

คุณสามารถอธิบายสั้น ๆ ว่าคุณพยายามทำอะไร
Shiv Kumar Baghel

0

ลองใช้ฟังก์ชันพื้นฐานโดยไม่จำเป็นต้องใช้ไลบรารี

Date.prototype.CustomformatDate = function() {
 var tmp = new Date(this.valueOf());
 var mm = tmp.getMonth() + 1;
 if (mm < 10) mm = "0" + mm;
 var dd = tmp.getDate();
 if (dd < 10) dd = "0" + dd;
 return mm + "/" + dd + "/" + tmp.getFullYear();
};

0
function pad(value) {
    return value.tostring().padstart(2, 0);
}

let d = new date();
console.log(d);
console.log(`${d.getfullyear()}-${pad(d.getmonth() + 1)}-${pad(d.getdate())}t${pad(d.gethours())}:${pad(d.getminutes())}:${pad(d.getseconds())}`);

2
ในขณะที่รหัสนี้อาจตอบคำถามให้บริบทเพิ่มเติมเกี่ยวกับวิธีการและ / หรือทำไมมันแก้ปัญหาจะปรับปรุงค่าระยะยาวของคำตอบ
leopal

0

คุณสามารถใช้String.slice ()ซึ่งแยกส่วนของสตริงและส่งคืนเป็นสตริงใหม่โดยไม่ต้องแก้ไขสตริงเดิม:

const currentDate = new Date().toISOString().slice(0, 10) // 2020-04-16

หรือคุณสามารถใช้ lib เช่นMoment.jsเพื่อจัดรูปแบบวันที่:

const moment = require("moment")
const currentDate = moment().format("YYYY-MM-DD") // 2020-04-16
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.