欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JS---案例:手风琴 (利用封装好的动画函数)

程序员文章站 2022-05-29 08:29:11
案例:手风琴 封装好的动画函数在common.js里面 //function getStyle(element, attr) {...} //function animate(element, json, fn) {...} 手风琴设置的是背景图吗,backgroudImage="url(image ......

案例:手风琴

   
封装好的动画函数在common.js里面
    //function getstyle(element, attr) {...}
    //function animate(element, json, fn) {...}

手风琴设置的是背景图吗,backgroudimage="url(image/***.jpg)";

当鼠标进入的时候,当前的宽度变为800,其余的遍历并设置为100;

鼠标离开的时候,所有li宽度变为400

<!doctype html>
<html>

<head lang="en">
  <meta charset="utf-8">
  <title></title>
  <style>
    ul {
      list-style: none;
    }

    * {
      margin: 0;
      padding: 0;
    }

    div {
      width: 1150px;
      height: 400px;
      margin: 50px auto;
      border: 1px solid red;
      overflow: hidden;
    }

    div li {
      width: 240px;
      height: 400px;
      float: left;
    }

    div ul {
      width: 1300px;
    }
  </style>
</head>

<body>
  <div id="box">
    <ul>
      <li></li>
      <li></li>
      <li></li>
      <li></li>
      <li></li>
    </ul>
  </div>
  <script src="common.js"></script>
  <script>

    //下面2个封装好的函数在common.js里面
    //function getstyle(element, attr) {
    //function animate(element, json, fn) {

    //先获取所有的li标签
    var list = my$("box").getelementsbytagname("li");
    for (var i = 0; i < list.length; i++) {
      list[i].style.backgroundimage = "url(images/" + (i + 1) + ".jpg)";
      //鼠标进入
      list[i].onmouseover = mouseoverhandle;
      //鼠标离开
      list[i].onmouseout = mouseouthandle;
    }
    //进入和离开函数
    function mouseoverhandle() {
      for (var j = 0; j < list.length; j++) {
        animate(list[j], { "width": 100 });//动画效果
      }
      animate(this, { "width": 800 });

    }
    function mouseouthandle() {
      for (var j = 0; j < list.length; j++) {
        animate(list[j], { "width": 240 });//动画效果
      }
    }

  </script>

</body>

</html>