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 相关文章推荐
Jquery从头学起第四讲 jquery入门教程
Aug 01 Javascript
DIV+CSS+JS不间断横向滚动实现代码
Mar 19 Javascript
jQuery ui 利用 datepicker插件实现开始日期(minDate)和结束日期(maxDate)
May 22 Javascript
推荐25个超炫的jQuery网格插件
Nov 28 Javascript
Javascript中replace()小结
Sep 30 Javascript
JavaScript操作选择对象的简单实例
May 16 Javascript
react系列从零开始_简单谈谈react
Jul 06 Javascript
vue项目中添加单元测试的方法
Jul 21 Javascript
JavaScript展开操作符(Spread operator)详解
Jul 20 Javascript
vue轮播组件实现$children和$parent 附带好用的gif录制工具
Sep 26 Javascript
Vue实现简易计算器
Feb 25 Javascript
uniapp开发小程序实现滑动页面控制元素的显示和隐藏效果
Dec 10 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
php 取得瑞年与平年的天数的代码
2009/08/10 PHP
php通过正则表达式记取数据来读取xml的方法
2015/03/09 PHP
PHP获取用户客户端真实IP的解决方案
2016/10/10 PHP
php实现获取近几日、月时间示例
2019/07/06 PHP
Javascript图像处理思路及实现代码
2012/12/25 Javascript
js获取select默认选中的Option并不是当前选中值
2014/05/07 Javascript
JS数组(Array)处理函数整理
2014/12/07 Javascript
JavaScript、tab切换完整版(自动切换、鼠标移入停止、移开运行)
2016/01/05 Javascript
jquery checkbox的相关操作总结
2016/10/17 Javascript
JavaScript实现的CRC32函数示例
2016/11/23 Javascript
node.js基于mongodb的搜索分页示例
2017/01/22 Javascript
js中document.referrer实现移动端返回上一页
2017/02/22 Javascript
js断点调试经验分享
2017/12/08 Javascript
JavaScript实现区块链
2018/03/14 Javascript
vue-lazyload使用总结(推荐)
2018/11/01 Javascript
vue 插件的方法代码详解
2019/06/06 Javascript
简述Vue中容易被忽视的知识点
2019/12/09 Javascript
[04:05]TI9战队采访 - Natus Vincere
2019/08/22 DOTA
用Python实现一个简单的多线程TCP服务器的教程
2015/05/05 Python
python处理图片之PIL模块简单使用方法
2015/05/11 Python
Python中基础的socket编程实战攻略
2016/06/01 Python
Python列表和元组的定义与使用操作示例
2017/07/26 Python
Python用sndhdr模块识别音频格式详解
2018/01/11 Python
Python+OpenCV实现车牌字符分割和识别
2018/03/31 Python
python 统计列表中不同元素的数量方法
2018/06/29 Python
python读取xlsx的方法
2018/12/25 Python
numpy下的flatten()函数用法详解
2019/05/27 Python
解决Python发送Http请求时,中文乱码的问题
2020/04/30 Python
使用python实现学生信息管理系统
2021/02/25 Python
CSS+jQuery+PHP+MySQL实现的在线答题功能
2015/04/25 HTML / CSS
利用简洁的图片预加载组件提升html5移动页面的用户体验
2016/03/11 HTML / CSS
2015小学师德工作总结
2015/07/21 职场文书
毕业班工作总结
2015/08/10 职场文书
2016年教师政治思想表现评语
2015/12/02 职场文书
《司马光》教学反思
2016/02/22 职场文书
使用JS前端技术实现静态图片局部流动效果
2022/08/05 Javascript