ウィンドウジッター効果の JavaScript 実装サンプルコード

怪我咯
リリース: 2017-07-04 15:14:53
オリジナル
2069 人が閲覧しました

シェイクエフェクトは、すべての主要なWebページで頻繁に発生します。この記事では、ウィンドウシェイクエフェクトを実現するためのJavaScriptの関連情報を主に紹介します。これは非常に優れており、必要な友人は

の原理を参照できます。

はじめに

ジッターは実際には往復運動の特殊な形式ですが、往復運動は摩擦のない無限運動であり、速度を基準として使用しますが、ジッターは位置を基準として使用し、最終的に開始時に停止します。開始点

Web ページで最も一般的なディザリング効果は、ウィンドウを振るプロンプトです

ディザリング要素は開始点から開始され、最初に最大距離 len だけ右に移動し、次に対称に移動します。左の位置; そして、左に移動します 少し短い距離を右に移動し、次に対称の左の位置に移動します; このループでは、最後の要素が開始点で停止します

コードの実装

コードでの実装はタイマーに過ぎず、1 つおきに左か上の値を一定期間変化させます

モーションの実装では、距離変更には 2 つのアイデアがあります

アイデア 1

p.style.left = p.offsetLeft + value;
ログイン後にコピー

要素の現在のスタイルを毎回取得し、変更された値と比較します 操作

アイデア 2

left = p.offsetLeft;
......
p.style.left = left + value;
ログイン後にコピー

タイマーがオンになる前に、要素の初期スタイルを取得し、次の計算を実行します変更された値

ジッターの実装の観点から、距離を完全に変更するには 2 番目の方法を使用します。 したがって、コード実装の鍵は、値がどのように変化するかを理解することです。最も遠い距離がターゲット、同じ方向の距離間隔がステップです。数値でより直感的に表現すると、value の値は 4、-4、2、-2、0 と似ています。したがって、開始の揺れの方向を制御するには変数 dir が必要です

//定时器开启前的变量声明
dir = 1;
step = 0;
left = p.offsetLeft
//定时器里面的代码
value = dir*(target - step);
if(step >= target){
step = target
}
p.style.left = left + value + 'px';
if(dir === -1){
step++; 
}
dir = -dir;
ログイン後にコピー

揺れのエフェクトをshakeMove.jsにカプセル化します

function getCSS(obj,style){
if(window.getComputedStyle){
return getComputedStyle(obj)[style];
}
return obj.currentStyle[style];
} 
function shakeMove(json){
//声明要进行抖动的元素
var obj = json.obj;
//声明元素抖动的最远距离
var target = json.target;
//默认值为20
target = Number(target) || 20;
//声明元素的变化样式
var attr = json.attr;
//默认为'left' 
attr = attr || 'left'; 
//声明元素的起始抖动方向
var dir = json.dir;
//默认为'1',表示开始先向右抖动
dir = Number(dir) || '1';
//声明元素每次抖动的变化幅度
var stepValue = json.stepValue;
stepValue = Number(stepValue) || 2;
//声明回调函数 
var fn = json.fn;
//声明步长step
var step = 0;
//保存样式初始值
var attrValue = parseFloat(getCSS(obj,attr));
//声明参照值value
var value;
//清除定时器
if(obj.timer){return;}
//开启定时器
obj.timer = setInterval(function(){
//抖动核心代码
value = dir*(target - step);
//当步长值大于等于最大距离值target时
if(step >= target){
step = target
}
//更新样式值
obj.style[attr] = attrValue + value + 'px';
//当元素到达起始点时,停止定时器
if(step == target){
clearInterval(obj.timer);
obj.timer = 0;
//设置回调函数
fn && fn.call(obj); 
} 
//如果此时为反向运动,则步长值变化
if(dir === -1){
step = step + stepValue; 
}
//改变方向
dir = -dir; 
},50); 
}
ログイン後にコピー

以下のパッケージを使用します。いくつかのシンプルなシェイク アプリケーションを実装するには、shakeMove

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.test{
height: 50px;
width: 50px;
position: absolute;
top: 50px;
} 
</style>
</head>
<body>
<p id="box">
<p class="test" style="left:10px;background:lightblue"></p>
<p class="test" style="left:70px;background:lightgreen"></p>
<p class="test" style="left:130px;background:pink"></p>
<p class="test" style="left:190px;background:lightcoral"></p>
<p class="test" style="left:250px;background:orange"></p>
</p>
<script src="http://files.cnblogs.com/files/xiaohuochai/shakeMove.js"></script>
<script>
var ap = box.getElementsByTagName(&#39;p&#39;);
for(var i = 0; i < ap.length; i++){
ap[i].onmouseover = function(){
shakeMove({obj:this,attr:&#39;top&#39;});
}
}
</script>
</body>
</html>
ログイン後にコピー

以上がウィンドウジッター効果の JavaScript 実装サンプルコードの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!