位置: 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)

  • 年应税销售额是利润表中的营业收入吗
  • 个体工商户需要交税吗?怎么交?
  • 小规模纳税人补税怎么补
  • 会计凭证的票号
  • 个人所得税该如何缴纳
  • 差旅费超支金额允许报销吗
  • 付佣金给客户怎么做分录?
  • 结转已到期未兑付怎么办
  • 房地产开发桩基施工方案
  • 管家婆进货单科目名称怎么录入?
  • 专用设备抵免企业所得税目录
  • 企业的车辆购置税计入哪个科目
  • 公司发给员工的奖金要交税吗
  • 销项在借方还是贷方
  • 代扣代缴个人所得税现金流计入哪里
  • 一般纳税人施工安装税点
  • 节能减排奖励资金追回
  • 合同到期退房子,租金退吗
  • 进项税额转出不交税款怎么处理
  • 支付现金未给发票怎么做账?
  • 快递公司之间的合作模式
  • 金税盘服务费计入什么会计科目
  • 服装工业企业成立时间
  • 员工迟到扣工资的会计处理
  • 电子承兑签收后多久可以到账
  • 核定征收如何做账务处理
  • windows11怎么设置壁纸
  • 存货对外销售会计分录
  • 投资收益亏损后会怎么样
  • vue技术解密
  • windows10怎么设置自启动
  • 企业车间承包合同的法律效力
  • 成品油企业自用油需要开具发票吗
  • 奇托尔加赫城堡
  • 税盘可以全额抵扣是什么意思
  • 企业之间可以背书吗
  • javascript获取字符串长度
  • 哪些农产品按照鲜品统计
  • 增值税进项税额能不能抵扣
  • 织梦参数配置设置
  • 职工教育经费申报表如何填写
  • 固定资产折旧率如何计算
  • 小额贷款公司如何做账
  • 一般纳税人福利费
  • 购买货物对方代垫的运输费分录
  • 防伪税控开票系统SOAP服务端
  • 一次性补缴养老保险的最新规定
  • 医院财务核算制度
  • 固定资产多少金额必须招标
  • win键有啥用
  • win2003r2企业版密钥
  • Windows Server 2008网络中禁止迅雷下载
  • macbookpro怎么提升性能
  • solaris版本查询
  • brasil.exe是什么进程
  • windows无法安装所需的文件,请确保所需的所有文件可用
  • ubuntu安装chia
  • Win10 Mobile首个RS2预览版14905快速版今日开始推送
  • 如何在linux中安装软件
  • windows8开机启动项设置
  • win8系统咋样
  • opengles 抗锯齿
  • 电脑自动重启命令
  • python三角形角度
  • webgl基础教程
  • css中hack
  • 怎么设置网页就用指定浏览器
  • unity触摸屏控件
  • 一起学ap
  • 批处理倒计时30秒内打开文件a,否则30秒后执行文件b
  • python文法
  • jquery常见问题
  • python爬虫爬取网页数据
  • js传参是什么意思
  • unity官方插件
  • 国家税务局服务宗旨是什么
  • 福建省税务报税系统官网
  • 360浏览器hi真不巧
  • 长安cs752016款2.0手动
  • 长春市朝阳区公安局电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设