ECharts兩種動畫效果完整代碼
加載動畫:當(dāng)數(shù)據(jù)第一次加載或切換數(shù)據(jù)集時,可以通過設(shè)置 animation 屬性來展示加載動畫,具體可以設(shè)置為 ‘auto’ 或者 true,這將啟用默認(rèn)的加載動畫效果,也可以設(shè)置為一個對象,自定義加載動畫的具體效果。例如:
option = {
animation: true,
...
};更新動畫:當(dāng)數(shù)據(jù)發(fā)生變化時,可以通過設(shè)置 animationDurationUpdate 和 animationEasingUpdate 屬性來展示更新動畫,這將在數(shù)據(jù)變化后自動執(zhí)行動畫,使得數(shù)據(jù)變化更加直觀和平滑。例如:
option = {
series: [{
type: 'sankey',
animationDurationUpdate: 1000, // 更新動畫時長為 1s
animationEasingUpdate: 'quinticInOut', // 更新動畫緩動效果為 'quinticInOut'
...
}]
...
};在以上代碼中,我們將 series 屬性的 type 設(shè)置為 ‘sankey’,即表示創(chuàng)建一個?;鶊D,并通過 animationDurationUpdate 和 animationEasingUpdate 屬性分別設(shè)置了更新動畫的時長和緩動效果。這樣,在數(shù)據(jù)發(fā)生變化時,?;鶊D將自動執(zhí)行更新動畫。需要注意的是,為了使用動畫效果,需要將 ECharts 版本升級到 4.0 及以上版本。
完整代碼如下:
HTML部分:
<div id="sankeyChart" style="height: 500px;"></div>
js:
// 初始化echarts實例
var myChart = echarts.init(document.getElementById('sankeyChart'));
// 配置項
var option = {
tooltip: {
trigger: 'item',
triggerOn: 'mousemove'
},
series: {
type: 'sankey',
emphasis: {
focus: 'adjacency'
},
nodeWidth: 20,
data: [{
name: 'A'
}, {
name: 'B'
}, {
name: 'C'
}, {
name: 'D'
}, {
name: 'E'
}],
links: [{
source: 'A',
target: 'B',
value: 10
}, {
source: 'A',
target: 'C',
value: 15
}, {
source: 'B',
target: 'D',
value: 12
}, {
source: 'C',
target: 'D',
value: 8
}, {
source: 'C',
target: 'E',
value: 10
}]
}
};
// 顯示加載動畫
myChart.showLoading();
// 異步加載數(shù)據(jù)
setTimeout(function () {
myChart.hideLoading();
myChart.setOption(option);
}, 2000);
// 更新數(shù)據(jù)
setTimeout(function () {
option.series.data.push({
name: 'F'
});
option.series.links.push({
source: 'D',
target: 'F',
value: 5
});
myChart.setOption(option);
}, 4000);上述代碼中,通過 showLoading() 方法來展示加載動畫,在異步加載數(shù)據(jù)完成后,使用 hideLoading() 方法來隱藏加載動畫并且調(diào)用 setOption() 方法來設(shè)置圖表數(shù)據(jù)。然后,在延遲 4 秒后,使用 setOption() 方法來更新數(shù)據(jù)。最終效果是一個帶有加載動畫和更新動畫的桑基圖。
總結(jié)
到此這篇關(guān)于ECharts兩種動畫效果的文章就介紹到這了,更多相關(guān)ECharts動畫效果內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實現(xiàn)合并(歸并)排序算法示例解析
這篇文章主要為大家介紹了JavaScript實現(xiàn)合并(歸并)排序算法示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
原生javascript如何實現(xiàn)共享onload事件
這篇文章主要介紹了原生javascript如何實現(xiàn)共享onload事件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07
JS實現(xiàn)根據(jù)用戶輸入分鐘進(jìn)行倒計時功能
倒計時功能大家無論在各大網(wǎng)站都可以看到,今天小編給大家分享一段基于js實現(xiàn)的根據(jù)用戶輸入分鐘進(jìn)行倒計時功能,非常不錯,需要的朋友參考下吧2016-11-11
JavaScript中判斷函數(shù)是new還是()調(diào)用的區(qū)別說明
具名函數(shù)的各種調(diào)用方式 在之前篇幅中已經(jīng)介紹過了。這篇看看如何判斷一個函數(shù)是被new調(diào)用的,還是被其它方式調(diào)用的。2011-04-04
Vue項目vscode 安裝eslint插件的方法(代碼自動修復(fù))
這篇文章主要介紹了Vue項目vscode 安裝eslint插件的方法 代碼自動修復(fù),需要的朋友可以參考下2020-04-04
微信小程序?qū)崿F(xiàn)音頻文件播放進(jìn)度的實例代碼
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)音頻文件播放進(jìn)度的實例代碼,代碼包括對進(jìn)度條的實現(xiàn)及進(jìn)度條的滑動,對大家的工作或?qū)W習(xí)具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03

