扇形导航

圆形按钮,切换一系列图片导航的显示与隐藏。

如果涉及过渡动画,定位的 top 和 left 必须写

Math.sin(弧度)

  • 一圈弧度 = 2π,一圈角度 = 360
  • 弧度 = (deg*2π)/360 = (deg*π)/180
  • <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8" />
    <title>扇形导航</title> <style type="text/css">
    body {
    width: 100%;
    color: #000;
    background: #96b377;
    font: 14px Helvetica, Arial, sans-serif;
    } /**** Corner Nav ****/
    #corner_nav {
    position: fixed;
    bottom: 0px;
    right: 0px; width: 50px;
    height: 50px;
    padding: 1px 0 0 1px; background: #f000;
    } #corner_btn {
    position: absolute;
    top: 1px;
    left: 1px;
    z-index: 5; width: 49px;
    height: 49px;
    border-radius: 50%;
    background: url(./img/corner.png) no-repeat;
    transition: 1s all ease 0s;
    cursor: pointer;
    } #a_imgs {
    list-style: none;
    width: 42px;
    height: 42px;
    } #a_imgs img {
    display: block;
    border-radius: 50%; transition: 1s all ease 0s;
    opacity: 0.6;
    } #a_imgs li {
    position: absolute;
    top: 4px;
    left: 4px; }
    </style>
    </head> <body> <div id="corner_nav"> <div id="corner_btn"></div> <ul id="a_imgs">
    <li class="aImgLi"><a href="javescript:;"><img src="./img/clos.png" /></a></li>
    <li class="aImgLi"><a href="javescript:;"><img src="./img/full.png" /></a></li>
    <li class="aImgLi"><a href="javescript:;"><img src="./img/open.png" /></a></li>
    <li class="aImgLi"><a href="javescript:;"><img src="./img/prev.png" /></a></li>
    <li class="aImgLi"><a href="javescript:;"><img src="./img/refresh.png" /></a></li>
    </ul> </div> <!-- javascript 代码 -->
    <script type="text/javascript"> var cornerBtn = document.getElementById("corner_btn"); var lis = document.querySelectorAll("li.aImgLi");
    var navLength = 200; var isOpen = false;
    cornerBtn.onclick = function(){
    if(isOpen){
    // 收回
    cornerBtn.style.transform = "rotate(0deg)"; for(i=0; i<lis.length; i++){
    lis[i].style.transition = 0.5+"s "+0.1*(lis.length-1-i)+"s"; lis[i].style.left = 4+"px";
    lis[i].style.top = 4 +"px"; lis[i].style.transform = "rotate(0deg)";
    }
    }else{
    // 释放
    cornerBtn.style.transform = "rotate(-360deg)"; var i = 0;
    for(i=0; i<lis.length; i++){
    lis[i].style.transition = 0.5+"s "+0.1*i+"s"; lis[i].style.left = -navLength*Math.sin( (90/(lis.length-1))*i*Math.PI/180 )+"px";
    lis[i].style.top = -navLength*Math.cos( (90/(lis.length-1))*i*Math.PI/180 )+"px"; lis[i].style.transform = "rotate(-720deg)";
    }; };
    isOpen = !isOpen;
    }; // 点击按钮: 按钮放大,透明度为 1
    var aImgs = document.getElementById("a_imgs");
    aImgs.onclick = function(e){
    e = e || window.event;
    var obj = e.target || e.srcElement; // 单独设置点击元素的样式: 透明度 放大
    if(obj.nodeName == "IMG"){
    obj.style.opacity = "1";
    obj.style.transform = "scale(1.5)"; // 在过渡结束和,缩小到原来大小
    // window.setTimeout(function(){
    // obj.style.transform = "scale(1)";
    // },1000); /**** transitionend 检测事件结束事件
    必须是 DOM2 级事件绑定 ****/
    /**** 1. 兼容性问题****/

    obj.addEventListener('transitionend', styleBack);
    obj.addEventListener('webkitTransitionEnd', styleBack); // 小驼峰命名法 function styleBack(){
    obj.style.transform = "scale(1)"; /**** 2. 解绑问题 PC 端流量不限量,无大影响
    移动端必须解绑 省流量
    因为事件存在,需要一定流量监控此事件,
    且无关触发需要消耗流量执行 ****/

    obj.removeEventListener('transitionend', styleBack);
    obj.removeEventListener('webkitTransitionEnd', styleBack); // 小驼峰命名法
    }; };
    }; // 鼠标离开,所有元素回到默认样式
    aImgs.onmouseleave = function(){
    var allImgs = document.getElementById("a_imgs").children;
    var i = 0;
    var theImg = null;
    for(i=0; i<allImgs.length; i++){
    theImg = allImgs[i].getElementsByTagName("img")[0];
    theImg.style.opacity = "0.6";
    };
    }; </script>
    </body>
    </html>

CSS3_扇形导航_transitionend 事件的更多相关文章

  1. 扇形导航 css3

    本篇文章将通过对css3中的2d变化以及过渡进行分析设计 先放上最终效果图                 功能实现:1.给扇形home元素设置点击事件并添加2d旋转 2.给导航栏设置2d旋转 并通过 ...

  2. 原生js实现扇形导航以及动画的坑

    第一次发博客,有点紧张.首先来一张效果图. 主要是实现了点击右下角的风扇按钮实现了: 导航栏的开启与关闭,中间伴随着 transition过渡以及transform的2D动画. 上源码: <!D ...

  3. JavaScript----分层导航 滚动事件

    分层导航 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...

  4. 简单二级导航JQ事件代码

    $(function()){ $("li").hover(function(){ $(this).children("dl").show() },functio ...

  5. jQuery导航切换功能

    Css ------------------------------------------------------------------------------------------------ ...

  6. Android导航栏ActionBar的具体分析

    尊重原创:http://blog.csdn.net/yuanzeyao/article/details/39378825 关于ActionBar,相信大家并不陌生,可是真正能够熟练使用的也不是许多,这 ...

  7. [JavaScript] JavaScript事件注册,事件委托,冒泡,捕获,事件流

    面试题 event 事件 事件委托是什么? 如何阻止事件冒泡,阻止默认事件呢? Javascript 的事件流模型都有什么? 事件绑定和普通事件有什么区别? Event 对象 Event 对象,当事件 ...

  8. 背水一战 Windows 10 (41) - 控件(导航类): Frame

    [源码下载] 背水一战 Windows 10 (41) - 控件(导航类): Frame 作者:webabcd 介绍背水一战 Windows 10 之 控件(导航类) Frame 示例Controls ...

  9. WP8.1学习系列(第十九章)——事件和路由事件概述

    我们将介绍在使用 C#.Visual Basic 或 Visual C++ 组件扩展 (C++/CX) 作为编程语言并使用 XAML 进行 UI 定义时,针对 Windows 运行时应用的事件的编程概 ...

随机推荐

  1. 金融量化分析【day110】:Pandas的Series对象

    一.pandas简介安装 pandas是一个强大的python数据分析的工具包 pandsa是基于NumPy构建的 1.pandas的主要功能 1.具备对其功能的数据结构DataFrame.Serie ...

  2. 设 $y_1(x), y_2(x)$ 是 $y''+p(x)y'+q(x)y=0$ 的两个解 ($p(x), q(x)$ 连续), 且 $y_1(x_0)=y_2(x_0)=0$, $y_1(x)\not\equiv 0$. 试证: $y_1(x)$, $y_2(x)$ 线性相关.

    设 $y_1(x), y_2(x)$ 是 $y''+p(x)y'+q(x)y=0$ 的两个解 ($p(x), q(x)$ 连续), 且 $y_1(x_0)=y_2(x_0)=0$, $y_1(x)\n ...

  3. [物理学与PDEs]第1章第8节 静电场和静磁场 8.3 静磁场

    1. 静磁场: 由稳定电流形成的磁场. 2. 此时, Maxwell 方程组为 $$\beex \bea \Div{\bf D}&=\rho_f,\\ \rot {\bf E}&={\ ...

  4. gitlab升级迁移(二)

    前面我们写了一篇gitlab升级迁移的文章(https://www.cnblogs.com/liangyou666/p/9434158.html),这次我们主要是讲另一种升级迁移方法和其中遇到的一些问 ...

  5. Python DB operation

    mysql http://www.cnblogs.com/zhangzhu/archive/2013/07/04/3172486.html 1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目 ...

  6. windows7 java环境配置

    最近在工作碰到了在ie浏览器调用java程序时,出现了一些问题,所以在这里整理一下: jdk的下载地址为:http://666dx.pc6.com/wwb3/jdkx6417.zip 正对于windo ...

  7. 【webpack】中mini-css-extract-plugin使用方法

    这个参加可以压缩CSS,然后让CSS输出到指定的目录中 使用这个loader也很简单,只有将style-loader 替换成 MiniCssExtractPlugin.loader, 'css-loa ...

  8. Django对于模型的数据操作

    一.引入模型的包 from myApp.models import Grades,Students 二.查询所有数据 #objecs是类的隐藏属性:类名.objects.all()可以查询所有数据 G ...

  9. 使用fetch调用node.js的Resuful服务

    在目前的软件架构中,慢慢又有这样的趋势,就是在前端和业务接口层中间再加入一层,这是由于nodejs相对JAVA而言不适合做复杂的业务逻辑,如下图: 在这样的结构中,JS前端和web层都是前端开发工程师 ...

  10. vim简单使用教程【转】

    vim的学习曲线相当的大(参看各种文本编辑器的学习曲线),所以,如果你一开始看到的是一大堆VIM的命令分类,你一定会对这个编辑器失去兴趣的.下面的文章翻译自<Learn Vim Progress ...