Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 08.12.2011, 11:51
Аватар для Dudo4nick
Интересующийся
Отправить личное сообщение для Dudo4nick Посмотреть профиль Найти все сообщения от Dudo4nick
 
Регистрация: 20.07.2011
Сообщений: 23

Аналог toggle в javascript?
А есть аналог toggle в javascript? Ну чтобы по первому клику на некий элемент срабатывала одна функция, а по повторному - совершенно другая? И дальше чередование.
Ответить с цитированием
  #2 (permalink)  
Старый 08.12.2011, 13:44
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,228

Сообщение от Dudo4nick
А есть аналог toggle в javascript?
А содержимое toggle() это уже не javascript?
Ответить с цитированием
  #3 (permalink)  
Старый 08.12.2011, 15:00
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

вот написал маленький пример того, как это можно сделать.
сначала решил проблему через свои свойства (element.i), но потом вспомнил, что это плохо и чревато утечкой памяти к некоторых браузерах и решил задачу через имитацию jQuery.data
/*
*  toggle : при срабатывании события будет сначала исполнять первую функцию,
* потому вторую и т.д по порядку
*
* Аргументы :
*   element - элемент, который будет реагировать на события
*   event - тип события.(без 'on')
*   funcArr - массив функций
*/
function toggle(element, event, funcArr){
    // проводим нужную инициализацию

    // мини база данных для элементов, их событий и индексов.
    var BD = [];

    // имеем ли дело с ie
    var ie = /*@cc_on!@*/0;
    
    //исполняет нужную ф-ю из массива
    function handler(e){
        // находим наш элемент
        var element = ie ? window.event.srcElement:e.target;
        
        // ищем сохраненный индекс и извлекаем инфу для этого эл-а из миниБД
        var index = element.getAttribute('id-toggle');
        var elBD = BD[index];
        
        // проверяем наличие исполняем ф-ю из списка с текущим индексом.
        if(elBD.i == elBD.arr.length){ // вышли за массив. начинаем с начала
            elBD.i = 0;
        } 
        elBD.arr[elBD.i].call(element, ie ? event:e);//исполняем ф.ю
        elBD.i += 1; // увеличиваем индекс
    }

    // переназначаем ф-ю
    toggle = function(element, event, funcArr){
        var elBD = {};

        // индекс функции, которая исполнится. 
        elBD.i = 0;
        // массив функций для обхода
        elBD.arr = funcArr;

        var BDindex = BD.push(elBD) - 1; // возвратит новую длину. минус 1 - последний член массива.

        // сохраняем индекс для связки с базой
        element.setAttribute("id-toggle", BDindex);

        // назначаем эл-у обработчик по-умолчанию.
        if(ie){
            element.attachEvent(event, handler);
        } else {
            element.addEventListener(event, handler, false);
        }
    }

    // вызываем изменённую функцию
    toggle(element, event, funcArr);
}

писал на одном дыхании!! потом проверил код - и о чудо, он работает!

пример использования : jsfiddle

и ещё тут :
<script>
function toggle(h,c,i){function f(b){var d=e?event.srcElement:b.target,a=d.getAttribute("id-toggle"),a=g[a];if(a.i==a.arr.length)a.i=0;a.arr[a.i].call(d,e?c:b);a.i+=1}debugger;var g=[],e=0;toggle=function(b,d,a){var c={i:0};c.arr=a;a=g.push(c)-1;b.setAttribute("id-toggle",a);e?b.attachEvent(d,f):b.addEventListener(d,f,!1)};toggle(h,c,i)};
</script>
<div id="a" style="padding:10px;border:2px black solid;border-color:white;">kkjjhkjhlkjh</div>
<script>
toggle(document.getElementById("a"),"click",[function(){this.style.borderColor="red"},function(){this.style.borderColor="green"}]);
</script>

Последний раз редактировалось melky, 08.12.2011 в 23:37.
Ответить с цитированием
  #4 (permalink)  
Старый 08.12.2011, 17:55
что-то знаю
Отправить личное сообщение для devote Посмотреть профиль Найти все сообщения от devote
 
Регистрация: 24.05.2009
Сообщений: 5,176

Сообщение от melky
var ie = /*@cc_on!@*/0;
а на последних версиях ИЕ это раздве не сработает? Ведь вроде как с ИЕ9 уже работает addEventListener
Ответить с цитированием
  #5 (permalink)  
Старый 08.12.2011, 22:15
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

по идее, оно сработает на всех ie ..
Ответить с цитированием
  #6 (permalink)  
Старый 08.12.2011, 23:09
что-то знаю
Отправить личное сообщение для devote Посмотреть профиль Найти все сообщения от devote
 
Регистрация: 24.05.2009
Сообщений: 5,176

Сообщение от melky Посмотреть сообщение
по идее, оно сработает на всех ie ..
Ну дык и зачем это юзать, не проще сделать?
if ( document.addEventListener ) {}
Ответить с цитированием
  #7 (permalink)  
Старый 08.12.2011, 23:12
что-то знаю
Отправить личное сообщение для devote Посмотреть профиль Найти все сообщения от devote
 
Регистрация: 24.05.2009
Сообщений: 5,176

Сообщение от melky
var element = ie ? e.srcElement:e.target;
И это у тебя работать не будет, надо:
var element = e ? e.target : window.event.srcElement;
Да и других там пару строк надо поправить
Ответить с цитированием
  #8 (permalink)  
Старый 08.12.2011, 23:40
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

Сообщение от devote Посмотреть сообщение
Ну дык и зачем это юзать, не проще сделать?
if ( document.addEventListener ) {}
наверное, в связи с ie 9 надо будет перейти на такую конструкцию.

... а e.target в 9 ие работает? если так, то можно будет сделать маленькую помарочку

Код:
для ие < 9 нет событийной модели 2, поэтому будет использоваться attachEvent и window.event.srcElement.
Сообщение от devote Посмотреть сообщение
И это у тебя работать не будет, надо:
var element = e ? e.target : window.event.srcElement;
Да и других там пару строк надо поправить
поправил. я вспомнил про этот косяк, когда уже вышел из дома (код писал перед уходом).

пара-тройка строк для фиксации ивента.. нафиг надо, я не ставил пред собой цель написать всё разом.
Ответить с цитированием
  #9 (permalink)  
Старый 03.05.2012, 19:29
Аватар для x-yuri
Отправить личное сообщение для x-yuri Посмотреть профиль Найти все сообщения от x-yuri
 
Регистрация: 27.12.2008
Сообщений: 4,201

а вы в курсе, что в ie 10 собираются отменить conditional comments? Правда непонятно, касается ли это jscript. Ну и к слову, target должно работать в ie 9.
Ответить с цитированием
  #10 (permalink)  
Старый 03.05.2012, 20:03
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

Сообщение от x-yuri Посмотреть сообщение
а вы в курсе, что в ie 10 собираются отменить conditional comments? Правда непонятно, касается ли это jscript. Ну и к слову, target должно работать в ie 9.
в коде в переменной ie будет true в ie<9 (если не ошибаюсь) - а сама она написана для использования ie api. в ie > 8 она будет false, а в них уже поддеживаются методы w3c.

всё схвачено
Ответить с цитированием
Ответ



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

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


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Есть ли аналог nl2br в javascript ? saturn Элементы интерфейса 7 13.11.2011 14:02
Есть ли в JavaScript аналог функции exec() из php? lorddarkside Общие вопросы Javascript 3 22.12.2010 12:37
Последние книги по JavaScript! monolithed Учебные материалы 7 26.10.2010 19:40
Выдвет ошибку JavaScript Ромио Opera, Safari и др. 4 21.10.2010 20:34
Есть ли на JavaScript аналог PHP функции include?) FirstFrost Общие вопросы Javascript 3 13.07.2010 10:13