Миграция с YUI2 на YUI3 и уже - PullRequest
1 голос
/ 02 февраля 2011

Я хочу перенести javascript на своем сайте с YU2 на YUI3, но я всего лишь плохой программист-любитель и застрял на первой ловушке.

У меня есть следующий код:

MyApp.Core = function() {  
    return {  
        init: function(e, MyAppConfig) {  
            if (MyAppConfig.tabpanels) {  
                MyApp.Core.prepareTabpanels(MyAppConfig.tabpanels);  
            }  
        },  
        prepareTabpanels: function(tabpanels) {  
            // Code here
        }  
    }  
}();  

var MyAppConfig = {  
    "tabpanels":{"ids":["navigation"]}  
};

YAHOO.util.Event.addListener(window, "load", MyApp.Core.init, MyAppConfig);

Как передать объект MyAppConfig в функцию MyApp.Core.init с помощью прослушивателя событий YUI3 "domready"?

Заранее спасибо!

1 Ответ

1 голос
/ 16 февраля 2011

Вы должны быть в состоянии сделать что-то вроде:

var MyApp = {};
    MyApp.Core = function(){ return {  
    init: function(MyAppConfig) {  
        console.log(MyAppConfig);
    },  
        prepareTabpanels: function(tabpanels) {  
    // Code here
    }  
}  
}();

var MyAppConfig = {  
    "tabpanels":{"ids":["navigation"]}  
};

YUI().use('node', 'event', function(Y){
    Y.on('domready', MyApp.Core.init, this, MyAppConfig);
});

Обратите внимание, что событие не передается в качестве первого параметра, это конфигурация.

Y.on принимает параметрыкак <event_type>, <callback_function>, <context>, <params> ..

любой параметр после передачи третьего элемента в функцию обратного вызова, так что MyAppConfig становится первым параметром в вашем init.

РЕДАКТИРОВАТЬ См. Документацию по API YUI3 здесь: http://developer.yahoo.com/yui/3/api/YUI.html#method_on

...