说前端很简单,我说,越简单的东西做好越难。
我们经常用css3写一些动画,很是方便,下面普及一个前端开发冷知识,css动画设置暂停 animation-play-state, 你用过吗?
看代码
鼠标一上去动画暂停,是不是涨姿势了? 基于它你是否已经有了更好动画实现的想法?
--
切图网qietu.com ,专注前端开发
击右上方红色按钮关注“小郑搞码事”,每天都能学到知识,搞懂一个问题!
大家可能会经常使用animation来处理一些动画效果,所以对animation这个CSS属性应该是非常熟悉。自定义一个动画过程,然后用animation来设置它的动画时间,动画效果,动画方式等等。
今天我们来想想,我们是否可控制animation的暂停和继续播放了? 答案是可以的,怎么搞了?一个属性:animation-play-state。
取值:paused(暂停)|running(播放)
竟然知道了用这个属性可以实现,那处理方式就有好多了,下面我来想几种常规思路。
JavaScript动态设置嘛,当用户点击按钮时,将animation-play-state属性设置到DOM上。效果就是下面这样的:
核心代码就是一段监听点击事件和设置animation-play-state属性:
很容易想得到,其实用纯CSS也可以实现animation的播放和暂停。
.stop:hover~.animation {
animation-play-state: paused;
}
radio标签的checked伪类,加上<label for>实现点击响应,这个在我之前的文章写纯CSS实现TAB切换时有详细讲的这个方法。这里同样也可以用来响应点击,从而控制动画的状态。
核心代码如下:
#stop:checked ~ .animation {
animation-play-state: paused;
}
#play:checked ~ .animation {
animation-play-state: running;
}
最后总结一下:
除了上面提到的一些处理方式,我现在能想到的至少还有一个伪类能实现,大家动动脑。
TML 规范的开发是一个渐进的过程,有时会出现问题。随着时间的推移,许多元素和属性被添加到 HTML 中,直到后来 Web 社区集体意识到有更好的方法时才被删除。由于已弃用和过时的元素和属性已经存在于网络上,因此许多现代浏览器继续支持它们的使用。尽管它们可能仍然有效,但您应该始终遵循最新版本的要求 HTML。不能保证浏览器对过时和弃用元素的支持会持续下去。有效但执行不A力。
有几种 HTML 元素和属性是有效的并且应该被使用,但是这些特性的实现随着时间的推移而发生了变化,而 Web 开发社区的一些人还没有注意到。HTMLtables就是一个很好的例子。table在某一时刻,使用 HTML元素创建网页布局是很常见的。几乎没有人再这样做了,CSS 比tables以往任何时候都更强大。但是,即使是经验丰富的 Web 开发人员,也存在许多其他不太严重的误用和语法错误。以下是一些经常被误用得完全有效且有用的 HTML 功能以及正确实现的示例。
虽然在技术上不是 HTML 元素,但DOCTYPE声明应该是每个 HTML 文档中出现的第一件事。这个声明是浏览器文档中代码的语言。过去,这个声明包括几个部分,可能会有点复杂。然而,在 HTML5 中,这很简单:
使用该声明开始每个人 HTML 文档,Web 浏览器将准确地知道您要说什么。
Web 浏览器必须知道用于编写文档的字符集才能正确呈现它。在绝大多数情况下,要声明的正确字符集是UTF-8。如果您需要声明其他任何内容,很可能您已经知道并知道如何去做。如果您不确定,请坚持使用 UTF-8 是一个安全的选择。在 HTML5 中声明字符集比在以前的 HTML 版本中要简单得多。这是现代 HTML5 中声明的正确语法:
只需将该行放到head您的 HTML 文档中即可。
过去,通常使用meta标签来提供版权信息。但是,这不是处理此任务的正确方法,并且网络爬虫无法识别标签的这种标签外使用meta。识别版权的正确方法是使用HTML 文档link中的元素,如下所示:head
您还可以在锚点和区域元素上使用rel="license"属性值对。
在过去,通常使用如下语法将脚本添加到 HTML 文档中:
这是有充分理由的。在某一时刻,许多浏览器无法识别script标签,并试图将标签之间的内容呈现为 HTML,从而导致它们以纯文本形式显示脚本。为了避免这个问题,开发人员会注释掉文本,这样它就不会被不受支持的浏览器呈现为 HTML。那些日子已经离我们很远了。所有现代浏览器都支持该script标签。只需完全删除 HTML 注释括号,或者更好的是,将 JavaScript 编写在单独的文件中,然后使用script标记将其导入到当前的 HTML 文档中,如下所示:
还有不少元素曾经是 HTML 规范的一部分,但后来被弃用或废弃。以下是您可能仍在使用的八个 HTML 元素,您应该立即停止使用它们以及您可以使用的替代标签:
有许多元素和属性曾经是 HTML 的一部分,但执行的任务更适合 CSS。这些元素已经被弃用,取而代之的是让 CSS 控制网页呈现。
曾经使用 HTML 元素(如font、basefont、center、strike和u. 这些元素都已被弃用,取而代之的是 CSS 提供的字体和排版控件。要了解更多信息,请查看我们的字体和网页排版教程。一个从未真正流行起来的独特标签是multicol。此标签可用于将文本分成多列,类似于报纸的外观。现在可以使用 CSScolumns属性在现代浏览器中创建类似但更强大的效果。
广泛的 HTML 元素属性曾经可用于控制 HTML 元素的呈现。几乎所有这些标签都已被弃用,现在 CSS 提供了相同的功能。如果您不熟悉 CSS 以及如何实现这些属性,我们的 CSS 教程将帮助您立即开始使用层叠样式表。下面是一些更常用的属性和现在可以用来实现相同结果的 CSS 属性。
在本文中,我们介绍了一些最常见的元素和属性,这些元素和属性使用不当或已被弃用或过时。然而,我们真的只是触及了冰山一角。如果您想了解已从 HTML 规范中删除的所有 HTML 元素和属性,请参阅以下资源:
*请认真填写需求信息,我们会在24小时内与您取得联系。