Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 22.04.2010, 19:00
Аспирант
Отправить личное сообщение для tazododu Посмотреть профиль Найти все сообщения от tazododu
 
Регистрация: 18.02.2010
Сообщений: 90

Пишу хитрый unload помогите разобраться
написал окошко потипу Confirm, но никак не могу сделать ожидание результата обработчика

var edit = 0;
$(window).unload( function () { 
		if(edit == 1)
		{
			var go = '';
			jSave("Возможно были внесены изменения.<br />Сохранить изменения?", '', "Внимание!", function(r){ 
				if($r == 'go') return go = 1;
				else return go = 0;
			});
			
			alert("go");

			if(go == 1) return true;
			else return false;
		}
		else return true;
	} );


jSave выводит окошко с тремя кнопочками сохр не схор и отмена, не сохр возвращает 'go' после которого должен продолжиться unload.
заметил, что alert выполняется до того, как jSave вернет результат.

у кого какие соображения?
Ответить с цитированием
  #2 (permalink)  
Старый 23.04.2010, 15:02
Аватар для Даниэль Ноубл
Интересующийся
Отправить личное сообщение для Даниэль Ноубл Посмотреть профиль Найти все сообщения от Даниэль Ноубл
 
Регистрация: 21.04.2010
Сообщений: 12

А что происходит внутри jSave в твоем коде ни чего не видно искать надо там
Ответить с цитированием
  #3 (permalink)  
Старый 23.04.2010, 18:32
Профессор
Отправить личное сообщение для exec Посмотреть профиль Найти все сообщения от exec
 
Регистрация: 21.01.2010
Сообщений: 1,022

Зачем return перед присваиванием переменной?
Ответить с цитированием
  #4 (permalink)  
Старый 23.04.2010, 19:49
Аватар для Gozar
Отправить личное сообщение для Gozar Посмотреть профиль Найти все сообщения от Gozar
 
Регистрация: 07.06.2007
Сообщений: 7,504

написать всё внутри функции
function(r){
	                if($r == 'go') return go = 1;
	                else return go = 0;
	            });


ну или присвоить результат так:
var go = jSave("Возможно были внесены изменения.<br />Сохранить изменения?", '', "Внимание!", function(r){
                if($r == 'go') return 1;
	                else return 0;
	            });


а вообще у вас go сначала строка, потом цифра, а затем булево, это ну прямо круто как-то, осталось его еще объектом сделать и будет вообще класс.

Последний раз редактировалось Gozar, 24.04.2010 в 09:13.
Ответить с цитированием
  #5 (permalink)  
Старый 23.04.2010, 20:17
Аватар для Gozar
Отправить личное сообщение для Gozar Посмотреть профиль Найти все сообщения от Gozar
 
Регистрация: 07.06.2007
Сообщений: 7,504

единственное чего не понимаю что в себе содержит r и с чем сравнивается 'go' - что это -> $r?
Ответить с цитированием
  #6 (permalink)  
Старый 24.04.2010, 13:49
Аспирант
Отправить личное сообщение для tazododu Посмотреть профиль Найти все сообщения от tazododu
 
Регистрация: 18.02.2010
Сообщений: 90

ну может я чего и перемудрил) просто нужно было сделать стилизованный конфирм

я взял jQuery Alert Dialogs Plugin и дописал туда свою функцию jSave, она как бы выводит диалоги о сохранении.

вот что происходит внутри jSave:
(function($) {
	
	$.alerts = {
		
		// These properties can be read/written by accessing $.alerts.propertyName from your scripts at any time
		
		verticalOffset: -75,                // vertical offset of the dialog from center screen, in pixels
		horizontalOffset: 0,                // horizontal offset of the dialog from center screen, in pixels/
		repositionOnResize: true,           // re-centers the dialog on window resize
		overlayOpacity: .01,                // transparency level of overlay
		overlayColor: '#FFF',               // base color of overlay
		draggable: true,                    // make the dialogs draggable (requires UI Draggables plugin)
		okButton: '&nbsp;OK&nbsp;',         // text for the OK button
		cancelButton: '&nbsp;Cancel&nbsp;', // text for the Cancel button
		dialogClass: null,                  // if specified, this class will be applied to all dialogs
		
		// Public methods
		
		alert: function(message, title, callback) {
			if( title == null ) title = 'Alert';
			$.alerts._show(title, message, null, 'alert', function(result) {
				if( callback ) callback(result);
			});
		},
		
		confirm: function(message, title, callback) {
			if( title == null ) title = 'Confirm';
			$.alerts._show(title, message, null, 'confirm', function(result) {
				if( callback ) callback(result);
			});
		},
			
		prompt: function(message, value, title, callback) {
			if( title == null ) title = 'Prompt';
			$.alerts._show(title, message, value, 'prompt', function(result) {
				if( callback ) callback(result);
			});
		},
		
		save: function(message, value, title, callback) {
			if( title == null ) title = 'Save';
			$.alerts._show(title, message, value, 'save', function(result) {
				if( callback ) callback(result);
			});
		},
		
		// Private methods
		
		_show: function(title, msg, value, type, callback) {
			
			$.alerts._hide();
			$.alerts._overlay('show');
			
			$("BODY").append(
			  '<div id="popup_container">' +
			    '<h1 id="popup_title"></h1>' +
			    '<div id="popup_content">' +
			      '<div id="popup_message"></div>' +
				'</div>' +
			  '</div>');
			
			if( $.alerts.dialogClass ) $("#popup_container").addClass($.alerts.dialogClass);
			
			// IE6 Fix
			var pos = ($.browser.msie && parseInt($.browser.version) <= 6 ) ? 'absolute' : 'fixed'; 
			
			$("#popup_container").css({
				position: pos,
				zIndex: 99999,
				padding: 0,
				margin: 0
			});
			
			$("#popup_title").text(title);
			$("#popup_content").addClass(type);
			$("#popup_message").text(msg);
			$("#popup_message").html( $("#popup_message").text().replace(/\n/g, '<br />') );
			
			$("#popup_container").css({
				minWidth: $("#popup_container").outerWidth(),
				maxWidth: $("#popup_container").outerWidth()
			});
			
			$.alerts._reposition();
			$.alerts._maintainPosition(true);
			
			switch( type ) {
				case 'alert':
					$("#popup_message").after('<div id="popup_panel"><input type="button" value="' + $.alerts.okButton + '" id="popup_ok" /></div>');
					$("#popup_ok").click( function() {
						$.alerts._hide();
						callback(true);
					});
					$("#popup_ok").focus().keypress( function(e) {
						if( e.keyCode == 13 || e.keyCode == 27 ) $("#popup_ok").trigger('click');
					});
				break;
				case 'confirm':
					$("#popup_message").after('<div id="popup_panel"><input type="button" value="' + $.alerts.okButton + '" id="popup_ok" /> <input type="button" value="' + $.alerts.cancelButton + '" id="popup_cancel" /></div>');
					$("#popup_ok").click( function() {
						$.alerts._hide();
						if( callback ) callback(true);
					});
					$("#popup_cancel").click( function() {
						$.alerts._hide();
						if( callback ) callback(false);
					});
					$("#popup_ok").focus();
					$("#popup_ok, #popup_cancel").keypress( function(e) {
						if( e.keyCode == 13 ) $("#popup_ok").trigger('click');
						if( e.keyCode == 27 ) $("#popup_cancel").trigger('click');
					});
				break;
				case 'prompt':
					$("#popup_message").append('<br /><input type="text" size="30" id="popup_prompt" />').after('<div id="popup_panel"><input type="button" value="' + $.alerts.okButton + '" id="popup_ok" /> <input type="button" value="' + $.alerts.cancelButton + '" id="popup_cancel" /></div>');
					$("#popup_prompt").width( $("#popup_message").width() );
					$("#popup_ok").click( function() {
						var val = $("#popup_prompt").val();
						$.alerts._hide();
						if( callback ) callback( val );
					});
					$("#popup_cancel").click( function() {
						$.alerts._hide();
						if( callback ) callback( null );
					});
					$("#popup_prompt, #popup_ok, #popup_cancel").keypress( function(e) {
						if( e.keyCode == 13 ) $("#popup_ok").trigger('click');
						if( e.keyCode == 27 ) $("#popup_cancel").trigger('click');
					});
					if( value ) $("#popup_prompt").val(value);
					$("#popup_prompt").focus().select();
				break;
				case 'save':
					$("#popup_message").append('<br />').after('<div id="popup_panel"><a class="btn" id="popup_save"href="#"><span><span>Сохранить</span></span></a> <a class="btn" id="popup_no_save"href="#"><span><span>Не сохранять</span></span></a> <a class="btn" id="popup_cancel"href="#"><span><span>Отменить</span></span></a></div>');
					$("#popup_no_save").click(function(){
						$.alerts._hide();
						if( callback ) callback( 'go' );
						return false;
					});
					$("#popup_save").click(function(){
						$.alerts._hide();
						$("#sbmtgoodss1").click();
						return false;
					});
					$("#popup_cancel").click( function() {
						$.alerts._hide();
						if( callback ) callback( null );
						return false;
					});
					$("#popup_no_save, #popup_save, #popup_cancel").keypress( function(e) {
						if( e.keyCode == 27 ) $("#popup_cancel").trigger('click');
					});

				break;
			}
			
			// Make draggable
			if( $.alerts.draggable ) {
				try {
					$("#popup_container").draggable({ handle: $("#popup_title") });
					$("#popup_title").css({ cursor: 'move' });
				} catch(e) { /* requires jQuery UI draggables */ }
			}
		},
		
		_hide: function() {
			$("#popup_container").remove();
			$.alerts._overlay('hide');
			$.alerts._maintainPosition(false);
		},
		
		_overlay: function(status) {
			switch( status ) {
				case 'show':
					$.alerts._overlay('hide');
					$("BODY").append('<div id="popup_overlay"></div>');
					$("#popup_overlay").css({
						position: 'absolute',
						zIndex: 99998,
						top: '0px',
						left: '0px',
						width: '100%',
						height: $(document).height(),
						background: $.alerts.overlayColor,
						opacity: $.alerts.overlayOpacity
					});
				break;
				case 'hide':
					$("#popup_overlay").remove();
				break;
			}
		},
		
		_reposition: function() {
			var top = (($(window).height() / 2) - ($("#popup_container").outerHeight() / 2)) + $.alerts.verticalOffset;
			var left = (($(window).width() / 2) - ($("#popup_container").outerWidth() / 2)) + $.alerts.horizontalOffset;
			if( top < 0 ) top = 0;
			if( left < 0 ) left = 0;
			
			// IE6 fix
			if( $.browser.msie && parseInt($.browser.version) <= 6 ) top = top + $(window).scrollTop();
			
			$("#popup_container").css({
				top: top + 'px',
				left: left + 'px'
			});
			$("#popup_overlay").height( $(document).height() );
		},
		
		_maintainPosition: function(status) {
			if( $.alerts.repositionOnResize ) {
				switch(status) {
					case true:
						$(window).bind('resize', $.alerts._reposition);
					break;
					case false:
						$(window).unbind('resize', $.alerts._reposition);
					break;
				}
			}
		}
		
	}
	
	// Shortuct functions
	jAlert = function(message, title, callback) {
		$.alerts.alert(message, title, callback);
	}
	
	jConfirm = function(message, title, callback) {
		$.alerts.confirm(message, title, callback);
	};
		
	jPrompt = function(message, value, title, callback) {
		$.alerts.prompt(message, value, title, callback);
	};
	
	jSave = function(message, value, title, callback) {
		$.alerts.save(message, value, title, callback);
	};
	
})(jQuery);


и вообще, я как бы не в первый раз сталкиваюсь с тем, что следующая строка начинает обрабатываться не дождавшись обработки предыдущей(
Ответить с цитированием
  #7 (permalink)  
Старый 24.04.2010, 13:51
Аспирант
Отправить личное сообщение для tazododu Посмотреть профиль Найти все сообщения от tazododu
 
Регистрация: 18.02.2010
Сообщений: 90

чет слишком много запостил, вот основное:
case 'save':
					$("#popup_message").append('<br />').after('<div id="popup_panel"><a class="btn" id="popup_save"href="#"><span><span>Сохранить</span></span></a> <a class="btn" id="popup_no_save"href="#"><span><span>Не сохранять</span></span></a> <a class="btn" id="popup_cancel"href="#"><span><span>Отменить</span></span></a></div>');
					$("#popup_no_save").click(function(){
						$.alerts._hide();
						if( callback ) callback( 'go' );
						return false;
					});
					$("#popup_save").click(function(){
						$.alerts._hide();
						$("#sbmtgoodss1").click();
						return false;
					});
					$("#popup_cancel").click( function() {
						$.alerts._hide();
						if( callback ) callback( null );
						return false;
					});
					$("#popup_no_save, #popup_save, #popup_cancel").keypress( function(e) {
						if( e.keyCode == 27 ) $("#popup_cancel").trigger('click');
					});

				break;


var r - то, что отдает функция jSave
Ответить с цитированием
  #8 (permalink)  
Старый 24.04.2010, 22:20
Новичок на форуме
Отправить личное сообщение для Kolyaj Посмотреть профиль Найти все сообщения от Kolyaj
 
Регистрация: 19.02.2008
Сообщений: 9,177

tazododu,
ключевое слово: асинхронность. Если лень вникать, просто учтите -- при unload только стандартный confirm, больше ничто не поможет.
Ответить с цитированием
Ответ



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

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


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Помогите разобраться с кодом. TheWanderer Общие вопросы Javascript 10 17.04.2010 13:41
Помогите пожалуйста разобраться Kupu4 Ваши сайты и скрипты 0 21.01.2010 10:44
Помогите разобраться с галереей IMAGIN yana_studio Общие вопросы Javascript 4 12.12.2009 17:24
Помогите разобраться с задачей (поиск строки) Absinthe Ваши сайты и скрипты 6 07.12.2009 09:17
Помогите разобраться со скриптом! Чайник Элементы интерфейса 1 13.03.2009 23:57