问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

div css编写网页出现分层怎么处理

发布网友 发布时间:2022-04-21 17:16

我来回答

5个回答

懂视网 时间:2022-04-21 21:37

原文: Moving along a curved path in CSS with layered animation

翻译:涂鸦码龙

译者注:部分代码示例在原文中可以看效果(作者写在博文里面了…),我偷懒把它做成Gif图了。

CSS 的 animations (动画) 和 transitions(变换)擅于实现从点 A 到点 B 的直线运动,运动轨迹是直线路径。给一个元素添加了 animation 或者 transition 以后,无论你如何调整 贝塞尔曲线 ,都无法让它沿着弧形路径运动。你可以通过自定义 timing function 属性,做出弹动的效果,但是它沿着 X 和 Y 轴相对移动的值永远是相同的。

与其使用 JavaScript 实现外观自然的运动,不如尝试用这种简单的方式:分层动画,绕过已有的限制。通过使用两个或多个元素实现动画效果,我们可以更加细粒度地控制某个元素的路径,沿着 X 轴运动使用一种 timing function ,沿着 Y 轴运动使用另一种 timing function 。

问题所在

当我们深入探讨解决方案之前,看看到底问题在哪。CSS animations 和 transitions 限制我们只能沿直线路径运动。元素总是沿着点 A 到点 B 的最短路径运动,如果我们另辟蹊径,告诉 CSS 沿着“更好的路径”,而不是“最短路径”运动呢?

用 CSS (开启硬件加速)实现两点之间的运动,最直截了当的方式是使用 transform 的 translate 在一定时间内移动某个元素。这就产生了直线运动。在 @keyframes 中,我们打算在 (0,0) 和 (100,-100) 间来回运动,见上图例子:

@keyframes straightLine { 50% { transform: translate3D(100px, -100px, 0); }}.dot { animation: straightLine 2.5s infinite linear;}

这些看起来并不难懂,但我们稍等片刻,思考一下我们需要的解决方案,拆分开来的动画,视觉上长什么样子呢。

0% 时,元素从 (0,0) 出发, 50% 时,我们用了 translate3D(100px, -100px, 0) 把它移动到 (100,-100),然后原路返回。换句话说,我们把元素向右移动了 100px ,向上移动了 100px ,两个方向联合作用使元素沿着一个角度运动。

解决方案:每个轴执行自己的动画函数

那么,原先展示的例子中我们如何实现的弧形路径呢?为了让创建的路径不是直线, 我们想让元素沿 X 轴和 Y 轴的运动速度不同步 。

先前例子中都用到了 linear 线性运动函数,如果我们给运动的元素包裹一个容器,我们可以为 X 轴应用一种动画函数,Y 轴应用另一种动画函数。以下例子,我们在 X 轴使用 ease-in ,Y 轴使用 ease-out 。

每个轴元素的具体实现

不幸的是,我们不能只把 transform 动画简单叠加:因为只有最后声明的动画会执行。那么我们如何把两个动画效果联合起来呢?可以把一个元素放入另一个元素内部,给容器元素加一种动画,给里面的子元素添加另一种动画。

在以上例子中,你已经看到一个点沿着弧形路径运动,看到两个独立的元素一起做动画,只不过容器元素是完全透明的。为了清晰地看到两个元素沿着弧形路径是如何相互作用的,我们给容器元素加个边框看看呗:

那个点藏在带边框的盒子内部,跟随盒子一起沿 X 轴远动,同时它自己又在 Y 轴方向上下运动。去掉容器盒子的边框,我们就得到了弧形路径。与其在 HTML 中用两个元素,还不如用伪元素实现嘞。如果 HTML 是这样:

 

我们可以添加伪元素:

.dot { /* 容器:沿 X 轴运动 */}.dot::after { /* 黑点儿,沿 Y 轴运动 */}

然后,我们需要两块独立的动画代码:X 轴,Y 轴各一块。注意一处用了 ease-in ,另一处用了 ease-out :

.dot { /*省略 一些布局代码...*/ animation: xAxis 2.5s infinite ease-in;}.dot::after { /* 渲染小黑点儿*/ animation: yAxis 2.5s infinite ease-out;}@keyframes xAxis { 50% { animation-timing-function: ease-in; transform: translateX(100px); }}@keyframes yAxis { 50% { animation-timing-function: ease-out; transform: translateY(-100px); }}

加上 WebKit 前缀,用一些自定义的贝塞尔曲线代替 ease-in 和 ease-out ,我们就可以实现文章最开头展示的效果:

.demo-dot { -webkit-animation: xAxis 2.5s infinite cubic-bezier(0.02, 0.01, 0.21, 1); animation: xAxis 2.5s infinite cubic-bezier(0.02, 0.01, 0.21, 1);}.demo-dot::after { content: '; display: block; width: 20px; height: 20px; border-radius: 20px; background-color: #fff; -webkit-animation: yAxis 2.5s infinite cubic-bezier(0.3, 0.27, 0.07, 1.64); animation: yAxis 2.5s infinite cubic-bezier(0.3, 0.27, 0.07, 1.64);}@-webkit-keyframes yAxis { 50% { -webkit-animation-timing-function: cubic-bezier(0.02, 0.01, 0.21, 1); animation-timing-function: cubic-bezier(0.02, 0.01, 0.21, 1); -webkit-transform: translateY(-100px); transform: translateY(-100px); }}@keyframes yAxis { 50% { -webkit-animation-timing-function: cubic-bezier(0.02, 0.01, 0.21, 1); animation-timing-function: cubic-bezier(0.02, 0.01, 0.21, 1); -webkit-transform: translateY(-100px); transform: translateY(-100px); }}@-webkit-keyframes xAxis { 50% { -webkit-animation-timing-function: cubic-bezier(0.3, 0.27, 0.07, 1.64); animation-timing-function: cubic-bezier(0.3, 0.27, 0.07, 1.64); -webkit-transform: translateX(100px); transform: translateX(100px); }}@keyframes xAxis { 50% { -webkit-animation-timing-function: cubic-bezier(0.3, 0.27, 0.07, 1.64); animation-timing-function: cubic-bezier(0.3, 0.27, 0.07, 1.64); -webkit-transform: translateX(100px); transform: translateX(100px); }}

以下是文章起始处的例子:

JS Bin on jsbin.com

你可能注意到我们在所有例子中都用了 @keyframes ,这纯粹是因为我们想展示黑点儿往返的两种状态。如果只想实现点 A 至点 B 的运动,使用 transition 属性做分层动画同样好用。

如果有个绝对定位的元素,通过给 left 和 bottom 属性加特效,就可以实现弧形路径运动,单个元素就可以,不需要容器元素。为什么不这么做呢:它性能稍差一些,动画的每一帧都会引起重绘。使用带伪元素的分层动画, translate 属性又开了硬件加速,动画效果更好,性能也更高。

译者自己搞了个绝对定位的例子:

JS Bin on jsbin.com

热心网友 时间:2022-04-21 18:45

语法:
position : static | absolute | fixed | relative
取值:
static : 默认值。无特殊定位,对象遵循HTML定位规则
absolute : 将对象从文档流中拖出,使用 left , right , top , bottom 等属性相对于其最接近的一个最有定位设置的父对象进行绝对定位。如果不存在这样的父对象,则依据 body 对象。而其层叠通过 z-index 属性定义
fixed : 未支持。对象定位遵从绝对(absolute)方式。但是要遵守一些规范
relative : 对象不可层叠,但将依据 left , right , top , bottom 等属性在正常文档流中偏移位置

看到有 position 的CSS样式 删了就可以了

热心网友 时间:2022-04-21 20:03

具体情况具体分析~~问题是 根本不知道你在讲什么

热心网友 时间:2022-04-21 21:38

什么意思

热心网友 时间:2022-04-21 23:29

同上,搞不懂你问的问题!猜了半天也没猜懂!
这只能说明一个问题,新手就是新手
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
国家对腾讯已经作出解除音乐版权处罚,为什么网易云还是很 市场监管总局依法对腾讯控股有限公司作出责令解除网络音乐 腾讯放弃音乐独家版权,绝大部分独家协议已按期解约 高级BEC和中级口译哪个难? 三级口译是什么样的水平 高级日语口译大概是什么水平 高级口译常用谚语 品牌型号怎么填写 送刀剑是什么风水 送礼送菜刀是什么意思 为什么移动用户换了电信网络就不可以手机和电视联网 电视手机都连不上网怎么办? ...都能用 为什么创维电视连接不上无线网是怎么回事? 淘宝鲜花类目和农资类目人群相似吗 藕片和油炸薯片怎么做如何做好吃 农村淘宝服务站怎么申清 自制薯片油炸怎么做好吃 农村淘宝服务站申请 农村淘宝必须有快递资格证吗 农村淘宝网店卖野菜要办什么证件 薯片好不好吃? 农村淘宝服务站要办营业执照吗? 农村淘宝需要办营业执照,我想咨询一下大家是办公司的营业执照好还是办个体户工商执照好? 阿婆家的油炸薯片和焙烤薯片哪种更好吃一点? 低档次有几种空调 额? 十八年前,一体式移动空调贵还是有外机的空调贵,同p数,四p.五p_百度问一问 移动空调美菱,荣事达,万宝……那一款黑色的怎么看着都是一样的,不会是一个厂家的吧? 美菱移动空调机是什么牌子的压缩机,整体质量和售后服务怎么样? 真假美菱移动空调? 移动宽带不能看直播是怎么回事 本人初学c,最近编了一个求物理量的小程序,但是每次运行都报错。望指教。 源代码如下: 求一个用C语言编写的小程序的源代码 一小程序,如何能得到源代码 市面上的 手机标记电话/显示*扰电话的功能都是基于哪些网站或软件的 抹茶豆浆西米露怎么做 有种奶茶是绿色的西米露,叫什么名字 CSS分层采用什么标记构建? 元宵节送什么给家人最实在? 元宵节送什么礼物给长辈最好 在元宵节送什么生日礼物给父亲好? 正月十五元宵节要到了,送点什么礼物给老人好呢? 元宵节打算买点礼物去看望一下长辈,送什么好呢? 我三十岁有点高血压高压160低压70,我血压高吗,要注意什么? 元宵节送父母什么礼物好? 男,30岁,高压160,低压110,血压是不是特别高啊?怎么有效治疗,别复制答案,要简单具体的!谢谢 我30岁这两天头痛高压160低压110怎么办? 我今年32岁,高压160,低压140,身体没有明显的不适,我该怎么办 美容院专业注氧补水仪器好吗 我今年30岁,最近量高压160低压110,请问不用药可以吗? 30岁163cm80公斤低压120高压160正常吗