百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

站在巨人的肩膀上——制作酷炫web幻灯片

zhezhongyun 2025-02-09 15:03 14 浏览

你是否还在用ppt做一些毫无意思的幻灯片?你是否在做ppt的时候绞尽脑汁想把效果做的吸引大家?你是否想通过一次ppt吸引领导的注意?那好吧!来学学怎么制作一款炫酷的web幻灯片~

  • ps:如果看到这里还不感兴趣就请先看看素材演示,这个演示是前些时候给组里新人介绍HTML5的时候自己做的一款幻灯片!

工具

  1. 一款最近版本的chrome浏览器(火狐,safari也可)

  2. 一款趁手的IDE工具

  3. impress.js君(您也可下载本页素材进行自己需求的修改)

优点

几乎不需要写任何JS,只需要在每个子页DOM处添加几个属性就可达到效果!至于CSS嘛,根据你的幻灯片需求,看情况写啦!

操作时候可以用键盘空格、光标或者鼠标滚轮控制幻灯片切换

原理

看完效果大多数人应该就了解了原理,在这里还是罗嗦一下:其实每一个子页就是id为impress的div下的一级div,impress将他们每个起始位置或动画角度定好(由我们来配),当子页出现时候通过平滑的css动画过度到屏幕正向面前。就好像一张大纸上画了好几个div,屏幕就像一个放大镜焦点,从第一个div开始,挨个看div,在过程中不断平移或旋转这个大纸(3d效果动画另说)。

HTML部分结构

  1. ....

  2. 子页一

  3. 子页二

  4. 子页三

  5. 子页四

  6. ....

  • ....

  • JS代码部分

    除了引入impress.js就是下面这句了:

    API

    • data-x:幻灯片的x坐标(子页面出现时候进行平移)

    • data-y:幻灯片的y坐标(子页面出现时候进行平移)

    • data-z:幻灯片的z坐标(子页面出现时候进行z轴深度的平移)

    • data-scale:缩放。通过指定一个值来进行缩放,将该子页出现时进行放大,同时其他子页就会相对变小

    • data-rotate:旋转。通过一个数字度数来确定旋转你的幻灯片

    • data-rotate-x:为3D用,这个数字度数是它应该相对x轴旋转多少度。(前倾/后仰)

    • data-rotate-y:为3D用,这个数字度数是它应该相对y轴旋转多少度。 (左摆/右摆)

    • data-rotate-z:为3D用,这个数字度数是它应该相对z轴旋转多少度。

    一共就这几个参数,配置在每个子页div的DOM上

    DEMO

    1. ……

    2. …………

    3. 进入正题

    4. HTML 5

    5. *W3C万维网联盟

  • 语义

  • HTML5 引入了新的 HTML 元素,通过使用这些元素,开发者可以更细致的描述文档结构,让文档更加易读,搜索引擎也能更好的理解页面中各部分间的关系,我们也可以搜索到更快,更准确的信息。

  • …………

  • ……

  • 这是幻灯片中的一个片段,截取了源码中两个子页代码,从这里可以读出3个要点:

    1. 每个子页是一个div,必须有一个step作为class,如果没有,这个div将不会在幻灯片进行时候出现

    2. api中的属性写在子页div中

    3. 每个子页的自定义css可以定义class或者id写在css文件中

    到这里,聪明的读者应该已经迫不及待的,想要靠自己的智慧想要去亲手做一个了。但是这时候我再废话几句我的源码:

    1、第一个子页这里data-x,data-y是可以从0开始的,之所以这样其实是想告诉大家这里可以不从0开始,哈哈!可以把定位在0子页之前的这种子页当成幻灯片前言

      1. HTML5 介绍

    2、源码最后的子页有个这个空的div,其实是为了展示出来“整张大纸”的全景,坐标是自己摸索出来的,放大倍数也是根据内容多少而大致试出来的。这个div其实定义了style:display:none,但是幻灯片还是会展示,只是个空的而已。也就是说即便对他设置了css让他隐藏,但只要有step这个class在,一样不会被忽略!

    点击这里在线调试和把玩相关代码

    点击阅读原文获得更多精彩内容

    相关推荐

    字体缩放(方式一)(字体缩放150%怎么做)

    通过元素宽度和字数计算得到缩放简单实现如下:/***字体最大为视觉要求大小(maxFontSize);超出缩小字体显示,最小为minFontSize;最小字体时超出部分使用圆点(...);*p...

    网页世界隐藏的神秘代码语言,竟能这样改变布局

    CSS基础:选择器与属性CSS(CascadingStyleSheets)是用于控制网页外观的一门样式表语言。它通过定义HTML元素的显示方式来增强网页的表现力。CSS的选择器允许开发者精确地定位...

    CSS属性值计算过程详解(css属性用来定义元素计算)

    在CSS中,即使某些属性没有显式声明,浏览器也会通过**属性值计算过程**为每个元素的所有属性赋予最终值。这一过程分为四个关键步骤,以下将逐一解析。1.确定声明值浏览器首先检查所有**直接应用**到...

    软网推荐:找回调整Windows 10字号功能

    之前的系统,从WindowsXP到早期版本的Windows10,均有字体大小调整功能,但从创意者版Windows10以来,取消了之前的设置选项,取而代之的是自定义缩放比例设置。使用这个功能调整过...

    Excel中如何设置文本框属性,实例代码讲解

    Excel不仅可以对数据进行处理,而且也可以图形化数据,直观显示数据表达的内容。本节介绍一个很重要的对象,Characters,字符对象,使用Characters对象可修改包含在全文本字符串中的任...

    CSS 字体样式(css中字体)

    本节我们来讲字体样式,之前我们学习HTML的时候学过一些用于字体加粗、倾斜的标签,但是使用标签来实现的效果肯定没有我们通过CSS中的样式来的方便。接下来我们会给大家介绍下面这几个属性的使用:通...

    PC网站建设必备代码知识:HTML基础与应用技巧

    在PC网站建设的相关课程里,代码扮演着至关重要的角色。只有熟练运用正确的代码,我们才能打造出功能完善、用户体验出色的PC网站。接下来,我会详细讲解在PC网站建设环节中必须了解的代码知识。HTML基础代...

    让你大跌眼镜的疯狂 HTML 和 CSS 技巧

    今天,分享一个让你大开眼界的技巧。通过使用这个技巧,你可以将整个网页变成一个CSS编辑器。没错,你从未见过这种方法。当我第一次尝试时,我完全被震惊到了。现在,让我们开始吧!步骤1首先,创建一个基础的...

    jQuery EasyUI使用教程:创建一个链接按钮

    jQueryEasyUI最新版下载>本教程主要为大家展示如何使用jQueryEasyUI创建一个链接按钮。通常情况下,使用“button/”元素来创建一个按钮;使用“a/”元素来创建链接按钮...

    React 19 有哪些新特性?(react100)

    如果你对React18还不熟悉,欢迎阅读之前的文章《React18全览[1]》最近React发布了V19RC版本,按照惯例,我们对React19的新特性进行一次深度的体验学习...

    Java注解探秘:为什么@PostConstruct能解决你的初始化难题?

    你是否在Spring项目中遇到过这样的困扰:明明依赖注入已经完成,但某些配置就是无法正常加载?手动调用初始化方法又容易引发空指针异常?这就是@PostConstruct注解大显身手的时候了!@Post...

    AI驱动的表单自动填写(ai置入表格)

    我们都同意,填写表格是一项枯燥且耗时的任务。如果我们可以创建一个可以为我们填写表格的AI助手,让我们将时间投入到更有建设性的任务中,那会怎样?AI助手将能够通过调用以表单字段为参数的函数来填写表...

    从零到一:小程序设计新手如何快速上手?

    开发环境搭建对于小程序设计新手而言,搭建合适的开发环境是首要任务。以小程序为例,其官方提供了功能强大的开发工具——开发者工具。首先,新手需前往官方开发者平台,在页面中找到“工具下载”板块,根据...

    JavaSwingGUI从小白到大神-6(续)(java从小白到大牛怎么样)

    接上一篇《JavaSwingGUI从小白到大神-6》,因本篇文章3万多字,头条一篇发不完,只能分开发。同事查询面板:CompanyFind.javapublicclassCompanyFind{...

    C# winform界面假死(c#程序假死)

    针对C#WinForm界面假死问题,以下是分步解决方案:1.使用异步编程(async/await)将耗时操作移至后台线程,保持UI线程响应。步骤:将事件处理函数标记为async。使用Task....