ホームページ  >  記事  >  ウェブフロントエンド  >  JSを使用してバッファリングモーションを実装する方法

JSを使用してバッファリングモーションを実装する方法

php中世界最好的语言
php中世界最好的语言オリジナル
2018-06-01 14:19:581147ブラウズ

今回は、JSを使用してバッファリング動作を実装する方法と、JSを使用してバッファリング動作を実装する際の注意点について説明します。以下は実際的なケースです。

バッファリングでは数値の四捨五入、切り上げを使用する必要があります: Math.ceil()  向下取整Math.floor()

移動速度を徐々に遅くする効果、移動速度 = (終了位置 - 現在の位置) / 数値

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>JS缓冲运动</title>
<style>
#p{
  width:150px;
  height:150px;
  background:#0C6;
  position:absolute;
  left:0;
  top:50px;
}
#p2{
  background:#000;
  height:600px;
  position:absolute;
  left:500px;
  width:2px;
}
</style>
</head>
<script>
var speed;
var time;
window.onload = function(){
  var btn = document.getElementById('btn');
  btn.onclick = function(){
    speed = 0;
    move(500);
  };
  btn2.onclick = function(){
    speed = 0;
    move(0);
  };
};
function move(e){
  var p = document.getElementById('p');
  clearInterval(time);
  time = setInterval(function(){
    //改变位置,如果向左则e==500, 向上取整, 否则向右,向下取整,速度=(终点位置 - 当前位置)/一个数
    e==500 ? speed = Math.ceil((e-(p.offsetLeft))/30):speed = Math.floor((e-(p.offsetLeft))/30)
    if (e <= p.style.left){//达到,关闭定时器
      clearInterval(time);
    }
    else
    {
      p.style.left = p.offsetLeft+speed+&#39;px&#39;;
    }
  },30);
};
</script>
<body>
<input type="button" value="向右运动" id="btn" />
<input type="button" value="向左运动" id="btn2" />
<p id = "p">
</p>
<p id = "p2">
</p>
</body>
</html>

このケースを読んだことがあると思います。この方法をマスターしたら、よりエキサイティングなコンテンツを得るために、php 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

Vue プロジェクトで Vux を使用する方法

JS を使用せずにメニューを開いたり閉じたりする

以上がJSを使用してバッファリングモーションを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。