> 웹 프론트엔드 > JS 튜토리얼 > 수평 및 수직 이동 효과를 얻기 위해 js를 사용하는 방법

수평 및 수직 이동 효과를 얻기 위해 js를 사용하는 방법

王林
풀어 주다: 2020-04-08 09:20:47
앞으로
3357명이 탐색했습니다.

수평 및 수직 이동 효과를 얻기 위해 js를 사용하는 방법

수평 이동 분석:

물체의 왼쪽 여백의 변화로 볼 수 있습니다.

예: 오른쪽으로 이동하면 왼쪽 여백이 점점 커지고(값은 양수) 개체의 왼쪽 여백을 조정하여 이를 달성할 수 있습니다.

왼쪽으로 이동하면 왼쪽 여백이 작아지고 (값이 음수임), 객체의 왼쪽 여백을 조정할 수 있습니다. 실제 왼쪽 여백을 구현한 코드는 다음과 같습니다.

<style>
    *{padding: 0;margin: 0px;}
    #box{width: 100px;height: 100px;border-radius: 50%;background: red;position: absolute;top: 50px;left: 0;}
</style>
<body>
  <button id="btn">向右</button>
  <button id="btn1">向左</button>
  <div id="box"></div>
  <script>
    var box=document.getElementById(&#39;box&#39;);
    //速度
    var index=10;
    //定时器编号
    var b;
    //添加向右点击事件
    document.getElementById(&#39;btn&#39;).onclick=function(){
      clearInterval(b);//清除上一个定时器执行的事件
      b=setInterval(getMove,100,index);//每100毫秒执行一次getMove函数
    }
    //添加向左点击事件
    document.getElementById(&#39;btn1&#39;).onclick=function(){
      clearInterval(b);//清除上一个定时器执行的事件
      b=setInterval(getMove,100,-index);//每100毫秒执行一次getMove函数
    }
    //box移动位置
    function getMove(index){
      //获取box的左距离
      var a=window.getComputedStyle(box,null).left;
      a=parseInt(a);//转换为数值
      box.style.left=a+index+&#39;px&#39;//计算box的左距离
    }
  </script>
</body>
로그인 후 복사

수직 이동 분석:

객체의 위쪽 여백이 변경되는 것으로 볼 수 있습니다. .

예: 아래로 이동하면 상단 여백이 점점 커지고(값은 양수) 개체의 상단 여백을 조정하여 이를 달성할 수 있습니다.

위로 이동하면 상단 여백이 점점 작아지는 것을 의미합니다( 값은 음수), 객체의 상단 여백은 조정될 수 있습니다.

를 달성하는 실제 코드는 다음과 같습니다:

<style>
    *{padding: 0;margin: 0px;}
    #box{width: 100px;height: 100px;border-radius: 50%;background: red;position: absolute;top: 50px;left: 0;}
</style>
<body>
  <button id="btn">向下</button>
  <button id="btn1">向上</button>
  <div id="box"></div>
  <script>
    var box=document.getElementById(&#39;box&#39;);
    //速度
    var index=10;
    //定时器编号
    var b;
    //添加向下点击事件
    document.getElementById(&#39;btn&#39;).onclick=function(){
      clearInterval(b);//清除上一个定时器执行的事件
      b=setInterval(getMove,100,index);//每100毫秒执行一次getMove函数
    }
    //添加向上点击事件
    document.getElementById(&#39;btn1&#39;).onclick=function(){
      clearInterval(b);//清除上一个定时器执行的事件
      b=setInterval(getMove,100,-index);//每100毫秒执行一次getMove函数
    }
    //box移动位置
    function getMove(index){
      //获取box的上距离
      var a=window.getComputedStyle(box,null).top;
      a=parseInt(a);//转换为数值
      box.style.top=a+index+&#39;px&#39;//计算box的上距离
    }
  </script>
</body>
로그인 후 복사

권장 관련 튜토리얼:

js tutorial

위 내용은 수평 및 수직 이동 효과를 얻기 위해 js를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
js
원천:jb51.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿