Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Изменение массива функцией (https://javascript.ru/forum/misc/40246-izmenenie-massiva-funkciejj.html)

Айvan 29.07.2013 16:24

Изменение массива функцией
 
Здравствуйте! Хотел сделать чтобы при нажатии кнопки менялся цвет объекта. Например 3 цвета и при нажатии на кнопку они меняются по кругу(одно нажатие - смена одного цвета, второе - следующий цвет и т.д.)

Долго дуплил, писал длинные коды, ничего не работало! В итоге понял, что проблема с функцией!
<button onClick="nu()">Надпись</button>

<script>


	var hy = ['1', '2', '3'];

function nu(huy) {

	hut = hy.splice(0, 1);
	
	alert(hy);
}
</script>

если вынести массив из функции, как на примере выше, то функция его не видит. Если объявить массив в самой функции, то при каждом нажатии массив обновляется и всегда отвечает "2,3".
Как сделать чтобы получить данные из массива и внести изменения в массив??

function color2() {
	
	
    var color = ['1', '2', '3'];
    var cString = color.join();
    var cStrigIf = cString.indexOf(i);
    var colorId = document.getElementById("square");
    var i = 1;
	
	
	for (var i = 1;; i++) {
		
		if (cStringIf(i) == true) {
			color.splice(0, 1);
			return i;
		}
        else {
                continue;
        }
}
	
	
		
		color.splice(i-1, 0, i);
		
		switch(i) {
			case 1 :
			colorId.style.backgroundColor = "white"
			;
			break;
			
			case 2 :
			colorId.style.backgroundColor = "gold"
			;
			break;
			case 3 :
			colorId.style.backgroundColor = "lime"
			;
			break;
		}
		
		if (i > 3) {
			
			color.splice(0);
		}
	
}


Вот, так я представлял "рабочий" код, но все оказалось сложно из-за моих плохих знаний языка. Но я только начинаю его учить и решил сделать такую программу, думая, что все просто!

skrudjmakdak 29.07.2013 16:28

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"> 
<html> <head>

</head> 
<body> 
<div style="width: 100px; height: 100px; background-color: red;"></div>

	<script type="text/javascript" src="http://code.jquery.com/jquery-1.10.2.min.js"></script>
	<script type="text/javascript">
var colors = ['red', 'silver', 'yellow'];
var index = 0;

$('div').click(function()
	{
	index++;
	if (index == colors.length)
		index = 0;
	$(this).css('background', colors[index]);
	});
	</script>
</body> 
</html>

Айvan 29.07.2013 16:34

Спасибо! но тут на jquery, а его я тем более не знаю! Нужно порыться в гугле и разобрать код. Еще раз спасибо! А на чистом JS можно реализовать?

skrudjmakdak 29.07.2013 16:37

та какая разница с jquery, без него.. код сильно не изменится:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"> 
<html> <head>

</head> 
<body> 
<div style="width: 100px; height: 100px; background-color: red;" onclick="divClick(this);"></div>

	<script type="text/javascript" src="http://code.jquery.com/jquery-1.10.2.min.js"></script>

	<script type="text/javascript">
var colors = ['red', 'silver', 'yellow'];
var index = 0;

function divClick(ths)
	{
	index++;
	if (index == colors.length)
		index = 0;
	ths.style.background = colors[index];
	};
	</script>
</body> 
</html>

Айvan 29.07.2013 16:39

Гигантское спасибо! Просто меня $ всякие смущают! Хочу разобраться, а пока ток простой js учу!
СПАСИБО!

Айvan 29.07.2013 16:48

как сделать управление кнопкой???

danik.js 29.07.2013 17:42

Ты хочешь радиоуправляемую кнопку?

Айvan 29.07.2013 17:54

именно!
я хочу чтобы цвет div менялся при нажатии на кнопку

skrudjmakdak 29.07.2013 19:17

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"> 
<html><head></head> 
<body> 
<div style="width: 100px; height: 100px; background-color: red;" id="block"></div>
<input type="radio" name="color" onclick="divClick(0);" checked="checked"><br>
<input type="radio" name="color" onclick="divClick(1);"><br>
<input type="radio" name="color" onclick="divClick(2);"><br>

	<script type="text/javascript">
var block = document.getElementById('block');
var colors = ['red', 'silver', 'yellow'];
var index = 0;

function divClick(ind)
	{
	block.style.background = colors[ind];
	};
	</script>
</body> 
</html>

Айvan 31.07.2013 07:11

Спасибо, но нужна именно кнопка!


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