26.01.2014, 21:36
|
|
Профессор
|
|
Регистрация: 26.01.2014
Сообщений: 181
|
|
Помогите с выводом блоков
Помогите разобраться, вообщем есть такой код:
В HTML 1 блок #idDiv
Скрипт:
$(document).ready(function(){
function Boxs(width,height,bgColor){
this.width = width;
this.height = height;
this.bgColor = bgColor;
}
var box = new Boxs(250,250,'green');
var box2 = new Boxs(200,200,'yellow');
//Создание коробки
Boxs.prototype.createBox = function(){
$('#idDiv').append('
');
$('.clBox').css({'width' : this.width+'px', 'height' : this.height+'px', 'background-color' : this.bgColor, 'margin' : '80px'});
}
box.createBox();
box2.createBox();
});
Когда я вызываю метод "createBox()" оно создает блок с заданными параметрами в объекте "box", но если я после этого вызову тот же метод но уже для другого объекта который имеет другие параметры, то "this" будет брать параметры из "box2", и сделает 2 блока со свойствам "box2".
Как сделать так что бы у меня вышли 2 блока с разными параметрами.
Насколько я понял "this" берется из последнего вызова метода, как можно это исправить?
Просьба помочь.
|
|
26.01.2014, 21:49
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,129
|
|
Сообщение от hfts_rider
|
Как сделать так что бы у меня вышли 2 блока с разными параметрами.
|
а разве это не так?
<!DOCTYPE HTML>
<html>
<head>
<title>Untitled</title>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>
$(document).ready(function(){
function Boxs(width,height,bgColor){
this.width = width;
this.height = height;
this.bgColor = bgColor;
}
var box = new Boxs(250,250,'green');
var box2 = new Boxs(200,200,'yellow');
//Создание коробки
Boxs.prototype.createBox = function(){
$('#idDiv').append(
$('<div/>').css({'width' : this.width+'px', 'height' : this.height+'px', 'background-color' : this.bgColor, 'margin' : '80px'})
);
}
box.createBox();
box2.createBox();
});
</script>
</head>
<body>
<div id="idDiv" ></div>
</body>
</html>
|
|
27.01.2014, 00:03
|
|
Профессор
|
|
Регистрация: 26.01.2014
Сообщений: 181
|
|
В этой строчке была проблема, я понял... я обновлял при втором вызове css (.clBox)...
==
Boxs.prototype.createBox = function(width,height,bgColor){
$('#idDiv').append('<div class="clBox"></div>');
$('.clBox').css({'width' : this.width+'px', 'height' : this.height+'px', 'background-color' : this.bgColor, 'margin' : '80px'});
}
==
Спасибо за помощь)
|
|
27.01.2014, 00:14
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,129
|
|
hfts_rider,
ваш вариант ))) чуть дополненный
<!DOCTYPE HTML>
<html>
<head>
<title>Untitled</title>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>
$(document).ready(function(){
function Boxs(width,height,bgColor){
this.width = width;
this.height = height;
this.bgColor = bgColor;
}
var box = new Boxs(250,250,'green');
var box2 = new Boxs(200,200,'yellow');
//Создание коробки
Boxs.prototype.createBox = function(width,height,bgColor){
$('#idDiv').append('<div class="clBox"></div>');
$('.clBox:last').css({'width' : this.width+'px', 'height' : this.height+'px', 'background-color' : this.bgColor, 'margin' : '80px'});
}
box.createBox();
box2.createBox();
});
</script>
</head>
<body>
<div id="idDiv" ></div>
</body>
</html>
|
|
27.01.2014, 00:39
|
|
Профессор
|
|
Регистрация: 26.01.2014
Сообщений: 181
|
|
Да! Спасибо! То что мне и нужно было "$('.clBox:last')"
|
|
27.01.2014, 00:52
|
|
Профессор
|
|
Регистрация: 26.01.2014
Сообщений: 181
|
|
Еще одно))) Подскажите как сделать теперь rotate(transform) для каждого элемента, что бы был универсальный метод, вот у меня крутит все блоки у которых класс определенный, а как можно переделать что бы при вызове метода "rotateBox()" для каждого блока он делал rotate отдельно?
<!DOCTYPE HTML>
<html>
<head>
<title>Untitled</title>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>
$(document).ready(function(){
function Boxs(width,height,bgColor){
this.width = width;
this.height = height;
this.bgColor = bgColor;
}
var box = new Boxs(250,250,'green');
var box2 = new Boxs(200,200,'yellow');
//Создание коробки
Boxs.prototype.createBox = function(width,height,bgColor){
$('#idDiv').append('<div class="clBox"></div>');
$('.clBox:last').css({'width' : this.width+'px', 'height' : this.height+'px', 'background-color' : this.bgColor, 'margin' : '80px'});
}
box.createBox();
box2.createBox();
var i = 0;
var timer;
//Поворот коробки
Boxs.prototype.rotateBox = function(){
$('.startInterval').click(function(){
if(!timer){
timer = setInterval(function(){
$('.clBox').css({'transform' : 'rotate('+ i++ +'deg)'});
if(i === 180){
i = 0;
}
},30);
}
});
};
$('.stopInterval').click(function(){
clearInterval(timer);
timer = null;
});
box2.rotateBox();
});
</script>
</head>
<body>
<div id="idDiv"></div>
<div class="startInterval">[START]</div>
<div class="stopInterval">[STOP]</div>
</body>
</html>
|
|
27.01.2014, 01:13
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,129
|
|
hfts_rider, жми кнопку макс START
<!DOCTYPE HTML>
<html>
<head>
<title>Untitled</title>
<meta charset="utf-8">
<style type="text/css">
.clBox{
-webkit-transition: all 3s ease-in-out;
-moz-transition: all 3s ease-in-out;
-o-transition: all 3s ease-in-out;
-ms-transition: all 3s ease-in-out;
transition: all 3s ease-in-out;
}
</style>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>
$(document).ready(function(){
function Boxs(width,height,bgColor){
this.width = width;
this.height = height;
this.bgColor = bgColor;
}
var box = new Boxs(250,250,'green');
var box2 = new Boxs(200,200,'yellow');
//Создание коробки
Boxs.prototype.createBox = function(width,height,bgColor){
$('#idDiv').append('<div class="clBox"></div>');
$('.clBox:last').css({'width' : this.width+'px', 'height' : this.height+'px', 'background-color' : this.bgColor, 'margin' : '80px'});
this.el = $('.clBox:last')
}
box.createBox();
box2.createBox();
var i = 0;
var timer;
//Поворот коробки
Boxs.prototype.rotateBox = function(i){
this.el.css({'transform' : 'rotate('+ i +'deg)'});
};
box2.rotateBox(45);
$('.startInterval').click(function(){
box.rotateBox(25);
});
});
</script>
</head>
<body>
<div id="idDiv"></div>
<div class="startInterval">[START]</div>
<div class="stopInterval">[STOP]</div>
</body>
</html>
|
|
30.01.2014, 20:36
|
|
Профессор
|
|
Регистрация: 26.01.2014
Сообщений: 181
|
|
Спасибо! "this.el", то что нужно!
|
|
|
|