JS1K是JavaScript编程竞赛——参加竞赛的规则很简单,脚本必须小于1K,竞赛网站开始也只是为了娱乐,却意外地收到了很多优秀的作品。

这是2016年JS1k上传的作品,用几十行代码实现的一个3D旋转魔方:

代码如下:

function z(t, e) {

return t? e? t.appendChild(e) : "width:"+t+"px;height:"+t+"

px;position:absolute;" : document.createElement("div")

}

function w() {

++t==360&&(t=0, x=++x%3)

for (i in m) 2 == m[i][s[x]] ? m[i][u][a] = r+s[x]+"(" + t + "deg)" : 0;

c[u][a] = r+"3d(1,1,1," + t + "deg)",

requestAnimationFrame(w)

}

var a = "transform",

p = "background-color:",

y = a+"-style:preserve-3d;",

u = "style",

v = "cssText",

B = z(),

c = z(),

t = x = 0,

d, e, f, g, h, k, l, m = [], n, i, r="rotate", s = ["X","Y","Z"];

B[u][v] = "perspective:900px;"+z(600)+p+"#666";

c[u][v] = y + z(240) +"top:30%;left:30%", z(B, c), z(window.b, B);

for (l = 27; l--; z(c, f)) {

f = z(),

f[u][v] = y + z(240),

f.X = g = l % 3,

f.Y = h = (l - g) % 9 / 3,

f.Z = k = ~~(l / 9), e = z(),

e[u][v] = y + z(80) +a+":translate3d(" + 80 * g + "px," +

80 * h + "px," + 80 * (k-1) + "px)";

for (n = 6; n--; z(e, d))

d = z(),

d[u][v] = y + z(72) + "border-radius:9px;border:4px solid

#000;opacity:0.9;"+a+":"+r+"X(" + (4 > n ? 90 * n : 0)

+ "deg)"+r+"Y(" + (4 > n ? 0 : 4 == n ? -90 : 90) + "deg)translateZ(40px);"+p+

(0==n&&2==k?"#05C":1==n&&0==h?"#FD0":

2==n&&0==k?"#0A6":3==n&&2==h?"#FFF":4==n&&0==g?"#F60":5==n&&2==g?"#C24":"#000");

z(f, e), m.push(f)

}

w();

知识点扩展

JS如何实现旋转的魔方,浏览器从其他标签页回来依然匀速旋转?

Document

front
back
left
right
top
bottom

.cube {

width: 400px;

height: 400px;

transition: all 3s;

margin: 300px auto;

/* 作用于所有3d转换的子元素 设置给父级 */

/* perspective: 1000px; */

/* transform: rotateX(30deg) rotateY(45deg); */

/* 平面到立方 默认值:平面flat*/

transform-style: preserve-3d;

position: relative;

}

/* div:hover {

transform: rotateY(90deg) translateZ(-200px);

opacity: 0.5;

} */

.front,

.back,

.left,

.right,

.top,

.bottom {

width: 100%;

height: 100%;

text-align: center;

line-height: 400px;

position: absolute;

opacity: 0.9;

left: 0;

top: 0;

}

.front {

background-color: palevioletred;

background-image: url('http://img1.gtimg.com/tj/pics/hv1/117/208/2153/140051982.jpg');

transform: translateZ(200px);

}

.back {

background-color: yellow;

transform: translateZ(-200px);

background-image: url('https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=841408372,3004217725&fm=11&gp=0.jpg');

}

.left {

background-color: pink;

background-image: url('https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2388632836,3966607624&fm=26&gp=0.jpg');

transform: rotateY(90deg) translateZ(-200px)

}

.right {

background-color: yellowgreen;

background-image: url('https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=192610795,467565159&fm=26&gp=0.jpg');

transform: rotateY(90deg) translateZ(200px)

}

.top {

background-color: skyblue;

background-image: url("https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2936477803,4198185787&fm=15&gp=0.jpg");

transform: rotateX(90deg) translateZ(200px)

}

.bottom {

background-color: orange;

background-image: url('http://img0.pclady.com.cn/pclady/1611/02/1612285_jyz.jpg');

transform: rotateX(90deg) translateZ(-200px)

}

window.onload = function () {

let cube = document.querySelector('.cube')

let timer = null

let x = 0; y = 0;

function rotate() {

cube.style.transform = 'rotateX(' + x + 'deg)' + '' + 'rotateY(' + y + 'deg)';

x += 30

y += 45

}

function stop() {

clearInterval(timer)

}

clearInterval(timer);

timer = setInterval(() => {

rotate();

}, 1000);

// 监听是否在当前页,并置为已读

// document.addEventListener("visibilitychange", function () {

// if (document.hidden) { //不处于当前页面

// // do something

// clearInterval(timer)

// } else {

// timer;

// }

// });

var hiddenProperty = 'hidden' in document ? 'hidden' :

'webkitHidden' in document ? 'webkitHidden' :

'mozHidden' in document ? 'mozHidden' :

null;

var visibilityChangeEvent = hiddenProperty.replace(/hidden/i, 'visibilitychange');

var onVisibilityChange = function () {

if (!document[hiddenProperty]) {

timer = setInterval(() => {

rotate();

}, 1000);

console.log(hiddenProperty);

} else {

clearInterval(timer)

}

}

document.addEventListener(visibilityChangeEvent, onVisibilityChange);

// document.addEventListener("visibilitychange", function () {

// if (!document.hidden) { //处于当前页面

// timer = setInterval(() => {

// rotate();

// }, 1000);

// console.log('active');

// } else {

// clearInterval(timer);

// console.log('hidden');

// }

// });

}

html旋转3d魔方制作方法,JavaScript实现的3D旋转魔方动画效果实例代码相关推荐

  1. 图书浏览界面html代码,javaScript+turn.js实现图书翻页效果实例代码

    为了实现图书翻页的效果我们在网上可以看到很多教程 在这里推荐turn.js 网上的turn.js 有api 不过是英文的  很多人看起来不方便 .关于代码也是奇形怪状在这里我将详细讲解如何使用turn ...

  2. html实现图片加载动画效果,HTML5+javascript实现图片加载进度动画效果

    在网上找资料的时候,看到网上有图片加载进度的效果,手痒就自己也写了一个. 图片加载完后,隐藏loading效果. 想看加载效果,请ctrel+F5强制刷新或者清理缓存. 效果预览: 0% 代码如下: ...

  3. php编写九九乘法表隔行换色,JavaScript实现99乘法表及隔行变色实例代码

    项目需求:实现在页面中输出99乘法表.(要求:以每三行为一组,实现隔行变色(颜色为白,红,黄(也可自己定义)),鼠标滑过每一行,行背景颜色变为蓝色,鼠标离开又恢复原来的颜色),隔行变色的效果需要用if ...

  4. php九九乘法表隔行换色,JavaScript实现99乘法表及隔行变色实例代码_javascript技巧...

    项目需求:实现在页面中输出99乘法表.(要求:以每三行为一组,实现隔行变色(颜色为白,红,黄(也可自己定义)),鼠标滑过每一行,行背景颜色变为蓝色,鼠标离开又恢复原来的颜色),隔行变色的效果需要用if ...

  5. JavaScript 身份证号有效验证详解及实例代码

    这篇文章主要介绍了JavaScript 身份证号有效验证详解及实例代码的相关资料,需要的朋友可以参考下 JavaScript验证身份证号 1 2 3 4 5 6 7 8 9 10 11 12 13 1 ...

  6. JavaScript打造很酷的图片放大效果实例代码

    代码简介: 非常酷的一个JavaScript图片放大效果,不信就运行一下试试,相信你会喜欢的. 代码内容: View Code <html><head><title> ...

  7. 【web前端】JavaScript实现图片幻灯片滚动播放动画效果

    JavaScript实现图片幻灯片滚动播放动画效果 by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.co ...

  8. html切换搜索引擎,JavaScript切换搜索引擎的导航网页搜索框实例代码

    废话不多说了,直接给大家贴代码了,具体代码如下所述: #search ul { list-style-type: none; display: block; width: 100px; height: ...

  9. 【web前端特效源码】使用HTML5+CSS3制作一个会动的电脑桌面+昼夜变化动画效果~~适合初学者~超简单~ |前端开发

    b站视频演示效果: [web前端特效源码]使用HTML5+CSS3制作一个会动的电脑桌面+昼夜变化动画效果~~适合初学者~超简单~ |前端开发|IT软件 效果图: 完整代码: <!DOCTYPE ...

  10. html中制作烟花的效果代码,css3+js实现烟花绽放的动画效果(代码示例)

    本篇文章给大家介绍通过js+css3的transforms属性和keyframes属性来实现烟花绽放的动画效果的方法.有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助. 首先我们来看看效 ...

最新文章

  1. 量子计算机科学原理,1000字看懂IBM量子计算机原理
  2. 【python】一次移动平均算法
  3. 【机器学习】基于人工鱼群算法的非线性函数寻优
  4. python图案填充_向imshow Matplotlib添加图案填充
  5. tensorflow.python.framework.errors_impl.DataLossError:
  6. java中insert函数
  7. Docker安装及基本使用
  8. c++构造函数和析构函数的调用顺序研究
  9. 【Iphone 游戏开发】游戏引擎剖析
  10. iOS之多线程的使用和优缺点比较
  11. 文件另存为时名称会改变_易经:人处在困境时,不要焦虑,改变固定习惯,就会迎来转机...
  12. 2020快手食品行业数据价值报告
  13. C#.Net工作笔记008---c# 日期时间大小比较_日期相减
  14. 问题 K: A+B Problem (III) : Input/Output Practice 山东科技大学OJ c语言
  15. php高效获取数据分页
  16. 上传文件到sftp服务器
  17. java 骰子游戏_Java编写掷骰子游戏
  18. java http请求发送unicode_Java发送http请求
  19. 【2023】北京大学计算机考研信息汇总
  20. 4.一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?

热门文章

  1. js 利用audio buffers[int16Array]计算分贝
  2. phpyun怎么采集_phpyun采集
  3. 图解傅里叶变换(时域频域)
  4. javascript特效大全
  5. 计算机网络的定义以及分类
  6. 代码评审系统 ReviewBoard 和 Gerrit
  7. ubuntu Empathy msn验证出错
  8. 使用curl自动签到百度贴吧
  9. CuteFTP使用手册
  10. [SPSS]典型相关分析的SPSS实现——开卷和闭卷学科成绩的典型相关分析实例