1

利用できない日付と週末に利用できない日付の配列を設定しています。

配列:

<script type="text/javascript">//<![CDATA[
var unavailableDates = [];
{foreach $fixed.rows as $row}
    var row = {};
    row['date_from'] = "{$row.fixed_date_from.value}";
    row['date_until'] = "{$row.fixed_date_until.value}";
    row['name'] = "{$row.fixed_name.value} ({$row.fixed_type.value})";
    unavailableDates.push(row);
{/foreach}
//]]></script>

Q1)までの日付のチェックを追加するにはどうすればよいですか。開始日については、以下のように機能していますか?

Q2)各暦日の各日付をループする代わりにin_arrayを使用するようにコードを改善できますか?

var days = ["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"];
var unavailableDays = ["Saturday","Sunday"];

$("#.datePicker").datepicker($.extend(true, {}, $.initDatePickers.defaults, {
    beforeShowDay: function(date) {
        ymd = date.getFullYear() + "-" + ("0"+(date.getMonth()+1)).slice(-2) + "-" + ("0"+date.getDate()).slice(-2);
        day = new Date(ymd).getDay();
        result = null;

        // Check if date in unavailable array or weekend
        for(var i = 0; i < unavailableDates.length; i++){
            if ((ymd == unavailableDates[i].date_from) && $.inArray(days[day], unavailableDays) < 0) {
                return [false,"unavailable",unavailableDates[i].name];
            }
        }

        if(result){
            return result;
        } else {
            return [true, "available", ""];
        }
    } 
}));
4

1 に答える 1

0

オプションを使用しbefreShowDayてデータ配列を解析し、日が選択可能かどうかを判断します

beforeShowDayType:Function(Date date)

関数はパラメータとして日付を取り、この日付が選択可能かどうかを示すtrue / falseに等しい[0] 、デフォルトのプレゼンテーションのCSSクラス名または ""に等しい1 、および[2]の配列を返す必要があります。この日付のオプションのポップアップツールチップ。表示される前に、日付ピッカーで毎日呼び出されます。

于 2012-10-13T13:52:15.250 に答える