位置: IT常识 - 正文

【Vue】踩坑日记:Scoped下动画无效,曾经以为百利而无一害的Scoped,也有自己的限制

编辑:rootadmin
【Vue】踩坑日记:Scoped下动画无效,曾经以为百利而无一害的Scoped,也有自己的限制 文章目录问题描述解决过程玩味Vue Scoped知识点解决方法问题描述

推荐整理分享【Vue】踩坑日记:Scoped下动画无效,曾经以为百利而无一害的Scoped,也有自己的限制,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

​ 在开发的前期,我清晰的记得使用动画完成了图片放大的效果,当时还写了一篇博文 http://t.csdn.cn/lA9aq上了热榜。可是过了几天之后,这个效果居然“失效了”,我百思不得其解。一度怀疑自己的代码写的有问题,在CSDN等各大博客平台上查找了很久也没找到解决方案。在偶然的尝试下,我发现是scoped影响了动画的效果。真是欲哭无泪,打死我都想不到是scoped的原因。从学习vue的时候就习惯性的在style后面加上scoped,为的是不影响其他组件。曾几何时,我一度以为scoped有百利而无一害。痛定思痛,写下这篇博客,为的是警醒大家不要犯和我一样的错误,同时也提醒自己,对待一个知识点,一定要学透了,不然以后必受不熟悉其的害处。

​ 如果您的时间很宝贵,您可以直接去看解决方法;如果您的时间闲暇,不妨听我掰扯掰扯,所谓前车之"覆",后车之师。

解决过程

这里我看到动画的效果被加上去了,但是动画不生效。一度认为是自己动画代码写错了

悬浮的时候效果也加上了,但是不起作用

尝试删掉一些代码试试,结果变成了沿着X、Y只往一个方向拓展,类似于宽高以左上角为起点放大

想到了style.cssText会覆盖以前的样式,就把悬浮之前的样式也加了上去,结果回到解放前,又失效了。

试一试使用过渡,过渡是可以的(★)

这时候是可以的

然后又改成动画,结果还是不可以。

神来之笔,新建了一个页面,莫名其妙的删掉了scoped,结果就可以了

【Vue】踩坑日记:Scoped下动画无效,曾经以为百利而无一害的Scoped,也有自己的限制

动画可以了

怀疑可能是浏览器的原因,换了个浏览器,清空了一下缓存,结果还是可以。

此时的HomeTwo.vue 文件也莫名其妙的可以了(写了scoped),这时候我反应过来,是因为Test.vue 里面的样式没有写scoped,而两者之间动画的名字是一样的,所以Test.vue 影响了 HomeTwo.vue。当我改变scoped里面动画的名字,使之和Test.vue里面的动画名不一样的时候,HomeTwo的动画效果 也随之失效了

为了更清晰的对比,让加了scoped的放大效果为1.5倍,不加scoped的放大效果为3倍

不加scoped

加了scoped

可以很清晰的看到,二者的放大效果都是3倍,这也就说明了不加scoped的影响了加scoped

玩味

我试了试两者都开启全局模式,动画的名字一致,但是放大的效果不同。结果是

二者的谁影响到谁是不确定的

但是刷新之后,Test.vue总是能够影响HomeTwo.vue

这个原因是什么到现在还没找到。

Vue Scoped知识点

想了解更多的可以去看官网 https://vue-loader.vuejs.org/zh/guide/scoped-css.html

当 <style> 标签有 scoped 属性时,它的 CSS 只作用于当前组件中的元素。这类似于 Shadow DOM 中的样式封装。它有一些注意事项,但不需要任何 polyfill。它通过使用 PostCSS 来实现以下转换:

<style scoped>.example { color: red;}</style><template> <div class="example">hi</div></template>

转换结果:

<style>.example[data-v-f3f3eg9] { color: red;}</style><template> <div class="example" data-v-f3f3eg9>hi</div></template>

看了一下心凉大佬的博客,这里是给了组件一个唯一的标识,使得他的权重的增加了。

这里插入一件趣事:昨天晚上的时候,我错误的把转换结果当成了解决方法,照猫画虎,也在自己要操作的类上面加上了data-v-f3f3eg9,而且奇迹般的好了。今天再尝试的时候,又不可以了。昨天之所以成功,应是动画名字一致,受到了另一个动画的影响!

这时候我想过是不是可以用组件穿透的方式去解决,但又想了一下,我的样式是可以加上去的,真正的原因是动画在scoped条件下无效

解决方法不要使用动画,可以改成过渡,上面提到了过渡是有效果的。全局style和局部style混合使用,这里切记多个地方使用动画的时候,一定要动画的名不重复,否则会相互影响,如下图 不使用scoped(不建议)
本文链接地址:https://www.jiuchutong.com/zhishi/297642.html 转载请保留说明!

上一篇:逻辑回归(Logistic Regression)原理及其应用(逻辑回归模型)

下一篇:nodejs的安装与配置(nodejs的安装与配置mac)

  • 未认证的进项税能做转出处理吗
  • 公司出售房产缴纳税金如何凭证
  • 房产税城镇土地使用税申报期限
  • 企业所得税的纳税人有哪些简答题
  • 购买财务软件做什么科目
  • 佣金和手续费支出 纳税调整
  • 应收账款余额百分比法会计分录
  • 个税全员全额扣缴申报指什么
  • 固定资产折旧四种方法适用范围
  • 利润率多少才是正常的
  • 跨境电商的钱怎么到账
  • 总分机构汇算清缴成功后还需要填表什么报表
  • 业务招待费列支内容
  • 累计折旧贷方余额是负数表示什么
  • 800多项进口关税减免
  • 现金不够怎么办
  • 年终红包怎么入账
  • 不交增值税当月还需要计提税金吗?
  • 租入的固定资产属于资产吗
  • 价外费用的会计和税务处理
  • 合作建房分配的房屋
  • 应收账款周转率怎么分析
  • 企业贷款利息是否可以提前还款
  • 增值税纳税申报表在哪里查询
  • 应收账款零头没有收到如何账务处理
  • 退回社保费的会议记录
  • windows10你需要trustedinstaller提供的权限才能更改
  • 专项资金单独核算的法律依据是什么
  • 企业职工教育经费
  • 上年度所得税未计提已交本年度如何计提
  • 销售商品包装材料怎么做
  • amdr5 1400
  • deepin 文件管理器
  • i33240配什么主板
  • wordpress登录入口
  • php远程下载图片
  • 支付运费的会计处理
  • axios在vue中的使用慕课笔记
  • 营改增抵减的销项税发票要抵扣吗
  • 车辆购置税发票在哪里打印
  • php 短信验证码
  • logread命令
  • python如何在画布上写字
  • 外购产品的会计分录
  • dict.setdefault()在python中设置默认值
  • linux开启php服务
  • discuz发帖标签
  • python字符串方法总结
  • 计提工资大于实发工资企业所得税怎么算
  • 工程开票金额大于结算金额怎么处理
  • 公司pos机使用规范
  • 负债类账户期末余额在借方还是贷方
  • PostgreSQL 创建表分区
  • 企业支付的一次性就业补助金
  • 应收票据备查簿的作用
  • 增值税专用发票丢了怎么补救
  • 缴纳的增值税怎么做账
  • 低值易耗品库存
  • 预付账款的会计处理
  • 当期应纳税额是什么意思
  • 期末留抵税额可以退税吗
  • mysql kill -9
  • win7双系统安装教程
  • windows10安装教程u盘安装
  • windows10x预览版
  • win10电脑清理磁盘
  • win10 ie无法使用
  • sql2000停止拒绝访问
  • win7 安装系统
  • bootstrap怎么用
  • jquery中删除节点方法
  • android解析xml的方法中,将整个文件加载到内存
  • android基于linux还是unix
  • python简单实现刷新智联简历
  • js变量作用域
  • Activity与Theme
  • Python中MySQL数据迁移到MongoDB脚本的方法
  • 海口地税局领导班子
  • 土地要钻几回才能挖
  • 税收负担与税负转嫁
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设