Javascript.RU

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

Хочу понять применение this в функциях-конструкторах
Здравствуйте!

Объясните, пожалуйста, почему мы не можем в след. коде к объекту methods применить this.methods, а не var.. Хочу разобраться, чтобы появилось понимание логики!

<!DOCTYPE HTML>
<html>
<head>
	<meta charset="utf-8">
</head>
<body>
	
	<script>

	function isNumeric(n) {
		return !isNaN(parseFloat(n)) && isFinite(n);
	}

	function Calculator() {

		var methods = {
			"-": function(a, b) {
				return a - b;
			},
			"+": function(a, b) {
				return a + b;
			}
		};

		this.calculate = function(str) {

			var split = str.split(' '),
				a = split[0],
				op = split[1],
				b = split[2]

			if(!methods[op] || !isNumeric(a) || !isNumeric(b)) {
				return NaN;
			}

			return methods[op](+a, +b);
		}

		this.addMethod = function(name, func) {
			methods[name] = func;
		};
	}
	var calc = new Calculator;

	calc.addMethod("*", function(a, b) {
		return a * b;
	});
	calc.addMethod("/", function(a, b) {
		return a / b;
	});
	calc.addMethod("**", function(a, b) {
		return Math.pow(a, b);
	});

	var result = calc.calculate("2 ** 3");
	alert(result); // 8
	

	</script>
	
</body>
</html>
Ответить с цитированием
  #2 (permalink)  
Старый 29.01.2014, 21:41
Аватар для danik.js
Профессор
Отправить личное сообщение для danik.js Посмотреть профиль Найти все сообщения от danik.js
 
Регистрация: 11.09.2010
Сообщений: 8,804

Сообщение от cherrypashka
почему мы не можем
А ты пробовал хоть?
__________________
В личку только с интересными предложениями
Ответить с цитированием
  #3 (permalink)  
Старый 29.01.2014, 22:23
Интересующийся
Отправить личное сообщение для cherrypashka Посмотреть профиль Найти все сообщения от cherrypashka
 
Регистрация: 29.01.2014
Сообщений: 22

Да, пробовал!
Можете объяснить?
Ответить с цитированием
  #4 (permalink)  
Старый 29.01.2014, 22:36
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

<!DOCTYPE HTML>
<html>
<head>
	<meta charset="utf-8">
</head>
<body>

	<script>

	function isNumeric(n) {
		return !isNaN(parseFloat(n)) && isFinite(n);
	}

	function Calculator() {

		this.methods = {
			"-": function(a, b) {
				return a - b;
			},
			"+": function(a, b) {
				return a + b;
			}
		};

		this.calculate = function(str) {

			var split = str.split(' '),
				a = split[0],
				op = split[1],
				b = split[2]

			if(!this.methods[op] || !isNumeric(a) || !isNumeric(b)) {
				return NaN;
			}

			return this.methods[op](+a, +b);
		}

		this.addMethod = function(name, func) {
			this.methods[name] = func;
		};
	}
	var calc = new Calculator;

	calc.addMethod("*", function(a, b) {
		return a * b;
	});
	calc.addMethod("/", function(a, b) {
		return a / b;
	});
	calc.addMethod("**", function(a, b) {
		return Math.pow(a, b);
	});

	var result = calc.calculate("2 ** 3");
	alert(result); // 8


	</script>

</body>
</html>
Ответить с цитированием
  #5 (permalink)  
Старый 29.01.2014, 22:55
Интересующийся
Отправить личное сообщение для cherrypashka Посмотреть профиль Найти все сообщения от cherrypashka
 
Регистрация: 29.01.2014
Сообщений: 22

Спасибо большое! Так и делал, как вы, видимо была неточность!
А можете объяснить, почему в примере используется var methods?
И ещё: при создании объекта calc где находится var methods.. в объекте calc?
Ответить с цитированием
  #6 (permalink)  
Старый 30.01.2014, 04:14
Аватар для danik.js
Профессор
Отправить личное сообщение для danik.js Посмотреть профиль Найти все сообщения от danik.js
 
Регистрация: 11.09.2010
Сообщений: 8,804

Сообщение от cherrypashka
видимо была неточность
Для выявления неточностей есть F12 (консоль ошибок).
Сообщение от cherrypashka
почему в примере используется var methods
По той же причине, что и var split, a, op, b - это локальные переменные.
Эт такой способ сделать приватные свойства объекта в JS.
Сообщение от cherrypashka
где находится var methods.. в объекте calc?
Это локальная переменная. "Находится" в closure функции Calculator:
__________________
В личку только с интересными предложениями
Ответить с цитированием
  #7 (permalink)  
Старый 30.01.2014, 04:54
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

danik.js,
с картинками оно интереснее -- скопировать код - запустить локально -- поискать в Sources консоли -- поставить брекпоинт на первом применении метода и справа развернуть Scope - тока бы незабыть --- хмм только у меня никаких точек .......... в консоли нет?

Последний раз редактировалось рони, 30.01.2014 в 04:56.
Ответить с цитированием
  #8 (permalink)  
Старый 30.01.2014, 05:18
Аватар для danik.js
Профессор
Отправить личное сообщение для danik.js Посмотреть профиль Найти все сообщения от danik.js
 
Регистрация: 11.09.2010
Сообщений: 8,804

Сообщение от рони
хмм только у меня никаких точек .......... в консоли нет?
Что-то я не пойму о каких точках речь. И вкладка Console в данном случае не нужна. Только вкладка Sources.

Еще можно в коде прям прописать директиву debugger;, и тогда, при выполнении кода, отладчик автоматически поставится на паузу на строке с директивой.

рони, разобравшись с отладчиком, тебе станет в разы проще работать с кодом. Помню свой восторг, когда осознал всю силу отладчика
__________________
В личку только с интересными предложениями
Ответить с цитированием
  #9 (permalink)  
Старый 30.01.2014, 09:52
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

danik.js,
на скриншоте во всех строках кода точки например последняя строка........}
Сообщение от danik.js
Помню свой восторг
мечта)))
Ответить с цитированием
  #10 (permalink)  
Старый 30.01.2014, 15:16
Аватар для danik.js
Профессор
Отправить личное сообщение для danik.js Посмотреть профиль Найти все сообщения от danik.js
 
Регистрация: 11.09.2010
Сообщений: 8,804

рони, это пробелы отображаются.
Settings (правый нижний угол - шестерня) -> General -> Sources -> Show whitespace characters
__________________
В личку только с интересными предложениями
Ответить с цитированием
Ответ



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

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


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Хочу понять, где ошибка duron Ваши сайты и скрипты 19 05.02.2010 14:46