zoukankan      html  css  js  c++  java
  • (DOM艺术) 实用的动画

    • 前面用js实现了移动效果(书前面233),这里用移动效果实现:
      三个链接,光标移动到哪个链接,显示那个图片。书上面的实现思路比较好,用一张大图片包含三个要显示的图案区域,光标移动到哪里,就显示特定区域的图片。因为如果用三个图片,加载图片也是要时间的,当图片数量多了效果就明显了。这里就是一个优化的技巧。100*300图片,100*100的显示区域,光标移动,移动图片把该显示的部分移动到显示区域就行了,
    • 将函数抽象化,变成“通用函数”
    • 变量作用域问题:当用户鼠标的速度来回移动速度够快,积累在 setTimeout队列里的事件就会导致动画效果产生滞后。为了消除动画滞后的现象,可以用clearTimeout函数清除积累在setTimeout队列里的事件。根据分析这里的movement既不能使用全局变量也不能使用局部变量。用只与某个特定元素有关的变量的“属性”。JS也允许我们创建属性。这样我们把变量movement从一个全局变量改变为正在被移动的那个元素(elem元素)的属性。这样一来,既可以测试它是否已经存在,并在它已经存在的情况下使用clearTimeout函数了。每次执行移动前,如果存在这个一个属性,就清除。这样一来,即使用户快速移动鼠标指针而使得某个元素需要向不同的方向移动,实际执行的也只有一条setTimeout函数调用语句。
    • 改进动画效果:远则移动快,近则慢
    • **如果把position属性值是absolute的元素A放入一个position属性值是relative的元素B,B就成为A的容器元素,而A将在B的显示区域里按absolute方式进行摆放。
    • 完全分离:如果用户压根没有启用JS支持,div和img元素纯粹是为了动画效果才塞进来的,既然如此,与其硬塞进文档还不如用js生成HTML 图片区域。
    • 改进,可以用css实现一些更精彩的效果

    代码部分:

    list.html:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta http-equiv="content-type" content="text/html; charset=utf-8" />
      <title>Web Design</title>
      <style type="text/css" media="screen">
        @import url(styles/layout.css);
      </style>
      <script type="text/javascript" src="scripts/addLoadEvent.js">
      </script>
      <script type="text/javascript" src="scripts/insertAfter.js">
      </script>
      <script type="text/javascript" src="scripts/moveElement.js">
      </script>
      <script type="text/javascript" src="scripts/prepareSlideshow.js">
      </script>
    </head>
    <body>
      <h1>Web Design</h1>
      <p>These are the things you should know.</p>
      <ol id="linklist">
        <li>
          <a href="structure.html">Structure</a>
        </li>
        <li>
          <a href="presentation.html">Presentation</a>
        </li>
        <li>
          <a href="behavior.html">Behavior</a>
        </li>
      </ol>
    </body>
    </html>
    

    prepareSlideshow.js:

    function prepareSlideshow() {
    // Make sure the browser understands the DOM methods
      if (!document.getElementsByTagName) return false;
      if (!document.getElementById) return false;
    // Make sure the elements exist
      if (!document.getElementById("linklist")) return false;
      var slideshow = document.createElement("div");
      slideshow.setAttribute("id","slideshow");
      var preview = document.createElement("img");
      preview.setAttribute("src","topics.gif");
      preview.setAttribute("alt","building blocks of web design");
      preview.setAttribute("id","preview");
      slideshow.appendChild(preview);
      var list = document.getElementById("linklist");
      insertAfter(slideshow,list);
    // Get all the links in the list
      var links = list.getElementsByTagName("a");
    // Attach the animation behavior to the mouseover event
      links[0].onmouseover = function() {
        moveElement("preview",-100,0,10);
      }
      links[1].onmouseover = function() {
        moveElement("preview",-200,0,10);
      }
      links[2].onmouseover = function() {
        moveElement("preview",-300,0,10);
      }
    }
    addLoadEvent(prepareSlideshow);
    

    moveElement.js:

    function moveElement(elementID,final_x,final_y,interval) {
      if (!document.getElementById) return false;
      if (!document.getElementById(elementID)) return false;
      var elem = document.getElementById(elementID);
      if (elem.movement) {
        clearTimeout(elem.movement);
      }
      if (!elem.style.left) {
        elem.style.left = "0px";
      }
      if (!elem.style.top) {
        elem.style.top = "0px";
      }
      var xpos = parseInt(elem.style.left);
      var ypos = parseInt(elem.style.top);
      if (xpos == final_x && ypos == final_y) {
        return true;
      }
      if (xpos < final_x) {
        var dist = Math.ceil((final_x - xpos)/10);
        xpos = xpos + dist;
      }
      if (xpos > final_x) {
        var dist = Math.ceil((xpos - final_x)/10);
        xpos = xpos - dist;
      }
      if (ypos < final_y) {
        var dist = Math.ceil((final_y - ypos)/10);
        ypos = ypos + dist;
      }
      if (ypos > final_y) {
        var dist = Math.ceil((ypos - final_y)/10);
        ypos = ypos - dist;
      }
      elem.style.left = xpos + "px";
      elem.style.top = ypos + "px";
      var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")";
      elem.movement = setTimeout(repeat,interval);
    }
    

    insertAfter.js:

    function insertAfter(newElement,targetElement) {
      var parent = targetElement.parentNode;
      if (parent.lastChild == targetElement) {
        parent.appendChild(newElement);
      } else {
        parent.insertBefore(newElement,targetElement.nextSibling);
      }
    }
    

    addLoadEvent.js:

    function addLoadEvent(func) {
      var oldonload = window.onload;
      if (typeof window.onload != 'function') {
        window.onload = func;
      } else {
        window.onload = function() {
          oldonload();
          func();
        }
      }
    }
    

    layout.css:

    #slideshow {
       100px;
      height: 100px;
      position: relative;
      overflow: hidden;
    }
    #preview {
      position: absolute;
    }
  • 相关阅读:
    洛谷P3376 【模板】网络最大流
    bzoj 4598: [Sdoi2016]模式字符串
    JAVA类(下)
    2019DDCTF部分Writeup
    Atom配置(VIM党) · iuunhao
    Tips
    rsync auth failed on module xxx
    基于mykernel完成时间片轮询多道进程的简单内核
    机器学习技法笔记(2)-Linear SVM
    css之制作三角形
  • 原文地址:https://www.cnblogs.com/zhangmingzhao/p/7674220.html
Copyright © 2011-2022 走看看