最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

css如何实现图片的旋转展示效果(代码示例)

来源:动视网 责编:小采 时间:2020-11-02 22:12:42
文档

css如何实现图片的旋转展示效果(代码示例)

css如何实现图片的旋转展示效果(代码示例):本篇文章给大家带来内容是通过代码示例介绍使用css+js实现图片的旋转展示,制作一个手动操作的无限照片轮播图。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。下面我们就开始介绍如何实现效果。1、构建图像轮播框架首先是HTML。它
推荐度:
导读css如何实现图片的旋转展示效果(代码示例):本篇文章给大家带来内容是通过代码示例介绍使用css+js实现图片的旋转展示,制作一个手动操作的无限照片轮播图。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。下面我们就开始介绍如何实现效果。1、构建图像轮播框架首先是HTML。它
本篇文章给大家带来内容是通过代码示例介绍使用css+js实现图片的旋转展示,制作一个手动操作的“无限”照片轮播图。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

下面我们就开始介绍如何实现效果。

1、构建图像轮播框架

首先是HTML。它有点难以阅读,因为我们删除了元素之间的任何空格或回车。这样我们就可以使用JavaScript更轻松地引用不同的图像 - 空格或行在某些浏览器中创建新节点。

<div id="stage">
<div id="rotator"><a href="snow1.jpg"><img src="snow1.jpg" width="140"></a><a href="snow2.jpg"><img src="snow2.jpg" width="140"></a><a href="snow3.jpg"><img src="snow3.jpg" width="140"></a><a href="snow4.jpg"><img src="snow4.jpg" width="140"></a><a href="snow5.jpg"><img src="snow5.jpg" width="140"></a><a href="snow6.jpg"><img src="snow6.jpg" width="140"></a><a href="snow7.jpg"><img src="snow7.jpg" width="140"></a><a href="snow8.jpg"><img src="snow8.jpg" width="140"></a></div>
</div>

<p id="controls"><a href="#" onclick="rollLeft(document.getElementById('rotator')); return false;">←</a>
 <a href="#" onclick="rollRight(document.getElementById('rotator')); return false;">→</a></p>

正如你所看到的,那里没有太多需要解释的地方。画廊包含在DIV中,包括列出的照片/链接,然后是一些带有onclick事件的导航链接。

2、在3D空间中布置照片

造型更加复杂。我们在这里做的是将前五张照片塑造成凹形并隐藏任何额外的照片(暂时)。外部照片旋转60度,相邻照片旋转30度。中央照片被抬离页面。

#stage {
 margin: 1em auto;
 height: 120px;
 }
 #rotator {
 position: absolute;
 white-space: nowrap;
 -webkit-perspective: 1200px;
 -moz-perspective: 1200px;
 }
 #rotator a img {
 position: relative;
 padding: 10px;
 border: 1px solid #ccc;
 vertical-align: middle;
 }
 #rotator a:nth-child(1) img {
 -webkit-transform-origin: 100% 50% 0;
 -webkit-transform: rotateY(-60deg);
 -moz-transform-origin: 100% 50% 0;
 -moz-transform: rotateY(-60deg);
 }
 #rotator a:nth-child(2) img {
 -webkit-transform-origin: 0 50% 0;
 -webkit-transform: rotateY(-30deg);
 -moz-transform-origin: 0 50% 0;
 -moz-transform: rotateY(-30deg);
 }
 #rotator a:nth-child(3) img {
 -webkit-transform: translateZ(220px);
 -moz-transform: translateZ(220px);
 }
 #rotator a:nth-child(4) img {
 -webkit-transform-origin: 100% 50% 0;
 -webkit-transform: rotateY(30deg);
 -moz-transform-origin: 100% 50% 0;
 -moz-transform: rotateY(30deg);
 }
 #rotator a:nth-child(5) img {
 -webkit-transform-origin: 0 50% 0;
 -webkit-transform: rotateY(60deg);
 -moz-transform-origin: 0 50% 0;
 -moz-transform: rotateY(60deg);
 }
 #rotator a:nth-child(n+6) {
 display: none;
 }

为了引用单个照片/链接,我们使用了nth-child伪类(如果不清楚,在之前的文章【css伪类之nth-child()示例详解】里有介绍)。在这种情况下,链接(A)是父DIV的子代。如果没有链接,则孩子们将成为IMG元素。

3、旋转照片

您之前看到的一点JavaScript(onclick)调用以下函数。他们所做的就是从DOM中的照片数组的一端获取一个元素并将其移动到另一端:

<script type="text/javascript">
 function rollRight(el)
 {
 el.insertBefore(el.lastChild, el.firstChild);
 }
 function rollLeft(el)
 {
 el.appendChild(el.firstChild);
 }
</script>

JavaScript代码应该(几乎总是)放在页面的底部。

第一个函数将包含包含最后一个照片/链接(可见或隐藏)的节点,并将其放在第一个照片/链接之前。第二个函数获取第一个照片/链接并将其移动到行的末尾。使用onclick不是最优雅的方法,但现在它就足够了。

随着节点的移动,它们会采用分配给新位置(1,2,3,4,5或6+)的样式,因此我们需要做的就是改变它们的位置而不用担心移动或旋转。

4、效果展示

在这里,您可以看到旋转照片轮播的示例:

9.gif

大功告成,大家可以自己动手试试效果!

文档

css如何实现图片的旋转展示效果(代码示例)

css如何实现图片的旋转展示效果(代码示例):本篇文章给大家带来内容是通过代码示例介绍使用css+js实现图片的旋转展示,制作一个手动操作的无限照片轮播图。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。下面我们就开始介绍如何实现效果。1、构建图像轮播框架首先是HTML。它
推荐度:
标签: 图片 旋转 如何
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top