Jquery UI Datepicker IE IndexOf ошибка - PullRequest
0 голосов
/ 09 августа 2011

У меня есть этот код на jsFiddle. http://jsfiddle.net/crashdesk/GbUZ9/

Кажется, есть проблема в IE7, где он выдает ошибку:

Объект не поддерживает свойство или метод 'indexOf'

По жизни я не могу это исправить.

Может ли какой-нибудь гуру javascript помочь мне с этим.

Большое спасибо, C

Ответы [ 2 ]

0 голосов
/ 09 августа 2011

Получил, что-то вроде хака. Мне пришлось создать строку для IE7, а также массив для всех других браузеров.

Используемая информация отсюда ... http://minimalbugs.com/questions/share-solve-javascript-error-on-ie-related-to-indexof-function

Надеюсь, это поможет кому-то еще. Уф!

var months = ["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];
            var months2 = "Jan,Feb,Mar,Apr,May,Jun,Jul,Aug,Sep,Oct,Nov,Dec";

                // initialise the "Select date" link
                $('#date-pick')
                    .datePicker(
                        // associate the link with a date picker
                        {
                            createButton:false,
                            endDate:'31/12/2012'
                        }
                    ).bind(
                        // when the link is clicked display the date picker
                        'click',
                        function()
                        {
                            updateSelects($(this).dpGetSelected()[0]);
                            $(this).dpDisplay();
                            return false;
                        }
                    ).bind(
                        // when a date is selected update the SELECTs
                        'dateSelected',
                        function(e, selectedDate, $td, state)
                        {
                            updateSelects(selectedDate);
                        }
                    ).bind(
                        'dpClosed',
                        function(e, selected)
                        {
                            updateSelects(selected[0]);
                        }
                    );

                var updateSelects = function (selectedDate)
                {
                    var selectedDate = new Date(selectedDate);
                    $('#d option[value=' + selectedDate.getDate() + ']').attr('selected', 'selected');
                    $('#m option[value=' + (months[selectedDate.getMonth()]) + '-' +  (selectedDate.getFullYear()) + ']').attr('selected', 'selected');
                }
                // listen for when the selects are changed and update the picker
                $('#d, #m')
                    .bind(
                        'change',
                        function()
                        {
                            var d = new Date(
                                        $('#m').val().split("-")[1],
                                        months2.indexOf($('#m').val().split("-")[0]),
                                        $('#d').val()
                                    );
                            $('#date-pick').dpSetSelected(d.asString());

                        }
                    );

                // default the position of the selects to today
                var today = new Date();
                updateSelects(today.getTime());

                // and update the datePicker to reflect it...
                $('#d').trigger('change');
        }
0 голосов
/ 09 августа 2011
...