Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Извлечь функцию из функции (https://javascript.ru/forum/misc/38953-izvlech-funkciyu-iz-funkcii.html)

nerv_ 10.06.2013 14:22

Цитата:

Сообщение от zebra
Почему бы просто не переопределить функцию someFunc?

+

а все остальное ненужые финты ушами

function foo() {
	alert( 1 );
}

function foo() {
	alert( 2 );
}      

foo();

cmd 11.06.2013 06:10

vadim5june, спасибо, буду разбираться. Не могу пока сказать работает или нет решение. В реальных условиях оно пока ведет себя немного не так как хотелось бы. Проблема в том, что success содержит функцию, а строка не может содержать функцию (я поэтому и пытался сделать через объект). Впрочем, думаю разберусь... В любом случае, большое спасибо за помощь и уроки JS - почерпнул для себя новой информации :)

nerv_, представьте, что Вы пишите маленький модуль для большого программного продукта, который регулярно обновляется. И представьте, что функция в которой я хочу изменить 3-4 строки на самом деле состоит из 30-40 строк. Если скопировать всю функцию и переопределить её, то с большой долей возникнет проблема обратной совместимости с новыми версиями.

Выложу "конечный" результат - может кому-то будет интересно.
<!DOCTYPE html>
<head>
<script 
src="http://code.jquery.com/jquery-1.9.1.js"> 
</script>
</head>
<body>
<script>
function someFunc(somevar) {
	somevar = typeof(somevar) != 'undefined' ? somevar : 100;
$.ajax({
		url: 'index.php',
		type: 'post',
		data: 'somevar=' + somevar,
		dataType: 'json',
		success: function(json) {
				}
	});
};

var somevar='somevar';
	
	var str 		= someFunc.toString();
	var str0		= str.split('$.ajax(')[0];
	var stre		= ')';
	var parameters 	= 'var pars=' + str.split('$.ajax(')[1].split('})')[0] + '}'; eval(parameters);
	
	var paramsArray = {};
		for (var u in pars) {
			if (u && pars && u) {
				if (u == 'dataType') {
				
				} 
				else if (u == 'success') {
					paramsArray[u]	= "function() { alert('success!'); }";
				} 
				else if (u == 'url') {
					paramsArray[u]	= pars[u];
				} 
				else if (typeof pars[u] == 'function') { 
					paramsArray[u]	= pars[u].toString();
				} 
				else {
					paramsArray[u]	= pars[u];
				}
			}
		}
		paramsArray['error'] = "function(error) { console.log(error); }"
	
	var pp			= 'alert(100500); $.ajax(' + JSON.stringify(paramsArray) + stre;
	
	str = str.replace(/(\$\.ajax\(\{[\s\S]+\}\);)/gm, pp);

	
	eval(str);

	console.log( someFunc);
	someFunc();
</script>
</body>
</html>

zebra 11.06.2013 09:46

Почему тогда не использовать ajaxSetup, ajaxComplete ?

nerv_ 11.06.2013 20:11

Цитата:

Сообщение от cmd
представьте, что Вы пишите маленький модуль для большого программного продукта

представь, что ты ломаешь инкапсуляцию, заложенную разработчиками продукта

cmd 12.06.2013 06:20

zebra, спасибо, вдохновился у Вас на
$(document).ajaxSend(function(evt, request, settings) {
  console.log("Ajax call on url " + settings.url); // url
  console.log(settings.success); // success function(), но к сожалению это только копия
});


nerv_, из двух зол выбираю. А разработчики в данном случае не "закладывали", а "клали".

UPD: Вот ещё интересное варварство.

danik.js 12.06.2013 07:04

Цитата:

Сообщение от cmd
но к сожалению это только копия

В смысле? А разве функцию можно скопировать?

cmd 12.06.2013 08:46

danik.js, js не моя специализация и я мог неправильно выразиться, но:
$(document).ajaxSend(function(event, xhr, options){
    delete options.success;
    console.log(options.success);   // undefined
});
$.ajax({
    url: "test.html",
    success: function() { console.log("Как бы там ни было, а мы увидим этот текст"); }
});



Помощь по проблеме не нужна. Я воспользовался хаком, который привел в предыдущем посте. Всем большое спасибо за интересные комментарии и помощь.

nerv_ 12.06.2013 11:16

Цитата:

Сообщение от cmd
js не моя специализация

теперь придется говорить, какая твоя специализация :)

danik.js 12.06.2013 13:49

Цитата:

Сообщение от cmd
delete options.success

С чего ты взял что options - тот самый объект, который передали в $.ajax ?

<script src="http://code.jquery.com/jquery-latest.min.js"></script>
<script>
$(document).ajaxSend(function(event, xhr, options){
    alert(options instanceof MyOptions);
    delete options.success;
    console.log(options.success);   // undefined
});

function MyOptions(options) {
    return options;
}
var myOptions = new MyOptions({
    url: "test.html",
    success: function() { console.log("Как бы там ни было, а мы увидим этот текст"); }
});
$.ajax(myOptions);
</script>


Часовой пояс GMT +3, время: 16:52.