<script>alert("2004-08-12".replace(/\b0(\d)\b/g,'$1'))</script>

解决方案 »

  1.   


    function formatDate(str){
      var dateDetail = str.split("-");//分割
      var returnStr = parseInt(dateDetail[0]).toString();//先转化成整数,去掉前面的0 ,再转化成字符串
      returnStr+ = parseInt(dateDetail[1]).toString();
      returnStr+ = parseInt(dateDetail[2]).toString();  
    }
      

  2.   

    我倒,用的到这么麻烦吗,直接这样:
    formatdatetime("2004-08-12",vbshortdate)就行了
      

  3.   

    function formatDate(str){
      var dateDetail = str.split("-");//分割
      var returnStr = parseInt(dateDetail[0],10).toString();//先转化成整数,去掉前面的0 ,再转化成字符串
      returnStr = returnStr +"-"+ parseInt(dateDetail[1],10).toString();
      returnStr = returnStr +"-"+ parseInt(dateDetail[2],10).toString(); 
      return returnStr;
      
    }alert(formatDate("2004-08-01"));
      

  4.   

    to : sunjiujiu(向第五个窝头努力) 
    你这是哪里的语法,不时javascript的吧.
      

  5.   

    谢谢您的回复
    http://community.csdn.net/Expert/topic/3263/3263869.xml?temp=.895138请问如何把 2004-08-11 转为为 "2004","8","11"
      

  6.   

    // ===================================================================
    // Author: Matt Kruse <[email protected]>
    // WWW: http://www.mattkruse.com/
    //
    // NOTICE: You may use this code for any purpose, commercial or
    // private, without any further permission from the author. You may
    // remove this notice from your final code if you wish, however it is
    // appreciated by the author if at least my web site address is kept.
    //
    // You may *NOT* re-distribute this code in any way except through its
    // use. That means, you can include it in your product, or your web
    // site, or any other form where the code is actually being used. You
    // may not put the plain javascript up on your site for download or
    // include it in your javascript libraries for download. 
    // If you wish to share this code with others, please just point them
    // to the URL instead.
    // Please DO NOT link directly to my .js files from your site. Copy
    // the files to your server and use them there. Thank you.
    // ===================================================================// HISTORY
    // ------------------------------------------------------------------
    // May 17, 2003: Fixed bug in parseDate() for dates <1970
    // March 11, 2003: Added parseDate() function
    // March 11, 2003: Added "NNN" formatting option. Doesn't match up
    //                 perfectly with SimpleDateFormat formats, but 
    //                 backwards-compatability was required.// ------------------------------------------------------------------
    // These functions use the same 'format' strings as the 
    // java.text.SimpleDateFormat class, with minor exceptions.
    // The format string consists of the following abbreviations:
    // 
    // Field        | Full Form          | Short Form
    // -------------+--------------------+-----------------------
    // Year         | yyyy (4 digits)    | yy (2 digits), y (2 or 4 digits)
    // Month        | MMM (name or abbr.)| MM (2 digits), M (1 or 2 digits)
    //              | NNN (abbr.)        |
    // Day of Month | dd (2 digits)      | d (1 or 2 digits)
    // Day of Week  | EE (name)          | E (abbr)
    // Hour (1-12)  | hh (2 digits)      | h (1 or 2 digits)
    // Hour (0-23)  | HH (2 digits)      | H (1 or 2 digits)
    // Hour (0-11)  | KK (2 digits)      | K (1 or 2 digits)
    // Hour (1-24)  | kk (2 digits)      | k (1 or 2 digits)
    // Minute       | mm (2 digits)      | m (1 or 2 digits)
    // Second       | ss (2 digits)      | s (1 or 2 digits)
    // AM/PM        | a                  |
    //
    // NOTE THE DIFFERENCE BETWEEN MM and mm! Month=MM, not mm!
    // Examples:
    //  "MMM d, y" matches: January 01, 2000
    //                      Dec 1, 1900
    //                      Nov 20, 00
    //  "M/d/yy"   matches: 01/20/00
    //                      9/2/00
    //  "MMM dd, yyyy hh:mm:ssa" matches: "January 01, 2000 12:30:45AM"
    // ------------------------------------------------------------------var MONTH_NAMES=new Array('January','February','March','April','May','June','July','August','September','October','November','December','Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec');
    var DAY_NAMES=new Array('Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sun','Mon','Tue','Wed','Thu','Fri','Sat');
    function LZ(x) {return(x<0||x>9?"":"0")+x}// ------------------------------------------------------------------
    // isDate ( date_string, format_string )
    // Returns true if date string matches format of format string and
    // is a valid date. Else returns false.
    // It is recommended that you trim whitespace around the value before
    // passing it to this function, as whitespace is NOT ignored!
    // ------------------------------------------------------------------
    function isDate(val,format) {
    var date=getDateFromFormat(val,format);
    if (date==0) { return false; }
    return true;
    }// -------------------------------------------------------------------
    // compareDates(date1,date1format,date2,date2format)
    //   Compare two date strings to see which is greater.
    //   Returns:
    //   1 if date1 is greater than date2
    //   0 if date2 is greater than date1 of if they are the same
    //  -1 if either of the dates is in an invalid format
    // -------------------------------------------------------------------
    function compareDates(date1,dateformat1,date2,dateformat2) {
    var d1=getDateFromFormat(date1,dateformat1);
    var d2=getDateFromFormat(date2,dateformat2);
    if (d1==0 || d2==0) {
    return -1;
    }
    else if (d1 > d2) {
    return 1;
    }
    return 0;
    }// ------------------------------------------------------------------
    // formatDate (date_object, format)
    // Returns a date in the output format specified.
    // The format string uses the same abbreviations as in getDateFromFormat()
    // ------------------------------------------------------------------
    function formatDate(date,format) {
    format=format+"";
    var result="";
    var i_format=0;
    var c="";
    var token="";
    var y=date.getYear()+"";
    var M=date.getMonth()+1;
    var d=date.getDate();
    var E=date.getDay();
    var H=date.getHours();
    var m=date.getMinutes();
    var s=date.getSeconds();
    var yyyy,yy,MMM,MM,dd,hh,h,mm,ss,ampm,HH,H,KK,K,kk,k;
    // Convert real date parts into formatted versions
    var value=new Object();
    if (y.length < 4) {y=""+(y-0+1900);}
    value["y"]=""+y;
    value["yyyy"]=y;
    value["yy"]=y.substring(2,4);
    value["M"]=M;
    value["MM"]=LZ(M);
    value["MMM"]=MONTH_NAMES[M-1];
    value["NNN"]=MONTH_NAMES[M+11];
    value["d"]=d;
    value["dd"]=LZ(d);
    value["E"]=DAY_NAMES[E+7];
    value["EE"]=DAY_NAMES[E];
    value["H"]=H;
    value["HH"]=LZ(H);
    if (H==0){value["h"]=12;}
    else if (H>12){value["h"]=H-12;}
    else {value["h"]=H;}
    value["hh"]=LZ(value["h"]);
    if (H>11){value["K"]=H-12;} else {value["K"]=H;}
    value["k"]=H+1;
    value["KK"]=LZ(value["K"]);
    value["kk"]=LZ(value["k"]);
    if (H > 11) { value["a"]="PM"; }
    else { value["a"]="AM"; }
    value["m"]=m;
    value["mm"]=LZ(m);
    value["s"]=s;
    value["ss"]=LZ(s);
    while (i_format < format.length) {
    c=format.charAt(i_format);
    token="";
    while ((format.charAt(i_format)==c) && (i_format < format.length)) {
    token += format.charAt(i_format++);
    }
    if (value[token] != null) { result=result + value[token]; }
    else { result=result + token; }
    }
    return result;
    }

    // ------------------------------------------------------------------
    // Utility functions for parsing in getDateFromFormat()
    // ------------------------------------------------------------------
    function _isInteger(val) {
    var digits="1234567890";
    for (var i=0; i < val.length; i++) {
    if (digits.indexOf(val.charAt(i))==-1) { return false; }
    }
    return true;
    }
    function _getInt(str,i,minlength,maxlength) {
    for (var x=maxlength; x>=minlength; x--) {
    var token=str.substring(i,i+x);
    if (token.length < minlength) { return null; }
    if (_isInteger(token)) { return token; }
    }
    return null;
    }

      

  7.   

    //续上
    // ------------------------------------------------------------------
    // getDateFromFormat( date_string , format_string )
    //
    // This function takes a date string and a format string. It matches
    // If the date string matches the format string, it returns the 
    // getTime() of the date. If it does not match, it returns 0.
    // ------------------------------------------------------------------
    function getDateFromFormat(val,format) {
    val=val+"";
    format=format+"";
    var i_val=0;
    var i_format=0;
    var c="";
    var token="";
    var token2="";
    var x,y;
    var now=new Date();
    var year=now.getYear();
    var month=now.getMonth()+1;
    var date=1;
    var hh=now.getHours();
    var mm=now.getMinutes();
    var ss=now.getSeconds();
    var ampm="";

    while (i_format < format.length) {
    // Get next token from format string
    c=format.charAt(i_format);
    token="";
    while ((format.charAt(i_format)==c) && (i_format < format.length)) {
    token += format.charAt(i_format++);
    }
    // Extract contents of value based on format token
    if (token=="yyyy" || token=="yy" || token=="y") {
    if (token=="yyyy") { x=4;y=4; }
    if (token=="yy")   { x=2;y=2; }
    if (token=="y")    { x=2;y=4; }
    year=_getInt(val,i_val,x,y);
    if (year==null) { return 0; }
    i_val += year.length;
    if (year.length==2) {
    if (year > 70) { year=1900+(year-0); }
    else { year=2000+(year-0); }
    }
    }
    else if (token=="MMM"||token=="NNN"){
    month=0;
    for (var i=0; i<MONTH_NAMES.length; i++) {
    var month_name=MONTH_NAMES[i];
    if (val.substring(i_val,i_val+month_name.length).toLowerCase()==month_name.toLowerCase()) {
    if (token=="MMM"||(token=="NNN"&&i>11)) {
    month=i+1;
    if (month>12) { month -= 12; }
    i_val += month_name.length;
    break;
    }
    }
    }
    if ((month < 1)||(month>12)){return 0;}
    }
    else if (token=="EE"||token=="E"){
    for (var i=0; i<DAY_NAMES.length; i++) {
    var day_name=DAY_NAMES[i];
    if (val.substring(i_val,i_val+day_name.length).toLowerCase()==day_name.toLowerCase()) {
    i_val += day_name.length;
    break;
    }
    }
    }
    else if (token=="MM"||token=="M") {
    month=_getInt(val,i_val,token.length,2);
    if(month==null||(month<1)||(month>12)){return 0;}
    i_val+=month.length;}
    else if (token=="dd"||token=="d") {
    date=_getInt(val,i_val,token.length,2);
    if(date==null||(date<1)||(date>31)){return 0;}
    i_val+=date.length;}
    else if (token=="hh"||token=="h") {
    hh=_getInt(val,i_val,token.length,2);
    if(hh==null||(hh<1)||(hh>12)){return 0;}
    i_val+=hh.length;}
    else if (token=="HH"||token=="H") {
    hh=_getInt(val,i_val,token.length,2);
    if(hh==null||(hh<0)||(hh>23)){return 0;}
    i_val+=hh.length;}
    else if (token=="KK"||token=="K") {
    hh=_getInt(val,i_val,token.length,2);
    if(hh==null||(hh<0)||(hh>11)){return 0;}
    i_val+=hh.length;}
    else if (token=="kk"||token=="k") {
    hh=_getInt(val,i_val,token.length,2);
    if(hh==null||(hh<1)||(hh>24)){return 0;}
    i_val+=hh.length;hh--;}
    else if (token=="mm"||token=="m") {
    mm=_getInt(val,i_val,token.length,2);
    if(mm==null||(mm<0)||(mm>59)){return 0;}
    i_val+=mm.length;}
    else if (token=="ss"||token=="s") {
    ss=_getInt(val,i_val,token.length,2);
    if(ss==null||(ss<0)||(ss>59)){return 0;}
    i_val+=ss.length;}
    else if (token=="a") {
    if (val.substring(i_val,i_val+2).toLowerCase()=="am") {ampm="AM";}
    else if (val.substring(i_val,i_val+2).toLowerCase()=="pm") {ampm="PM";}
    else {return 0;}
    i_val+=2;}
    else {
    if (val.substring(i_val,i_val+token.length)!=token) {return 0;}
    else {i_val+=token.length;}
    }
    }
    // If there are any trailing characters left in the value, it doesn't match
    if (i_val != val.length) { return 0; }
    // Is date valid for month?
    if (month==2) {
    // Check for leap year
    if ( ( (year%4==0)&&(year%100 != 0) ) || (year%400==0) ) { // leap year
    if (date > 29){ return 0; }
    }
    else { if (date > 28) { return 0; } }
    }
    if ((month==4)||(month==6)||(month==9)||(month==11)) {
    if (date > 30) { return 0; }
    }
    // Correct hours value
    if (hh<12 && ampm=="PM") { hh=hh-0+12; }
    else if (hh>11 && ampm=="AM") { hh-=12; }
    var newdate=new Date(year,month-1,date,hh,mm,ss);
    return newdate.getTime();
    }// ------------------------------------------------------------------
    // parseDate( date_string [, prefer_euro_format] )
    //
    // This function takes a date string and tries to match it to a
    // number of possible date formats to get the value. It will try to
    // match against the following international formats, in this order:
    // y-M-d   MMM d, y   MMM d,y   y-MMM-d   d-MMM-y  MMM d
    // M/d/y   M-d-y      M.d.y     MMM-d     M/d      M-d
    // d/M/y   d-M-y      d.M.y     d-MMM     d/M      d-M
    // A second argument may be passed to instruct the method to search
    // for formats like d/M/y (european format) before M/d/y (American).
    // Returns a Date object or null if no patterns match.
    // ------------------------------------------------------------------
    function parseDate(val) {
    var preferEuro=(arguments.length==2)?arguments[1]:false;
    generalFormats=new Array('y-M-d','MMM d, y','MMM d,y','y-MMM-d','d-MMM-y','MMM d');
    monthFirst=new Array('M/d/y','M-d-y','M.d.y','MMM-d','M/d','M-d');
    dateFirst =new Array('d/M/y','d-M-y','d.M.y','d-MMM','d/M','d-M');
    var checkList=new Array('generalFormats',preferEuro?'dateFirst':'monthFirst',preferEuro?'monthFirst':'dateFirst');
    var d=null;
    for (var i=0; i<checkList.length; i++) {
    var l=window[checkList[i]];
    for (var j=0; j<l.length; j++) {
    d=getDateFromFormat(val,l[j]);
    if (d!=0) { return new Date(d); }
    }
    }
    return null;
    }
    ///这是一个很不错的日期操作代码
    ///格式化可以用:formatDate(parseDate("2004-08-04"),"yyyy-M-d")