[小技巧]巧妙使用flex, letter-spacing实现过渡动画

巧妙利用flex, 实现下面的效果~ 无需js来获取clientWidth

0.gif

有时候会做一些小的宽度变换, 比如居中到居左的变换, 例如上面的搜索的placeholder

我之前试过4种居中到居左的切换

0. width + text-align:center;
1. position:absolute; left + right 的拉伸;
2. justify-content: center/flex-start;
3. display:inlne-block + text-align:center;
4. margin: 0 auto 的切换;

大概知道方式的, 就不细写了~

其中0是有transition动画的, 但是with的值需要js生成, 其他4种配合transition都没有效果

后来想到flex还有一种居中效果的实现, 需要3个元素来配合~

2017-10-28_095141.png

就是前面一个前后各放置个空元素设置即可, 居中的设置为flex: 0 0 auto;, 那么这个空元素就使用父级的::before/::after 伪元素来实现了~

这样设置transition是生效的~

2017-10-28_095528.png

很简答~ 下一环节~

那么flex什么时候配合transition是没有动画的捏?

1.gif

flex: 0 0 auto;flex: 0 0 0px;是没有动画的直接跳过的

那么如何是实现这个过程有动画捏?

思路很简单: 那么改变容器的with没有动画, 那么所以就是改变所撑开容器的东西

容器里面的是字体, 改变字体大小就可以了~ 但是...

2.gif

不连贯... 从5px的时候之后就不能的字体都是一样大小的了... 相当于5px跳到0px

还有什么可以改变容器宽度? 答案是letter-spacing

3.gif

这样就可以连贯的改变实现flex: 0 0 auto;flex: 0 0 0px;

但是, 这个有缺陷么? 有~

中文的字是一个letter , 英文的字母也是一个letter , 它们的字宽不同....

4.gif

所以导致, 英文使用-9px 和中文-17px的有效过渡时间是一致的, 但是当英文使用-17px的时候, 会加速收缩, 延迟展开

并且如果是中英混搭的情况, 过渡时间由中英分别的字母数决定...就是动画时间不可控 , 它带来的好处就是不需要js来设置, 所以使用场景也是有限的~

最后 flex宽度改变了, 需要的效果是, 向右移出, 怎么来实现?

    <div class="btn-cancel" @click="_cancel">
            <span class="btn-cancel-container">{{cancelBtnText}}</span>
      <div class="btn-cancel-takeplace">{{cancelBtnText}}</div>
    </div>

分出两个容器, 一个用来控制父级的宽度, 一个用于显示最初的状态

2017-10-28_104106.png

OK~ 昨天制作这个效果的关键点就是这些~ 在这里记录一下下~

btw, 这类改变width的局部小范围弄弄就好, 可以在组件的root添加will-change: opacity; ,减少一下paint的范围

2017-10-28_104641.png

下面是不加的效果

2017-10-28_104808.png

当然, 现在的大头是layout, 我还不知道如何控制layout的范围~ 如果有读者知道可以评论一下下~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,819评论 0 2
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,350评论 0 11
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,842评论 1 92
  • 1、属性选择器:id选择器 # 通过id 来选择类名选择器 . 通过类名来选择属性选择器 ...
    Yuann阅读 1,671评论 0 7
  • 如今在市场环境非常恶烈的情况下企业如何经营客户?如何经营员工? 1.研究客户 2.研究员工 首先从研客户来讲,市...
    沙漠泉阅读 488评论 0 0