From 0df4483c752fbdca048fef3d8f660fb72f772345 Mon Sep 17 00:00:00 2001 From: scythianfuego Date: Tue, 23 Apr 2013 14:00:44 +0400 Subject: [PATCH] fix bug with some of links already bound replaces if any target has data-address skip binding events with if target already has data-address skip it probably will fix issue #171 --- src/jquery.address.js | 54 ++++++++++++++++++++++--------------------- 1 file changed, 28 insertions(+), 26 deletions(-) diff --git a/src/jquery.address.js b/src/jquery.address.js index 8e17f18..a008daf 100644 --- a/src/jquery.address.js +++ b/src/jquery.address.js @@ -566,32 +566,34 @@ })(); $.fn.address = function(fn) { - if (!this.data('address')) { - this.on('click', function(e) { - if (e.shiftKey || e.ctrlKey || e.metaKey || e.which == 2) { - return true; - } - var target = e.currentTarget; - if ($(target).is('a')) { - e.preventDefault(); - var value = fn ? fn.call(target) : - /address:/.test($(target).attr('rel')) ? $(target).attr('rel').split('address:')[1].split(' ')[0] : - $.address.state() !== undefined && !/^\/?$/.test($.address.state()) ? - $(target).attr('href').replace(new RegExp('^(.*' + $.address.state() + '|\\.)'), '') : - $(target).attr('href').replace(/^(#\!?|\.)/, ''); - $.address.value(value); - } - }).on('submit', function(e) { - var target = e.currentTarget; - if ($(target).is('form')) { - e.preventDefault(); - var action = $(target).attr('action'), - value = fn ? fn.call(target) : (action.indexOf('?') != -1 ? action.replace(/&$/, '') : action + '?') + - $(target).serialize(); - $.address.value(value); - } - }).data('address', true); - } + $(this).each(function(index) { + if (!$(this).data('address')) { + $(this).on('click', function(e) { + if (e.shiftKey || e.ctrlKey || e.metaKey || e.which == 2) { + return true; + } + var target = e.currentTarget; + if ($(target).is('a')) { + e.preventDefault(); + var value = fn ? fn.call(target) : + /address:/.test($(target).attr('rel')) ? $(target).attr('rel').split('address:')[1].split(' ')[0] : + $.address.state() !== undefined && !/^\/?$/.test($.address.state()) ? + $(target).attr('href').replace(new RegExp('^(.*' + $.address.state() + '|\\.)'), '') : + $(target).attr('href').replace(/^(#\!?|\.)/, ''); + $.address.value(value); + } + }).on('submit', function(e) { + var target = e.currentTarget; + if ($(target).is('form')) { + e.preventDefault(); + var action = $(target).attr('action'), + value = fn ? fn.call(target) : (action.indexOf('?') != -1 ? action.replace(/&$/, '') : action + '?') + + $(target).serialize(); + $.address.value(value); + } + }).data('address', true); + } + }); return this; };