JS实现六边形3D拖拽翻转效果的方法


Posted in Javascript onSeptember 11, 2016

效果图

JS实现六边形3D拖拽翻转效果的方法

JS实现六边形3D拖拽翻转效果的方法

实例代码如下:

<!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>javascript六边形3d拖拽翻转效果</title>
</head>
    <style>
      #box{width:200px;height:200px;margin: 200px auto; background: #ccc; position: relative;
      transform:perspective(800px) rotateY(-60deg) rotateX(45deg);transform-style:preserve-3d;}
      #box div{width:100%;height: 100%; position: absolute;top:0;left:0; background-size: cover;-webkit-box-shadow:0 0 100px #5fbcff; opacity: 0.8;}
      .front{ transform: translateZ(100px); background:#f00;}
      .back{transform: translateZ(-100px); background:#20ab4f;}
      .top{transform:translateY(-100px) rotateX(90deg); background: #ff7800;}
      .bottom{transform:translateY(100px) rotateX(-90deg); background: #00f6ff;}
      .left{transform:translateX(-100px) rotateY(90deg); background: #0084ff;}
      .right{transform:translateX(100px) rotateY(-90deg); background: #b400ff;}
    </style>
    <script>
      window.onload=function(){
        var oDiv=document.querySelector("#box");
        var y=-60;
        var x=45;
        oDiv.onmousedown=function(ev){
          var ev=ev||event;
          var disX=ev.clientX-y;
          var disY=ev.clientY-x;
          document.onmousemove=function(ev){
            var ev=ev||event;
            y=ev.clientY-disY;
            x=ev.clientX-disX;
            oDiv.style.transform='perspective(800px) rotateX('+x+'deg) rotateY('+y+'deg)';
            
          }
          document.onmouseup=function(){
            document.onmouseup=null;
            document.onmousemove=null;
            oDiv.releaseCapture&&oDiv.releaseCapture();
          }
          oDiv.setCapture&&oDiv.setCapture()
          return false;
        }
        
      }
    </script>
  </head>
  <body>
    <div id="box">
      <div class="front"></div>
      <div class="back"></div>
      <div class="top"></div>
      <div class="bottom"></div>
      <div class="left"></div>
      <div class="right"></div>
    </div>
  </body>
</html>

以上就是这篇文章的全部内容,怎么样?效果很好吧,感兴趣的朋友们自己运行看看效果,希望这篇文章对大家能有一定的帮助。

Javascript 相关文章推荐
该如何加载google-analytics(或其他第三方)的JS
May 13 Javascript
Javascript获取窗口(容器)的大小及位置参数列举及简要说明
Dec 09 Javascript
Node.js复制文件的方法示例
Dec 29 Javascript
JS日程管理插件FullCalendar中文说明文档
Feb 06 Javascript
JS判断两个对象内容是否相等的方法示例
Apr 10 Javascript
详解使用angularjs的ng-options时如何设置默认值(初始值)
Jul 18 Javascript
详解JavaScript中的数组合并方法和对象合并方法
May 11 Javascript
对Vue2 自定义全局指令Vue.directive和指令的生命周期介绍
Aug 30 Javascript
webpack优化的深入理解
Dec 10 Javascript
webpack3升级到webpack4遇到问题总结
Sep 30 Javascript
vue-simple-uploader上传成功之后的response获取代码
Sep 07 Javascript
探索node之事件循环的实现
Oct 30 Javascript
最全面的百度地图JavaScript离线版开发
Sep 10 #Javascript
简单分析javascript中的函数
Sep 10 #Javascript
javascript数组常用方法汇总
Sep 10 #Javascript
JavaScript实现输入框与清空按钮联动效果
Sep 09 #Javascript
Three.js快速入门教程
Sep 09 #Javascript
jQuery动态修改字体大小的方法【测试可用】
Sep 09 #Javascript
Bootstrap菜单按钮及导航实例解析
Sep 09 #Javascript
You might like
雄兵连三大错觉:凯莎没了,凉冰阵亡了,华烨觉得自己又行了
2020/04/09 国漫
Cappuccino 卡布其诺咖啡之制作
2021/03/03 冲泡冲煮
用PHP动态创建Flash动画
2006/10/09 PHP
PHP Smarty生成EXCEL文档的代码
2008/08/23 PHP
浅析php中如何在有限的内存中读取大文件
2013/07/02 PHP
PHP中filter函数校验数据的方法详解
2015/07/31 PHP
Zend Framework教程之分发器Zend_Controller_Dispatcher用法详解
2016/03/07 PHP
PHP入门教程之使用Mysqli操作数据库的方法(连接,查询,事务回滚等)
2016/09/11 PHP
基于thinkPHP类的插入数据库操作功能示例
2017/01/06 PHP
jquery实现智能感知连接外网搜索
2013/05/21 Javascript
js实现点击添加一个input节点
2014/12/05 Javascript
javascript获取wx.config内部字段解决微信分享
2016/03/09 Javascript
IScroll5 中文API参数说明和调用方法
2016/05/21 Javascript
jQuery获取select选中的option的value值实现方法
2016/08/29 Javascript
基于Two.js实现星球环绕动画效果的示例
2017/11/06 Javascript
JS实现的合并多个数组去重算法示例
2018/04/11 Javascript
JS加密插件CryptoJS实现的DES加密示例
2018/08/16 Javascript
vue 自定义右键样式的实例代码
2019/11/06 Javascript
JsonServer安装及启动过程图解
2020/02/28 Javascript
在Vue中使用Echarts实例图的方法实例
2020/10/10 Javascript
vue移动端下拉刷新和上滑加载
2020/10/27 Javascript
使用Python进行中文繁简转换的实现代码
2019/10/18 Python
Python列表原理与用法详解【创建、元素增加、删除、访问、计数、切片、遍历等】
2019/10/30 Python
Python PyInstaller库基本使用方法分析
2019/12/12 Python
Python异常继承关系和自定义异常实现代码实例
2020/02/20 Python
Python定时任务APScheduler原理及实例解析
2020/05/30 Python
探索HTML5本地存储功能运用技巧
2016/03/02 HTML / CSS
加拿大床上用品、家居装饰、厨房和浴室产品购物网站:Linen Chest
2018/06/05 全球购物
override和overload的区别
2016/03/09 面试题
审核会计岗位职责
2013/11/08 职场文书
详细的本科生职业生涯规划范文
2014/09/16 职场文书
2014年仓库保管员工作总结
2014/12/03 职场文书
教师先进个人材料
2014/12/17 职场文书
求职自荐信怎么写
2015/03/04 职场文书
小学体育课教学反思
2016/02/16 职场文书
详解Python魔法方法之描述符类
2021/05/26 Python