基于Vue过渡状态实例讲解
发布时间 - 2026-01-11 03:14:48 点击率:次前面的话

Vue 的过渡系统提供了非常多简单的方法设置进入、离开和列表的动效。那么对于数据元素本身的动效呢?包括数字和运算、颜色的显示、SVG 节点的位置、元素的大小和其他的属性等。所有的原始数字都被事先存储起来,可以直接转换到数字。做到这一步,我们就可以结合 Vue 的响应式和组件系统,使用第三方库来实现切换元素的过渡状态
状态动画
通过watcher,能监听到任何数值属性的数值更新
<div id="animated-number-demo">
<input v-model.number="number" type="number" step="20">
<p>{{ animatedNumber }}</p>
</div>
<script src="Tween.js"></script>
<script src="vue.js"></script>
<script>
new Vue({
el: '#animated-number-demo',
data: {
number: 0,
animatedNumber: 0
},
watch: {
number: function(newValue, oldValue) {
var vm = this;
function animate () {
if (TWEEN.update()) {
requestAnimationFrame(animate)
}
}
new TWEEN.Tween({ tweeningNumber: oldValue })
.easing(TWEEN.Easing.Quadratic.Out)
.to({ tweeningNumber: newValue }, 500)
.onUpdate(function () {
vm.animatedNumber = this.tweeningNumber.toFixed(0)
})
.start();
animate()
}
}
})
</script>
当把数值更新时,就会触发动画。这个是一个不错的演示,但是对于不能直接像数字一样存储的值,比如 CSS 中的 color 的值,通过下面的例子来通过 Color.js 实现一个例子:
<div id="example">
<input v-model="colorQuery" @keyup.enter="updateColor" placeholder="Enter a color">
<button @click="updateColor">Update</button>
<p>Preview:</p>
<span :style="{ backgroundColor: tweenedCSSColor }" style="display: inline-block;width: 50px;height: 50px;"></span>
<p>{{ tweenedCSSColor }}</p>
</div>
<script src="Tween.js"></script>
<script src="vue.js"></script>
<script src="color.js"></script>
<script>
var Color = net.brehaut.Color
new Vue({
el: '#example',
data: {
colorQuery: '',
color: {
red: 0,
green: 0,
blue: 0,
alpha: 1
},
tweenedColor: {}
},
created: function () {
this.tweenedColor = Object.assign({}, this.color)
},
watch: {
color: function () {
function animate () {
if (TWEEN.update()) {
requestAnimationFrame(animate)
}
}
new TWEEN.Tween(this.tweenedColor)
.to(this.color, 750)
.start()
animate()
}
},
computed: {
tweenedCSSColor: function () {
return new Color({
red: this.tweenedColor.red,
green: this.tweenedColor.green,
blue: this.tweenedColor.blue,
alpha: this.tweenedColor.alpha
}).toCSS()
}
},
methods: {
updateColor: function () {
this.color = new Color(this.colorQuery).toRGB()
this.colorQuery = ''
}
}
})
</script>
动态状态转换
就像 Vue 的过渡组件一样,数据背后状态转换会实时更新,这对于原型设计十分有用。当修改一些变量,即使是一个简单的 SVG 多边形也可以实现很多难以想象的效果
<style>
svg,input[type="range"]{display:block;}
</style>
<div id="app">
<svg width="200" height="200">
<polygon :points="points" fill="#41B883"></polygon>
<circle cx="100" cy="100" r="90" fill=" transparent" stroke="#35495E"></circle>
</svg>
<label>Sides: {{ sides }}</label>
<input type="range" min="3" max="500" v-model.number="sides">
<label>Minimum Radius: {{ minRadius }}%</label>
<input type="range" min="0" max="90" v-model.number="minRadius">
<label>Update Interval: {{ updateInterval }} milliseconds</label>
<input type="range" min="10" max="2000" v-model.number="updateInterval">
</div>
<script type="text/javascript" src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/vue.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/1.18.5/TweenLite.min.js"></script>
<script>
new Vue({
el: '#app',
data: function () {
//默认有10条边
var defaultSides = 10;
//默认地,stats = [100, 100, 100, 100, 100, 100, 100, 100, 100, 100]
var stats = Array.apply(null, { length: defaultSides })
.map(function () { return 100 })
return {
stats: stats,
points: generatePoints(stats),
sides: defaultSides,
minRadius: 50,
interval: null,
updateInterval: 500
}
},
watch: {
sides: function (newSides, oldSides) {
//计算设置的边数与默认的边数的差值
var sidesDifference = newSides - oldSides
//如果大于默认边数
if (sidesDifference > 0) {
//增加相应数量的随机值到stats数组中
for (var i = 1; i <= sidesDifference; i++) {
this.stats.push(this.newRandomValue())
}
}else{
//否则,计算出差值
var absoluteSidesDifference = Math.abs(sidesDifference)
//从stats数组末尾减少相应数量的数组值
for (var i = 1; i <= absoluteSidesDifference; i++) {
this.stats.shift()
}
}
},
stats: function (newStats) {
TweenLite.to(
this.$data,
this.updateInterval / 1000,
{ points: generatePoints(newStats) }
)
},
updateInterval: function () {
this.resetInterval()
}
},
mounted: function () {
this.resetInterval()
},
methods: {
//将stats里面的值都变成50-100的随机值
randomizeStats: function () {
var vm = this
this.stats = this.stats.map(function () {
return vm.newRandomValue()
})
},
newRandomValue: function () {
//产生一个50-100的随机半径
return Math.ceil(this.minRadius + Math.random() * (100 - this.minRadius))
},
//重启定时器
resetInterval: function () {
var vm = this;
clearInterval(this.interval);
this.randomizeStats();
this.interval = setInterval(function () {
vm.randomizeStats();
}, this.updateInterval)
}
}
})
function valueToPoint (value, index, total) {
var x = 0
var y = -value * 0.9
var angle = Math.PI * 2 / total * index
var cos = Math.cos(angle)
var sin = Math.sin(angle)
var tx = x * cos - y * sin + 100
var ty = x * sin + y * cos + 100
return { x: tx, y: ty }
}
//计算polygon中的路径点的值
function generatePoints (stats) {
var total = stats.length
return stats.map(function (stat, index) {
var point = valueToPoint(stat, index, total)
return point.x + ',' + point.y
}).join(' ')
}
</script>
组件组织过渡
管理太多的状态转换会很快的增加 Vue 实例或者组件的复杂性,幸好很多的动画可以提取到专用的子组件
<div id="example">
<input v-model.number="firstNumber" type="number" step="20"> +
<input v-model.number="secondNumber" type="number" step="20"> =
{{ result }}
<p>
<animated-integer :value="firstNumber"></animated-integer> +
<animated-integer :value="secondNumber"></animated-integer> =
<animated-integer :value="result"></animated-integer>
</p>
</div>
<script type="text/javascript" src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/vue.js"></script>
<script type="text/javascript" src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/Tween.js"></script>
<script>
Vue.component('animated-integer', {
template: '<span>{{ tweeningValue }}</span>',
props: {
value: {
type: Number,
required: true
}
},
data: function () {
return {
tweeningValue: 0
}
},
watch: {
value: function (newValue, oldValue) {
this.tween(oldValue, newValue)
}
},
mounted: function () {
this.tween(0, this.value)
},
methods: {
tween: function (startValue, endValue) {
var vm = this;
function animate () {
if (TWEEN.update()) {
requestAnimationFrame(animate)
}
}
new TWEEN.Tween({ tweeningValue: startValue })
.to({ tweeningValue: endValue }, 500)
.onUpdate(function () {
vm.tweeningValue = this.tweeningValue.toFixed(0)
})
.start()
animate()
}
}
})
new Vue({
el: '#example',
data: {
firstNumber: 20,
secondNumber: 40
},
computed: {
result: function () {
return this.firstNumber + this.secondNumber
}
}
})
</script>
以上这篇基于Vue过渡状态实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
# Vue过渡
# vue动画之点击按钮往上渐渐显示出来的实例
# vue动画打包后失效问题的解决方法
# 5分钟学会Vue动画效果(小结)
# vue过渡和animate.css结合使用详解
# Vue动画事件详解及过渡动画实例
# 是一个
# 给大家
# 就会
# 太多
# 就像
# 其他的
# 希望能
# 可以直接
# 可以实现
# 这篇
# 第三方
# 难以想象
# 重启
# 来实现
# 小编
# 大家多多
# 计算出
# 就可以
# 组中
# 这对于
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
电商网站制作价格怎么算,网上拍卖流程以及规则?
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
Laravel怎么实现微信登录_Laravel Socialite第三方登录集成
如何在新浪SAE免费搭建个人博客?
如何在香港免费服务器上快速搭建网站?
如何快速搭建安全的FTP站点?
如何正确选择百度移动适配建站域名?
敲碗10年!Mac系列传将迎来「触控与联网」双革新
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
Android自定义控件实现温度旋转按钮效果
Laravel观察者模式如何使用_Laravel Model Observer配置
如何快速搭建高效服务器建站系统?
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
高防服务器租用指南:配置选择与快速部署攻略
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
Linux系统命令中tree命令详解
Linux系统运维自动化项目教程_Ansible批量管理实战
Laravel如何配置任务调度?(Cron Job示例)
清除minerd进程的简单方法
laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
Python文本处理实践_日志清洗解析【指导】
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】
Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用
Bootstrap CSS布局之列表
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
Java遍历集合的三种方式
高端智能建站公司优选:品牌定制与SEO优化一站式服务
如何在 React 中条件性地遍历数组并渲染元素
Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?
如何快速搭建支持数据库操作的智能建站平台?
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】
七夕网站制作视频,七夕大促活动怎么报名?
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
JavaScript实现Fly Bird小游戏
如何在IIS中新建站点并配置端口与物理路径?
中山网站制作网页,中山新生登记系统登记流程?
在线制作视频网站免费,都有哪些好的动漫网站?
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
Laravel如何实现用户注册和登录?(Auth脚手架指南)
php做exe能调用系统命令吗_执行cmd指令实现方式【详解】
googleplay官方入口在哪里_Google Play官方商店快速入口指南
下一篇:nginx如何添加账号密码验证
下一篇:nginx如何添加账号密码验证

