이동하는 글자

· 13년 전 · 1665 · 2
<script>
   function nextRandomInteger(limit) {
     return Math.round(Math.random() * limit);
   }
   var alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
   function randomAlphabet() {
     return alphabet.charAt(nextRandomInteger(25));
   }
   function randomSpeed(maxSpeed) {
     return Math.random() * maxSpeed - Math.random() * maxSpeed;
   }
  var canvasWidth = 700;
  var canvasHeight = 500;
  function MovingText() {
  this.x = nextRandomInteger(canvasWidth);
  this.y = nextRandomInteger(canvasHeight);
  this.vX = randomSpeed(10);
  this.vY = randomSpeed(10);
  this.body = document.createElement('h1');
  this.body.innerHTML = randomAlphabet();
  this.body.style.position = 'absolute';
 
  MovingText.prototype.move = function () {
  }
    if (this.x < 0 || this.x > canvasWidth) {this.vX *= -1;}
    if (this.y < 0 || this.y > canvasHeight) {this.vY *= -1;}
   
    this.x += this.vX;
    this.y += this.vY;
    this.body.style.left = this.x + 'px';
    this.body.style.top = this.y + 'px';
   };
   window.onload = function () {
  var movingTexts = [];
  for (var i = 0; i < 100; i++) {
     movingTexts.push(new MovingText());
     }
  setInterval(function () {
     for (var i in movingTexts) {
     movingTexts[i].move();
  }
     }, 1000 / 60);
    };
</script>
 
오류도 없는데 빈화면으로밖에 나오질않네요...
뭐가문제인가요?
|

댓글 2개

소스가 약간씩 모자라거나 열고 닫는 부분이 잘못 되어있네요.
소스를 작성하실때 function 의 시작과 끝을 잘 파악하셔야 하고 무조건 따라 작성하시기 보다는 코드의 흐름을 파악하시고 작성하시는것이 좋을 것 같습니다.

완성소스는 아래와 같습니다.
(참고문헌 : 모던 웹을 위한 javascript jQuery 입문 (윤인성 저) )

<!DOCTYPE html>
<html>
<head>
<script>
function nextRandomInteger(limit) {
return Math.round(Math.random() * limit);
}

var alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
function randomAlphabet() {
return alphabet.charAt(nextRandomInteger(25));
}

function randomSpeed(maxSpeed) {
return Math.random() * maxSpeed - Math.random() * maxSpeed;
}
</script>
<script>

var canvasWidth = 700;
var canvasHeight = 500;
function MovingText() {
this.x = nextRandomInteger(canvasWidth);
this.y = nextRandomInteger(canvasHeight);
this.vX = randomSpeed(10);
this.vY = randomSpeed(10);

this.body = document.createElement('h1');
this.body.innerHTML = randomAlphabet();
this.body.style.position = 'absolute';

document.body.appendChild(this.body);
}

MovingText.prototype.move = function () {
if (this.x < 0 || this.x > canvasWidth) {this.vX *= -1;}
if (this.y < 0 || this.y > canvasHeight) {this.vY *= -1;}

this.x += this.vX;
this.y += this.vY;

this.body.style.left = this.x + 'px';
this.body.style.top = this.y + 'px';
};
</script>
<script>
window.onload = function () {
var movingTexts = [];
for (var i = 0; i < 100; i++) {
movingTexts.push(new MovingText());
}
setInterval(function () {
for (var i in movingTexts) {
movingTexts[i].move();
}
}, 1000 / 60);
};
</script>
</head>
<body>
</body>
</html>
감사합니다!
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
13년 전 조회 2,334
13년 전 조회 1,195
13년 전 조회 1,242
13년 전 조회 1,479
13년 전 조회 1,211
13년 전 조회 2,126
13년 전 조회 1,142
13년 전 조회 1,166
13년 전 조회 1,521
13년 전 조회 1,289
13년 전 조회 1,206
13년 전 조회 1,340
13년 전 조회 1,355
13년 전 조회 1,213
13년 전 조회 3,056
13년 전 조회 2,162
13년 전 조회 2,034
13년 전 조회 1,241
13년 전 조회 1,196
13년 전 조회 1,290
13년 전 조회 1,497
13년 전 조회 1,292
13년 전 조회 1,869
13년 전 조회 1,954
13년 전 조회 1,536
13년 전 조회 1,674
13년 전 조회 2,724
13년 전 조회 3,053
13년 전 조회 6,328
13년 전 조회 1,220
13년 전 조회 1,666
13년 전 조회 1,221
13년 전 조회 1,493
13년 전 조회 2,143
13년 전 조회 1,703
13년 전 조회 1,350
13년 전 조회 1,429
13년 전 조회 1,259
13년 전 조회 1,437
13년 전 조회 2,366
13년 전 조회 2,652
13년 전 조회 1,526
13년 전 조회 1,786
13년 전 조회 2,892
13년 전 조회 1,836
13년 전 조회 1,830
13년 전 조회 1,521
13년 전 조회 2,930
13년 전 조회 1,505
13년 전 조회 1,666
13년 전 조회 1,996
13년 전 조회 2,167
13년 전 조회 3,759
13년 전 조회 3,996
13년 전 조회 1,463
13년 전 조회 1,955
13년 전 조회 1,448
13년 전 조회 2,071
13년 전 조회 1,812
13년 전 조회 1,703
13년 전 조회 2,023
13년 전 조회 1,272
13년 전 조회 2,669
13년 전 조회 2,436
13년 전 조회 2,137
13년 전 조회 1,603
13년 전 조회 2,093
13년 전 조회 2,288
13년 전 조회 1,905
13년 전 조회 3,107
13년 전 조회 1,744
13년 전 조회 1,458
13년 전 조회 1,656
13년 전 조회 4,458
13년 전 조회 3,322
13년 전 조회 1,904
13년 전 조회 2,058
13년 전 조회 3,464
13년 전 조회 2,473
13년 전 조회 1,607
13년 전 조회 1,736
13년 전 조회 3,060
13년 전 조회 1,576
13년 전 조회 1,854
13년 전 조회 1,288
13년 전 조회 1,461
13년 전 조회 2,215
13년 전 조회 3,759
13년 전 조회 1,521
13년 전 조회 1,757
13년 전 조회 2,191
13년 전 조회 1,585
13년 전 조회 3,204
13년 전 조회 1,782
13년 전 조회 2,486
13년 전 조회 2,706
13년 전 조회 2,529
13년 전 조회 1,841
13년 전 조회 2,114
13년 전 조회 1,622