Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #11 (permalink)  
Старый 20.12.2011, 00:39
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

таки да.
Сообщение от Livanderiaamarum Посмотреть сообщение
я понял что тут происходит, но я не
понял как это связано с кешированием функций?
Сообщение от Livanderiaamarum Посмотреть сообщение
q() при вызове перезаписывает себя, и сохраняет в области видимости w , кэширует, ясно)
я же говорил
Ответить с цитированием
  #12 (permalink)  
Старый 21.12.2011, 12:42
Кандидат Javascript-наук
Отправить личное сообщение для Иваннн Посмотреть профиль Найти все сообщения от Иваннн
 
Регистрация: 31.05.2010
Сообщений: 106

Про варианты функций
"вот этот код как раз это делает"
Вроде не совсем то
Если я правильно понял, то в варианте Melky кэшируется w, и доступен сам объект функции w только через внешнюю функцию, при этом this у w=global obj
у Livanderiaamarum кэшируется тоже w, но this (при обращении через self ссылается на объект хозяин свойвства, то есть q) и объект функции доступен в глобальном пространстве через q.w.
Ответить с цитированием
  #13 (permalink)  
Старый 21.12.2011, 14:03
Аватар для Livanderiaamarum
Профессор
Отправить личное сообщение для Livanderiaamarum Посмотреть профиль Найти все сообщения от Livanderiaamarum
 
Регистрация: 10.12.2011
Сообщений: 290

Сообщение от Иваннн Посмотреть сообщение
в варианте Melky кэшируется w, и доступен сам объект функции w только через внешнюю функцию
вот это я и не понял вначале, я подумал что за бред? где это можно использовать? это же запарывает функцию q()
Ответить с цитированием
  #14 (permalink)  
Старый 21.12.2011, 14:40
Кандидат Javascript-наук
Отправить личное сообщение для Иваннн Посмотреть профиль Найти все сообщения от Иваннн
 
Регистрация: 31.05.2010
Сообщений: 106

Сообщение от Livanderiaamarum Посмотреть сообщение
вот это я и не понял вначале, я подумал что за бред? где это можно использовать? это же запарывает функцию q()
На сколько я понимаю q -это всего лишь ссылка на объект функции. При новом присваивании значения ссылке q ссылка просто начинает указывать на другой объект (на
function(){ return w();}

)
a объект на который ссылалась ссылка до изменения удалился бы, если бы не было вызвано замыкание (из глобального пространства есть ссылка на объект функции, "задекларированный" в виде выражения в другой функции ), а так как замыкание есть, то объект висит в памяти, и единственный способ к нему добраться, т.е к его области видимости - только через новую q.
Как я понимаю операцию можно разделить на две части. Не обязательно изменять саму ссылку q, можно внутренний объект функции привязать к любой переменной (т.е. ссылке, допустим у) видимой в глобальном объекте, а потом q=null или delete q, и работать с у.
Ответить с цитированием
  #15 (permalink)  
Старый 21.12.2011, 14:43
Аватар для Livanderiaamarum
Профессор
Отправить личное сообщение для Livanderiaamarum Посмотреть профиль Найти все сообщения от Livanderiaamarum
 
Регистрация: 10.12.2011
Сообщений: 290

Сообщение от Иваннн Посмотреть сообщение
На сколько я понимаю q -это всего лишь ссылка на объект функции. При новом присваивании значения ссылке q ссылка просто начинает указывать на другой объект
это и запарывает функцию по имени q() и я не могу больше её использовать.

но наверное человек работал ИСХОДЯ ИЗ ДАННОГО МНОЙ примера) и думал что внутри q() не будет ни какого кода кроме w()
Ответить с цитированием
  #16 (permalink)  
Старый 21.12.2011, 15:42
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

Сообщение от Livanderiaamarum Посмотреть сообщение
это и запарывает функцию по имени q() и я не могу больше её использовать.

но наверное человек работал ИСХОДЯ ИЗ ДАННОГО МНОЙ примера) и думал что внутри q() не будет ни какого кода кроме w()
это паттерн такой. и придуман он для того, чтобы не создавать каждый раз что-нибудь (кэшировать) и чтобы не захламлять скоп.

один пример - кеширование объекта настроек по-уолчанию.
function ajax(){

    var def = {
         "async":true
    };

    ajax = function(obj){
        // def сохранён в замыкании
        extend(obj, def);
    };

    ajax.apply(this,arguments);

};

ещё пример - удаление ветви кода при использовании опр. браузера.
// было :
function addScript(url, callback, parent){

    var script = document.createElement("script"),
        // ищем head каждый раз.
        parent = parent || document.getElementsByTagName('head')[0];



     // для IE<9.
    if('\v'=='v'){
        script.type = "text/javascript";
        script.onreadystatechange = function(){
            //this == script, но я буду использовать переменную
            if(script.readyState == "complete" || script.readyState == "loaded"){
                callback();
                // memory leak
                script.onreadystatechange = script.onload = null;
            }
        };
    } else {
        // нормальное поведение.
        script.onload = callback;
    }

    script.src = url;    
    parent.appendChild(script);
};

// стало :
function addScript(){

    // ищется только один раз
    var head = document.getElementsByTagName('head')[0];

    if('\v'=='v') // ie < 9

        addScript = function(url, callback){

            var script = document.createElement('script');

            script.onreadystatechange = function(){
                if(this.readyState == "complete" || this.readyState == "loaded"){
                    callback();
                    script.onreadystatechange = script.onload = null;
                };
            };
            
            script.type = "text/javascript";

            script.src = url;

            head.appendChild(script);
        };

    else 

        addScript = function(url, callback){

            var script = document.createElement("script");

            script.src = url;

            script.onload = callback;

            head.appendChild(script);

        };

    addScript.apply(this, arguments);
};


да, немного больше кода, немного больше запутанность кода. но , если ясно понимать, что тут происходит, всё становится понятным.

не ищется каждый раз head. конечно, в первом случае head можно было сохранить в переменной ещё до функции, но в данном случае мы это не рассматриваем.

во втором случае не просчитывается условие. следует понимать, что в данном случае это мало чего сэкономило, но в функции, в которой каждая строчка является if'ом, проверяющим браузер (или вообще любой другой if), это может сэкономить время. ты же любитель муравьиной оптимизации, Livanderiaamarum ?

во втором случае на выходе получается чистая функция. так сказать, "скомпилированная под конкретный браузер". в этом можно убедиться, вызвав addScript.toString();
Ответить с цитированием
  #17 (permalink)  
Старый 21.12.2011, 15:52
Аватар для Livanderiaamarum
Профессор
Отправить личное сообщение для Livanderiaamarum Посмотреть профиль Найти все сообщения от Livanderiaamarum
 
Регистрация: 10.12.2011
Сообщений: 290

Сообщение от melky Посмотреть сообщение
это паттерн такой. и придуман он для того, чтобы не создавать каждый раз что-нибудь (кэшировать) и чтобы не захламлять скоп.
спасибо, не знал)))) шикарная штука)
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как создать bodyclick код royksopp Общие вопросы Javascript 8 14.10.2011 16:39
АААААААААА!!! Протестируйте пожалуйста код в разных браузерах. выявляем ошибки. prototype Элементы интерфейса 1 22.07.2011 07:47
код странно отрабатывает комбинацию клавиш ffx Общие вопросы Javascript 4 20.01.2011 10:58
какой код клавиши у кнопки cmd у apple demi Events/DOM/Window 2 25.02.2010 11:32
Opera отдаёт неправильный код функциональных клавиш. NT Man Opera, Safari и др. 1 19.01.2010 02:45