【Vue】图片拉近、全屏背景实战经验总结
data:image/s3,"s3://crabby-images/889d3/889d387a64fe49b3d81305a84d27c134192673d9" alt="【Vue】图片拉近、全屏背景实战经验总结"
1 图片拉近
缘起是看到了下面的图片,我发现当鼠标悬浮的时候,发现他是可以拉近的,也就是图片的宽高不变,但是图片被放大了
data:image/s3,"s3://crabby-images/69aa0/69aa03836b346b4a296074f9fe1e20b7887a6bc8" alt=""
起初我以为是有一个这样的方法,可以实现这个操作,但是查找了很多网站都没有找到。
后来自己慢慢的摸索,才了解了其中的奥妙
子盒子和父盒子的大小一样大,为了能体现出父子盒子,我让父盒子略大,并未黄色,子盒子为白色
data:image/s3,"s3://crabby-images/3d0ff/3d0ff73f2554b4f8f940754c983ed76a6bc5fc8c" alt=""
当鼠标悬浮到该子盒子的时候,子盒子被放大(scale),如下图
data:image/s3,"s3://crabby-images/7b893/7b893a087a6576a2630e9b9301295e99b8e44033" alt=""
同时,我设置子盒子超出父盒子的部分隐藏(overflow:hidden),这样我只能看到黄色部分,但是图片却被放大了,就看到了最初的效果,图片好像被拉进了
data:image/s3,"s3://crabby-images/2a799/2a799ca43f7bfb4878e782863e5b43763400c38c" alt=""
这样似乎太突兀了,我们加一个实现的时间 1s transition: 1s;
data:image/s3,"s3://crabby-images/600c1/600c1f2f09a035368dbcab19b3d60721d5e48662" alt=""
这样就舒服多了
写这一篇博客,我发现这个图片功能太简单了。我自己用 vue 做的时候,用的是 @mouseover @mouseout 需要两个方法
让其有 1s 动画效果的时候,我用的是根据类名获取元素,然后鼠标悬浮的时候给他加上动画的效果。
但是动画的效果默认是不会保存的,间隔一秒后又会回到初始化的状态,所以又加了一句 animation-fill-mode:forwards,让其保持动画的状态。
写这篇博客之后,原来只需要几行代码就解决了!
2 全屏背景
data:image/s3,"s3://crabby-images/55051/55051cf157cb560490562ff64bf451c7888e31e2" alt=""
2.1 background-attachment
background-attachment 设置背景图像是否固定或者随着页面的其余部分滚动。
scroll 就是说,这个背景图片不是固定的,会随着页面高度的改变而变
fixed 意味着,图片是固定的,不会随着页面高度的改变而改变
2.2 background-size
2.3 display:flex;
弹性盒子由弹性容器(Flex container)和弹性子元素(Flex item)组成。
弹性容器通过设置 display 属性的值为 flex 或 inline-flex 将其定义为弹性容器。
弹性容器内包含了一个或多个弹性子元素。
不加 display:flex
data:image/s3,"s3://crabby-images/ebd2b/ebd2b63eb26767c5ba9427d635842dadfc3ff966" alt=""
加上 display:flex
data:image/s3,"s3://crabby-images/24823/24823532a15097ea0442d98633903510b088172e" alt=""
还是挺有用的以前一直用,float:left,float:right 解决布局,现在又学到了一个方法。
2.4 flex-direction
flex-direction 属性规定灵活项目的方向。
**注意:**如果元素不是弹性盒对象的元素,则 flex-direction 属性不起作用。
本来是按行排序的,flex-direction 可以灵活的排序,可以按列排序,也可以按行反着来一些效果如下:
data:image/s3,"s3://crabby-images/98b18/98b18ad59c297a2958e7e5b1c68472d117711861" alt=""
data:image/s3,"s3://crabby-images/16fca/16fca81f2655e2e14c13cf93656240148611f034" alt=""
2.5 100vh
vh 就是当前屏幕可见高度的 1%,也就是说
height:100vh == height:100%;
但是当元素没有内容时候,设置 height:100%,该元素不会被撑开,此时高度为 0,
但是设置 height:100vh,该元素会被撑开与屏幕高度一致。
对比
100%
data:image/s3,"s3://crabby-images/2f0d6/2f0d64d296849a1b162be97ae1032d24666ef44d" alt=""
100vh
data:image/s3,"s3://crabby-images/e961c/e961c6d79b1d1d9764a782814a9947da3feed591" alt=""
版权声明: 本文为 InfoQ 作者【游坦之】的原创文章。
原文链接:【http://xie.infoq.cn/article/afc848e131980b870a1ad3ad9】。文章转载请联系作者。
评论