0

この JQuery プラグインhttp://jquerymobile.com/demos/1.0a4.1/experiments/ui-datepicker/を使用してアプリにカレンダーを設定していますが、唯一の問題は mm/dd/yyyy としてフォーマットされていることです。これを変更する方法についていくつかの調査を行いましたが、これまでのところあまり運がありませんでした。

代わりに dd/mm/yyyy としてフォーマットしたいと思います。それを変更するためにいくつかの JavaScript 関数を追加しようとしましたが、これまでのところうまくいきませんでした。

これは私のカレンダーの HTML コードです。

  <form action="#" method="get">
     <div data-role="fieldcontain">
      <label for="date">Date Input:</label>
     <br>
      <input type="date" name="date" id="date" style="width: 50%;" />
     </div>     
    </form>

これは、フォーマットを変更しようとしている JavaScript ですが、うまくいきませんでした:

var date = $('#date').datepicker({ dateFormat: 'dd-mm-yy' }).val();

これまでのところ、これは入力 bbox のプレースホルダーを dd/mm/yyyy に変更するだけで、カレンダーで新しい日付が選択されても変更されません。

これについて何か助けていただければ幸いです。

4

2 に答える 2

1

解決

作業例: http://jsfiddle.net/Gajotres/PMrDn/65/

変更された JavaScript:

/*
* jQuery Mobile Framework : temporary extension to port jQuery UI's datepicker for mobile
* Copyright (c) jQuery Project
* Dual licensed under the MIT or GPL Version 2 licenses.
* http://jquery.org/license
*/
(function($, undefined ) {

    //cache previous datepicker ui method
    var prevDp = $.fn.datepicker;

    //rewrite datepicker
    $.fn.datepicker = function( options ){

        var dp = this;

        //call cached datepicker plugin
        prevDp.call( this, options );

        //extend with some dom manipulation to update the markup for jQM
        //call immediately
        function updateDatepicker(){
            $( ".ui-datepicker-header", dp ).addClass("ui-body-c ui-corner-top").removeClass("ui-corner-all");
            $( ".ui-datepicker-prev, .ui-datepicker-next", dp ).attr("href", "#");
            $( ".ui-datepicker-prev", dp ).buttonMarkup({iconpos: "notext", icon: "arrow-l", shadow: true, corners: true});
            $( ".ui-datepicker-next", dp ).buttonMarkup({iconpos: "notext", icon: "arrow-r", shadow: true, corners: true});
            $( ".ui-datepicker-calendar th", dp ).addClass("ui-bar-c");
            $( ".ui-datepicker-calendar td", dp ).addClass("ui-body-c");
            $( ".ui-datepicker-calendar a", dp ).buttonMarkup({corners: false, shadow: false}); 
            $( ".ui-datepicker-calendar a.ui-state-active", dp ).addClass("ui-btn-active"); // selected date
            $( ".ui-datepicker-calendar a.ui-state-highlight", dp ).addClass("ui-btn-up-e"); // today"s date
            $( ".ui-datepicker-calendar .ui-btn", dp ).each(function(){
                var el = $(this);
                // remove extra button markup - necessary for date value to be interpreted correctly
                el.html( el.find( ".ui-btn-text" ).text() ); 
            });
        };

        //update now
        updateDatepicker();

        // and on click
        $( dp ).click( updateDatepicker );

        //return jqm obj 
        return this;
    };

    //bind to pagecreate to automatically enhance date inputs   
    $(document).on( "pagecreate", ".ui-page",function(){        
        $( "input[type='date'], input:jqmData(type='date')" ).each(function(){
            $(this).after( $( "<div />" ).datepicker({ altField: "#" + $(this).attr( "id" ), showOtherMonths: true, dateFormat: 'dd-mm-yy' }) );
        }); 
    });
})( jQuery );

実装

最初にこのファイルを含めないでください:

<script src="http://jquerymobile.com/demos/1.0a4.1/experiments/ui-datepicker/jquery.ui.datepicker.mobile.js"></script>

この回答に添付されたjavascriptを使用してください。基本的には、新しいバージョンのjQueryと日付形式で動作するように変更されたトップリンクのjavascriptと同じです。別の日付形式が必要な場合は、次の行で手動で変更してください。

$(this).after( $( "<div />" ).datepicker({ altField: "#" + $(this).attr( "id" ), showOtherMonths: true, dateFormat: 'dd-mm-yy' }) );
于 2013-07-30T13:21:20.483 に答える
1

これが解決策です。

var date = $('#date').datepicker({ dateFormat: 'dd-mm-yy' }).val();

次のリンクも確認できます。

http://docs.jquery.com/UI/Datepicker#option-dateFormat

http://docs.jquery.com/UI/Datepicker/formatDate

于 2013-07-30T13:24:44.847 に答える