我的编程空间,编程开发者的网络收藏夹
学习永远不晚

angular使用TweenMax动画库的问题和解决方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

angular使用TweenMax动画库的问题和解决方法

最近闲来无事,捣鼓捣鼓CSS

发现了一个比较好动画库,就是TweenMax

用起来略微有点麻烦,但是效果确实可以。

首先在angular中使用TweenMax就得先通过npm 安装

1.  npm install --save-dev gsap
2.  npm install --save-dev @types/gsap

然后再引入


import {TweenMax} from "gsap";

就可以在页面中使用了。

遇到的第一个问题就是,想要动画通过按钮触发来不停的播放
但是动画播完一遍以后,怎点按钮都不会触发

后面找到了原因,需要在反复触发的时候,改变其位置才行,比如说一开始的X为500,动画播完后X的位置就是500了,再反复触发,位置还是500所以不会有作用,所以想要反复触发,就得修改其位置


this.test = new TweenMax('.box',3,{
   x:this.direction?0:500,
   ease:Bounce.easeOut
  })

第二个问题就是,在页面上,想要在动画过程中和结束以后改变蓝色按钮的状态和文字,结果发现直接用绑定在按钮上的属性不能够完成这个操作


<button [disabled]="isMoveing" style="margin-top: 10px;" nz-button nzType="primary" (click)="repeat()">
  {{describle}}
</button>

this.test = new TweenMax('.box',3,{
   x:this.direction?0:500,
   ease:Bounce.easeOut,
   onStart:function(){
    this.describle = '运动中'
    this.isMoveing = true
   },
   onComplete:function(){
    this.describle = '动'
    this.isMoveing = false
   }
  })

通过一番折腾发觉,其实是this指向的问题

上图可以看到,在TweenMax方法中,this指向的是Tween这个方法本身,而我们需要改变的对象,是处在组件中的,也就是下图所示

定位到了问题所在处,那解决起来就比较简单了,在函数作用域之外的地方定义一个元素指向正确的this就行


let _this = this
this.test = new TweenMax('.box',3,{
   x:this.direction?0:500,
   ease:Bounce.easeOut,
   onStart:function(){
    _this.describle = '运动中'
    _this.isMoveing = true
   },
   onComplete:function(){
    _this.describle = '动'
    _this.isMoveing = false
   }
  })

这样就正常了。

总结

到此这篇关于angular使用TweenMax动画库的文章就介绍到这了,更多相关angular使用TweenMax内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

angular使用TweenMax动画库的问题和解决方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何解决jQuery中animate动画方法及动画排队的问题

这篇文章将为大家详细讲解有关如何解决jQuery中animate动画方法及动画排队的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。jquery是什么jquery是一个简洁而快速的JavaScript库
2023-06-14

pytorch无法使用GPU问题的解决方法

无法使用GPU的PyTorch问题解决方法:确认GPU可用性:检查显卡和连接,运行nvidia-smi查看信息。安装PyTorchGPU版本:使用pip安装,并选择与GPU兼容的CUDA版本。配置环境变量:设置CUDA_VISIBLE_DEVICES和TORCH_CUDA_ARCH_LIST环境变量。更新驱动程序:安装最新显卡驱动程序。禁用其他GPU应用程序:关闭占用GPU资源的应用程序。检查防火墙设置:确保防火墙允许PyTorch访问GPU。修复损坏的PyTorch安装:卸载并重新安装PyTorchGP
pytorch无法使用GPU问题的解决方法
2024-04-02

C++中指针问题和引用问题的解决方法

C++中指针问题和引用问题的解决方法引言:在C++编程过程中,指针问题和引用问题是常见的困扰程序员的难题。本文将介绍一些解决这些问题的方法,并通过具体的代码示例进行说明,帮助读者更好地理解和应用。一、指针问题的解决方法空指针检测在使用指针之
2023-10-22

Vue-Luckysheet的使用方法及遇到问题解决方法

Luckysheet,一款纯前端类似excel的在线表格,功能强大、配置简单、完全开源,这篇文章主要介绍了Vue-Luckysheet的使用方法,需要的朋友可以参考下
2022-11-13

Shard-Jdbc数据库扩容的场景和问题的解决方法

这篇文章主要介绍“Shard-Jdbc数据库扩容的场景和问题的解决方法”,在日常操作中,相信很多人在Shard-Jdbc数据库扩容的场景和问题的解决方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Shard
2023-06-02

Android中Splash应用启动白屏问题的解决方法

不久前项目开始了一段时间了,刚开始怀疑是Android Studio中新加入的Instant Run功能引起的,于是重新打release包后再次运行发现还是有这样的问题,突然想到了上次集成进来了云信,于是猜想可能的确是加入云信后Applic
2022-06-06

使用stream的Collectors.toMap()方法常见的问题及解决

这篇文章主要介绍了使用stream的Collectors.toMap()方法常见的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-03-06

Win10自动安装游戏应用问题的解决方法

最近有不少用户反映,升级win10系统后,电脑会经常自动安装一些无用的游戏应用,即使卸载了,还是会自动安装,很是烦人。那么,遇到电脑总是自动安装游戏的问题该如何解决呢?下面就为大家分享下解决方法。 方法如下: 1、按Win+R键,打开运行,
2023-05-21

如何使用Golang继承方法解决问题和应用范例

Golang继承方法的优势和应用场景在Go语言中,虽然没有传统意义上的类的概念,但是通过结构体的嵌套和方法的继承,我们可以实现类似其他面向对象语言中的继承机制。本文将介绍Golang继承方法的优势和应用场景,并提供具体的代码示例。一、G
如何使用Golang继承方法解决问题和应用范例
2024-01-20

关于同时使用swiper和echarts遇到的问题及解决方法

这篇文章主要介绍了关于同时使用swiper和echarts遇到的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-15

编程热搜

目录