Ошибка «$ .______ не является функцией». Что случилось? - PullRequest
0 голосов
/ 29 июня 2011

Я пытаюсь добавить ротатор изображений на свой сайт, но по какой-то причине firebug сообщает мне, что функция, которую мне нужно вызвать, чтобы запустить ротатор, не определена.Мой файл jQuery загружается очень хорошо, и скрипт ротатора изображения загружается, поэтому я не уверен, что не так.Сайт heritage.newcoastmedia.com , но я опубликую скрипт:

;(function($) {
    $.fn.featureList = function(options) {
        var tabs    = $(this);
        var output  = $(options.output);

        new jQuery.featureList(tabs, output, options);

        return this;    
    };

    $.featureList = function(tabs, output, options) {
        function slide(nr) {
            if (typeof nr == "undefined") {
                nr = visible_item + 1;
                nr = nr >= total_items ? 0 : nr;
            }

            tabs.removeClass('current').filter(":eq(" + nr + ")").addClass('current');

            output.stop(true, true).filter(":visible").fadeOut();
            output.filter(":eq(" + nr + ")").fadeIn(function() {
                visible_item = nr;  
            });
        }

        var options         = options || {}; 
        var total_items     = tabs.length;
        var visible_item    = options.start_item || 0;

        options.pause_on_hover      = options.pause_on_hover        || true;
        options.transition_interval = options.transition_interval   || 5000;

        output.hide().eq( visible_item ).show();
        tabs.eq( visible_item ).addClass('current');

        tabs.click(function() {
            if ($(this).hasClass('current')) {
                return false;   
            }

            slide( tabs.index( this) );
        });

        if (options.transition_interval > 0) {
            var timer = setInterval(function () {
                slide();
            }, options.transition_interval);

            if (options.pause_on_hover) {
                tabs.mouseenter(function() {
                    clearInterval( timer );

                }).mouseleave(function() {
                    clearInterval( timer );
                    timer = setInterval(function () {
                        slide();
                    }, options.transition_interval);
                });
            }
        }
    };
});

А вот скрипт запуска ротатора изображения:

<script language="javascript">
    $(document).ready(function() {

        $.featureList(
            $("#tabs li a"),
            $("#output li"), {
                start_item  :   1
            }
        );
    });
</script>

Ответы [ 3 ]

6 голосов
/ 29 июня 2011

Ваш код создает анонимную функцию, но не вызывает ее.

Вам нужно вызвать функцию, добавив (jQuery) в конце.

0 голосов
/ 29 июня 2011

Вы только что немного упустили правильный синтаксис для создания плагина. То, что вы действительно хотите, это:

(function($) {
   $.fn.featureList = function() { // etc; }
   $.featureList = function() { // yet more etc; }
})(jQuery);
0 голосов
/ 29 июня 2011

Вы не можете сделать $.featureList(

См. Chrome error: enter image description here

Плагин необходимо применить к объекту

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...