草庐IT

每天一个JavaScript小特效——会魔法的旋转魔方相册

前端小刘不怕牛牛 2023-03-28 原文
<font size= 4px>写在前面:</font> <font color=skyblue> 星光不问赶路人,时光不误有心人</font> 本栏将持续更新前端小案例~ 牛牛最近学到了一个神奇的旋转魔方,今天就来分享给大家吧,希望大家能喜欢 <font color=orange >最后有完整代码链接,请注意查收</font>

效果图

实现功能: 点击下方图片可翻转到对应图片

实现思路:

  1. 构建盒子模型,完成html代码编写
  2. 设置样式,利用transform3D做出魔方
  3. JS构建事件

1. HTML篇

魔方中用<li>标签包含图片,方便用<ul>包裹,后面给ul添加3D模式便可进行翻折

比较简单不过多讲解,代码如下:

2. CSS篇

2.1 基础设置

清除样式默认的内外边距,直接上代码:

2.2 魔方样式

  • 主要是给父元素设置transform-style: preserver-3d;,对所有li子元素进行3D转换,后面便于用transform折叠
  • 这里用子绝父相的定位模式设定,是为了让ul下的所有li都放在父元素ul框内 也就是给每个li加定位——top: 0 ;left: 0;
  • 如果你设置的图片的原本尺寸并不是一致,你需要给img强制设置宽高,这样图片会强制更改自身尺寸
  • transition属性设置:
    1. 第一属性值是选择子元素的种类,all就是全部子元素
    2. 第二属性值是持续时间
    3. 第三属性值是速度变化曲线,这里用到的是贝塞尔曲线,这个无需过多关注,可以直接拿来用,值得说的是,第四个属性值你可以理解为最远达到距离,这里设置1.275就是魔方旋转到达目的地后在转个0.275,然后再回到目的地,这也是实现旋转抖动的原理

2.3 图片折叠

  • 前面其实已经做好铺垫,接下来我们只需要设置每个图片各XY的翻转角度,Z的位移,就可以组成魔方

  • 如果不知道怎么回事的,可以再重温一下transform的rotate属性,简单说明一下rotateX就是以X轴为对称中翻转,朝上为正,朝下为负,Y同理

  • 这里设置translateZ,简单理解就是把页面文档流看作地面,这里设置图片的高度, 全部设置为100px是为了让图片在一个高度,构成封闭魔方

代码实现如下:

2.4 图片按钮样式

也就是实现下面效果

这一块比较简单,牛牛就不多做介绍,讲一个文章出现过的知识点——background-size: contain; 该属性会保持图像的纵横比并将图像缩放成将适合背景定位区域的最大大小。

2.5 设置配合JS使用的翻转样式

这里需要 一定的理解能力,建议配合后面的JS代码一起看

讲一下具体思路:

  • 当我们对下方图片触发点击事件时,通过JS给魔方的ul加相对应类名,类名对应设置了transform样式,也就实现了点击触发相对应的魔方旋转

  • 下面代码的原理和上一节一致,不过需要注意的是,下面旋转的对象是整个魔方,而上一节旋转对象只是相对应的一张图片而已。

3. JS篇

最关键的部分来了

  • 首先我们需要知道,这块JS代码是用来为事件服务的,需要遵循三步就行:获取变量、创建事件、回调函数
  • 定义变量比较简单,根据自己创建事件中需要什么,去获取页面对象
  • 接下来我们需要实现当点击下方图片时,需要分辨是哪一张,我们可以看到在html篇中下方图片的类名其实是跟2.5节需要设置的类名是相对应的
  • 因此我们直接创建onclick事件,在回调函数中将点击图片的类名赋给我们的ul盒子,点击哪个图片,就执行对应的翻转
  • 小实践: 创建事件大家会不会觉得有些代码重复赘余的感觉,其实我们可以把这个回调函数封装起来,调用函数传入序号即可实现,感兴趣的可以做一下,如果需要封装代码,可以在评论区留言,牛牛会找个时间更新一下

4. 完整代码

4.1 html文件

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>旋转魔方相册</title> <style> *{ margin: 0; padding: 0; } body{ background-color: rgba(0, 0, 0, 0.8); } /* 魔方样式设置部分 */ .square{ width: 200px; height: 200px; margin: 200px auto; margin-bottom: 100px; } ul{ position: relative; transform-style: preserve-3d; transition: all .7s cubic-bezier(0.175, 0.885, 0.32, 1.275); width: 100%; height: 100%; } li{ /* display: inline-block; */ position: absolute; top: 0; left: 0; list-style: none; width: 100%; height: 100%; border: 1px solid pink; } img{ width: 200px; height: 200px; } /* 初始位置 */ /* ul{ transform: translateZ(-100px) rotateX(-15deg) rotateY(15deg); } */ /* 折叠图片,构成魔方 */ ul li:nth-child(1) { transform: translateZ(100px); } ul li:nth-child(2) { transform: rotateY(180deg) translateZ(100px); } ul li:nth-child(3) { transform: rotateY(90deg) translateZ(100px); } ul li:nth-child(4) { transform: rotateY(-90deg) translateZ(100px); } ul li:nth-child(5) { transform: rotateX(90deg) translateZ(100px); } ul li:nth-child(6) { transform: rotateX(-90deg) translateZ(100px); } /* 下方是点击目录 */ .img_1{ background-image: url(2.jpeg); } .img_2{ background-image: url(1.jpeg); } .img_3{ background-image: url(3.jpeg); } .img_4{ background-image: url(4.jpeg); } .img_5{ background-image: url(5.jpeg); } .img_6{ background-image: url(6.jpeg); } span{ display: inline-block; width: 50px; height: 25px; background-size: contain; border: 1px solid white; } .toc{ width: 350px; margin: 0 auto; } /* 辅助JS块样式设置 */ .square .img_1 { transform: translateZ(-100px); } .square .img_2 { transform: translateZ(-100px) rotateX(-180deg) ; } .square .img_3 { transform: translateZ(-100px) rotateY(-90deg) ; } .square .img_4 { transform: translateZ(-100px) rotateY(90deg) ; } .square .img_5 { transform: translateZ(-100px) rotateX(-90deg) ; } .square .img_6 { transform: translateZ(-100px) rotateX(90deg) ; } </style> </head> <body> <!-- 魔方 --> <div class="square"> <ul class="s-img"> <li><img src="2.jpeg"></li> <li><img src="1.jpeg"></li> <li><img src="3.jpeg"></li> <li><img src="4.jpeg"></li> <li><img src="5.jpeg"></li> <li><img src="6.jpeg"></li> </ul> </div> <!-- 手动点击旋转 --> <div class="toc"> <span class="img_1"></span> <span class="img_2"></span> <span class="img_3"></span> <span class="img_4"></span> <span class="img_5"></span> <span class="img_6"></span> </div> <!-- JS --> <script src="cube.js"> </script> </body> </html>

4.2 js文件

window.onload = function(){ //toc目录设置 var toc_img = document.querySelector('.toc'); var square = document.querySelector('ul'); var p_img = square.classList; var img_button = toc_img.querySelectorAll('span'); var flage = ''; img_button[0].onclick = function(e) { flage = img_button[0].className; square.setAttribute('class', flage); } img_button[1].onclick = function(e) { flage = img_button[1].className; square.setAttribute('class', flage); } img_button[2].onclick = function(e) { flage = img_button[2].className; square.setAttribute('class', flage); } img_button[3].onclick = function(e) { flage = img_button[3].className; square.setAttribute('class', flage); } img_button[4].onclick = function(e) { flage = img_button[4].className; square.setAttribute('class', flage); } img_button[5].onclick = function(e) { flage = img_button[5].className; square.setAttribute('class',flage); } } 以上就是今天分享的全部内容啦,谢谢观看,如果觉得对您有帮助的话,可否给牛牛一个小小的赞和关注呢?

债见~

有关每天一个JavaScript小特效——会魔法的旋转魔方相册的更多相关文章

  1. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  2. ruby-on-rails - Rails - 一个 View 中的多个模型 - 2

    我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何

  3. ruby-on-rails - 渲染另一个 Controller 的 View - 2

    我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>

  4. ruby-on-rails - 如果 Object::try 被发送到一个 nil 对象,为什么它会起作用? - 2

    如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象

  5. ruby - 为什么 SecureRandom.uuid 创建一个唯一的字符串? - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?

  6. ruby-on-rails - Rails - 从另一个模型中创建一个模型的实例 - 2

    我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案

  7. ruby - 用 Ruby 编写一个简单的网络服务器 - 2

    我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b

  8. ruby - 一个 YAML 对象可以引用另一个吗? - 2

    我想让一个yaml对象引用另一个,如下所示:intro:"Hello,dearuser."registration:$introThanksforregistering!new_message:$introYouhaveanewmessage!上面的语法只是它如何工作的一个例子(这也是它在thiscpanmodule中的工作方式。)我正在使用标准的ruby​​yaml解析器。这可能吗? 最佳答案 一些yaml对象确实引用了其他对象:irb>require'yaml'#=>trueirb>str="hello"#=>"hello"ir

  9. ruby - Rails 关联 - 同一个类的多个 has_one 关系 - 2

    我的问题的一个例子是体育游戏。一场体育比赛有两支球队,一支主队和一支客队。我的事件记录模型如下:classTeam"Team"has_one:away_team,:class_name=>"Team"end我希望能够通过游戏访问一个团队,例如:Game.find(1).home_team但我收到一个单元化常量错误:Game::team。谁能告诉我我做错了什么?谢谢, 最佳答案 如果Gamehas_one:team那么Rails假设您的teams表有一个game_id列。不过,您想要的是games表有一个team_id列,在这种情况下

  10. ruby-on-rails - 如何在 Ruby on Rails 中实现由 JSF 2.0 (Primefaces) 驱动的 UI 魔法 - 2

    按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。问题1)我想知道ruby​​onrails是否有功能类似于primefaces的gem。我问的原因是如果您使用primefaces(http://www.primefaces.org/showcase-labs/ui/home.jsf),开发人员无需担心javascript或jquery的东西。据我所知,JSF是一个规范,基于规范的各种可用实现,prim

随机推荐