ホームページ >ウェブフロントエンド >jsチュートリアル >JSにおけるモーションのバッファリングの役割を詳しく解説

JSにおけるモーションのバッファリングの役割を詳しく解説

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-14 14:29:171229ブラウズ

今回は、バッファリングモーションを実装する際の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 サイトの他の関連記事に注目してください。

推奨読書:

ES6 で全画面スクロール プラグインを実装する手順の詳細な説明

VueJs での V-bind 命令の使用方法

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

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