好吧,这里直接编辑源码并不允许设置css和js……毕竟会有危险……那直接放代码吧

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<title>vue-test</title>
<link rel="stylesheet" href="cube.css"><!--css-->
<script src="jquery-3.3.1.min.js"></script><!--引入jquery-->
<style>
.contain{
margin-top:100px;
position:relative;
width:800px;
height:400px;
background:black;
padding:20px;
text-align:center; }
.row{
position:relative;
}
.contain .button-container{ }
.contain .cube-container{ width:300px;
height:300px;
margin:auto;
}
.content-container{
color:white;
border:1px solid white;
width:300px;
max-height:400px;
overflow:auto;
position:absolute;
left:20px;
top:20px;
display:none;
}
.contain .button-container .control-button{
width:40px;
height:40px;
background:black;
color:white;
border-radius:20px;
outline: none;
}
.contain .button-container .control-button.choose{
background:white;
color:black;
}
</style>
</head>
<body>
<div class="contain">
<div class="row">
<div class="cube-container">
<div class="cube animation-rotating">
<div class="surface surface1">1</div>
<div class="surface surface2">2</div>
<div class="surface surface3">3</div>
<div class="surface surface4">4</div>
<div class="surface surface5">5</div>
<div class="surface surface6">6</div><!---->
</div>
</div>
<div class="content-container">
<div class="content-title"></div>
<div class="content"></div>
</div>
</div>
<div class="button-container">
<button class="control-button choose">0</button>
<button class="control-button">1</button>
<button class="control-button">2</button>
<button class="control-button">3</button>
<button class="control-button">4</button>
<button class="control-button">5</button>
<button class="control-button">6</button> </div>
</div> <script>
var content=[
{'title':'越人歌','content':'今夕何夕兮,搴舟中流。今日何日兮,得与王子同舟。蒙羞被好兮,不訾诟耻。心几烦而不绝兮,得知王子。山有木兮木有枝,心悦君兮君不知。'},
{'title':'木兰花·拟古决绝词柬友','content':'人生若只如初见,何事秋风悲画扇。等闲变却故人心,却道故人心易变。骊山语罢清宵半,泪雨霖铃终不怨。何如薄幸锦衣郎,比翼连枝当日愿。'},
{'title':'江城子·乙卯正月二十日夜记梦','content':'十年生死两茫茫,不思量,自难忘。千里孤坟,无处话凄凉。纵使相逢应不识,尘满面,鬓如霜。夜来幽梦忽还乡,小轩窗,正梳妆。相顾无言,惟有泪千行。料得年年肠断处,明月夜,短松冈'},
{'title':'离思五首·其四','content':'曾经沧海难为水,除却巫山不是云。取次花丛懒回顾,半缘修道半缘君。'},
{'title':'南歌子词二首 / 新添声杨柳枝词','content':'一尺深红胜曲尘,天生旧物不如新。合欢桃核终堪恨,里许元来别有人。井底点灯深烛伊,共郎长行莫围棋。玲珑骰子安红豆,入骨相思知不知。'},
{'title':'卜算子·我住长江头','content':'我住长江头,君住长江尾。日日思君不见君,共饮长江水。 此水几时休,此恨何时已。只愿君心似我心,定不负相思意。'},
];
$(document).ready(function(){
$('.cube .surface').hover(
function(e){
$(this).addClass('hover').siblings().removeClass('hover');
index=$(this).index()+1;//被指向哪一面,数值1-6
$('.control-button').eq(index).addClass('choose').siblings().removeClass('choose');//那一面绑定的按钮处于选择状态
$(this).parent().attr('class','cube show'+index);//正方体停止旋转并转向该面
//显示内容
$('.content-container .content-title').html(content[index-1]['title']);
$('.content-container .content').html(content[index-1]['content']);
$('.content-container').css({'display':'block'});
},
function(e){
$(this).removeClass('hover');
$(this).parent().attr('class','cube animation-rotating');
$('.control-button').eq(0).addClass('choose').siblings().removeClass('choose');
$('.content-container').css({'display':'none'}); });
$('.control-button').on('click',function(){
index = $(this).index();//按钮的顺序,0是返回原始状态,1-6分别对应6个面
console.log(index);
if(index==0){//返回原始状态
$('.control-button').eq(0).addClass('choose').siblings().removeClass('choose');
$('.cube').attr('class','cube animation-rotating');//正方体重新运转
$('.hover').each(function(){//没有任何一面处于hover状态
$(this).removeClass('hover');
});
$('.content-container').css({'display':'none'}); }
else{//触发1-6面被hover的状态
$('.cube .surface').eq(index-1).trigger('mouseenter');
} }); });
</script> </body>
</html>

index.html

    .cube-container{
perspective:1000px;
-webkit-perspective:1000px;
transform:scale(0.8);
}
.cube{
height: 200px;
width: 200px;
position: relative;
margin:auto;
transform-style:preserve-3d;/*定义3d转换*/
transition: all 1s; }
.cube.show1{
transform:rotateX(0deg) rotateY(0deg);
}
.cube.show2{
transform:rotateX(0deg) rotateY(180deg);
}
.cube.show3{
transform:rotateX(0deg) rotateY(90deg);
}
.cube.show4{
transform:rotateX(0deg) rotateY(-90deg);
}
.cube.show5{
transform:rotateX(-90deg) rotateY(0deg);
}
.cube.show6{
transform:rotateX(90deg) rotateY(0deg);
}
.animation-rotating{
animation:rotating 8s infinite;/*animation:动画名字 时长 无限循环 线性速度(匀速)*/
}
/*动画效果,也可以以百分百的方式。默认逆时针的方向旋转。*/
@keyframes rotating{
from{transfrom:rotate3d(0.5,-0.5,0,0deg)}
to{transform:rotate3d(0.5,-0.5,0,-360deg)}
}
.cube .surface{
height: 100%;
width: 100%;
opacity: 0.6;
position: absolute;
text-align: center;
background: black;
color:#fff;
line-height: 200px;
font-size: 30px;
border:1px solid #fff;
transition: all 1s;
}
.cube .surface1{
transform:translateZ(100px);
}
.cube .surface2{
transform:rotateY(180deg) translateZ(100px);
}
.cube .surface3{
transform:rotateY(-90deg) translateZ(100px);
}
.cube .surface4{
transform:rotateY(90deg) translateZ(100px);
}
.cube .surface5{
transform:rotateX(90deg) translateZ(100px);
}
.cube .surface6{
transform:rotateX(-90deg) translateZ(100px);
} .cube .surface1:hover, .cube .surface1.hover{
transform:translateZ(200px);
background:white;
color:black;
}
.cube .surface2:hover, .cube .surface2.hover{
transform:rotateY(180deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface3:hover, .cube .surface3.hover{
transform:rotateY(-90deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface4:hover, .cube .surface4.hover{
transform:rotateY(90deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface5:hover, .cube .surface5.hover{
transform:rotateX(90deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface6:hover, .cube .surface6.hover{
transform:rotateX(-90deg) translateZ(200px);
background:white;
color:black;
}

cube.css

界面实例--旋转的3d立方体的更多相关文章

  1. 纯CSS3实现一个旋转的3D立方体盒子

    简单介绍 上网易前端微专业课程,里面有一个课外作业是实现一个3D旋转立方体.花了点时间做了下.还有点意思.写个简单教程.供大家学习. 先放上终于要实现的效果 注:代码在chrome 43.0.2357 ...

  2. CSS动画实例:3D立方体

    CSS3支持3D转换,与3D转换有关的属性有: transform:向元素应用 2D或3D 转换. transform-origin:改变被转换元素的位置. transform-style:规定被嵌套 ...

  3. css3-实现3D立方体旋转

    核心内容: 1.CSS3 中 animation.perspective 属性的熟练运用. 2.CSS3 中的变形属性 transform,在 3D 立体效果中的运用. 3.3D 立方体旋转实现原理. ...

  4. 基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转

    基于css3新属性transform,实现3d立方体的旋转 通过原生JS,点击事件,鼠标按下.鼠标抬起和鼠标移动事件,实现3d立方体的拖动旋转,并将旋转角度实时的反应至界面上显示 实现原理:通过获取鼠 ...

  5. 基于css3的3D立方体旋转特效

    今天给大家分享一款基于css3的3D立方体旋转特效.这款特效适用浏览器:360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗. 不支持IE8及以下浏览器.效果图如下 : ...

  6. js拖拽3D立方体旋转

    这段时间有点闲,所以就自己找些小玩意来练习练习.今天做了一个可以拖拽页面内空白位置3D立方体就会跟着转动的小例子,布局方面用到css3 3D转换技术,通过transform控制旋转实现的. 上个图 代 ...

  7. Opengl ES 1.x NDK实例开发之七:旋转的纹理立方体

    开发框架介绍请參见:Opengl ES NDK实例开发之中的一个:搭建开发框架 本章在第六章(Opengl ES 1.x NDK实例开发之六:纹理贴图)的基础上绘制一个旋转的纹理立方体,原理和纹理贴图 ...

  8. CSS3 3D立方体效果-transform也不过如此

    CSS3系列已经学习了一段时间了,第一篇文章写了一些css3的奇技淫巧,原文戳这里,还获得了较多网友的支持,在此谢过各位,你们的支持是我写文章最大的动力^_^. 那么这一篇文章呢,主要是通过一个3D立 ...

  9. css3实践—创建3D立方体

    css3实践-创建3D立方体 要想实现3D的效果,其实非常简单,只需指定一个元素为容器并设置transform-style:preserve-3d,那么它的后代元素便会有3D效果.不过有很多需要注意的 ...

随机推荐

  1. [Recompose] Configure Recompose to Build React Components from RxJS Streams

    Recompose provides helper functions to stream props using an Observable library of your choice into ...

  2. SDSoC使用体验

    本文作者:卜居 转载请保留作者信息.原文网址(http://blog.csdn.net/kkk584520/article/details/47220575). 本文project可到我的资源下载(h ...

  3. Android开发之Volley网络通信框架

    今天用了一下Volley网络通信框架,感觉挺好用的,写个博客记录一下用法.方便以后VC. Volley(Google提供的网络通信库,能使网络通信更快,更简单,更健壮.) 功能模块: 1. JSON, ...

  4. eclipse C开发添加自己的头文件搜索路径

    eclipse编译C程序时提示: ..\src\main.c:8:21: fatal error: my_type.h: No such file or directory 如图: 需要添加自己的头文 ...

  5. mysql日期函数及批量循环返回主键ID

    实际项目中总是会遇到各种时间计算查询等等许多时候是特别麻烦前阵子公司有个需求大致是要查询当前日期与数据库存储日期之差,本来写了个工具类调用的但是最后觉得这样不好就想着能不能用函数解决,没想到还真有这里 ...

  6. Vue或React多页应用脚手架

    https://github.com/zhujiasheng/vue-multipage https://github.com/MeCKodo/vue-multipage

  7. Atcoder B - Moderate Differences

    http://agc017.contest.atcoder.jp/tasks/agc017_b B - Moderate Differences Time limit : 2sec / Memory ...

  8. 在Ubuntu14.04中配置mysql远程连接教程

    上一篇文章,小编带大家学会了在Ubuntu14.04中安装MySQL,没有来得及上课的小伙伴们可以戳这篇文章:如何在Ubuntu14.04中安装mysql,今天给大家分享一下,如何简单的配置MySQL ...

  9. HDU 3714 Error Curves

    Error Curves 思路:这个题的思路和上一个题的思路一样,但是这个题目卡精度,要在计算时,卡到1e-9. #include<cstdio> #include<cstring& ...

  10. jquery事件 【mousedown与mouseup ----keydown与keypress与keyup】focus--blur--orrer--pageX-pageY

    <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> ...