原標(biāo)題:用豆包MarsCode IDE,從0到1畫出精美數(shù)據(jù)大屏!
豆包MarsCode IDE 是一個(gè)云端 AI IDE 平臺(tái),通過內(nèi)置的 AI 編程助手,開箱即用的開發(fā)環(huán)境,可以幫助開發(fā)者更專注于各類項(xiàng)目的開發(fā)。
作為一名前端開發(fā)工程師,今天想嘗試?yán)枚拱麺arsCode IDE,選擇 Vue + Echarts 創(chuàng)建一個(gè)大屏項(xiàng)目:數(shù)智化線上車展數(shù)據(jù)分析平臺(tái)。
前置知識(shí)
在學(xué)習(xí)本教程前你需要具備以下編程基礎(chǔ)和技能:
前端開發(fā)基礎(chǔ)
- HTML 和 CSS:了解基本的 HTML 結(jié)構(gòu)和 CSS 樣式化技巧,以便理解如何構(gòu)建頁(yè)面結(jié)構(gòu)和樣式化元素。例如,教程中提到使用 CSS 的
transform
屬性進(jìn)行縮放和居中對(duì)齊。 推薦課程:《HTML入門課程(含HTML5)》、《CSS 入門課程》、《HTML + CSS 基礎(chǔ)實(shí)戰(zhàn)》 - JavaScript:掌握 JavaScript 基礎(chǔ),包括變量、函數(shù)、事件處理等,因?yàn)榻坛讨猩婕暗?JavaScript 代碼來處理數(shù)據(jù)和動(dòng)態(tài)生成圖表。 推薦課程:《JavaScript 入門課程》、《JavaScript 基礎(chǔ)實(shí)戰(zhàn)》
- Vue.js:熟悉 Vue.js 框架的基本概念和用法,因?yàn)榻坛讨惺褂?Vue 作為前端框架。了解組件、數(shù)據(jù)綁定、生命周期鉤子等概念。 推薦課程:《Vue2入門課程》、《Vue 3.0 新特性全面解析(走在技術(shù)前沿)blank》、《Vue3從零開始系列課程》
- ECharts:了解 ECharts 圖表庫(kù)的基本使用方法,包括如何配置和渲染不同類型的圖表(如柱狀圖、折線圖、熱力圖等)。 推薦課程:《【實(shí)戰(zhàn)】ECharts數(shù)據(jù)可視化之疫情實(shí)時(shí)監(jiān)控展示》
開發(fā)工具和環(huán)境
- IDE 使用:熟悉使用集成開發(fā)環(huán)境(IDE),如豆包MarsCode IDE 或其他常用的前端開發(fā) IDE(如 VSCode)。了解如何創(chuàng)建項(xiàng)目、運(yùn)行項(xiàng)目、安裝依賴等。
- 包管理工具:了解 npm 或 cnpm 等包管理工具的基本使用方法,能夠安裝和管理項(xiàng)目依賴。
其他相關(guān)知識(shí)
- 響應(yīng)式設(shè)計(jì):理解響應(yīng)式設(shè)計(jì)的基本概念,知道如何使網(wǎng)頁(yè)在不同分辨率的設(shè)備上適配顯示,例如使用 CSS 的
transform
屬性進(jìn)行縮放。 推薦課程:《HTML+CSS響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì) (基礎(chǔ)版)》 - 網(wǎng)絡(luò)請(qǐng)求和數(shù)據(jù)處理:雖然教程中沒有直接提到網(wǎng)絡(luò)請(qǐng)求,但通常數(shù)據(jù)大屏?xí)婕暗綇暮蠖双@取數(shù)據(jù),因此了解基本的網(wǎng)絡(luò)請(qǐng)求和數(shù)據(jù)處理方法是有幫助的。
軟件工程知識(shí)
- 代碼組織和注釋:了解如何合理組織代碼結(jié)構(gòu)和編寫注釋,以便于代碼的可讀性和維護(hù)性。
- 版本控制:熟悉基本的版本控制工具(如 Git)的使用,能夠進(jìn)行代碼的版本管理和協(xié)作開發(fā)。 推薦課程:《1小時(shí)快速上手版本控制器-SVN精講視頻教程》、《Git 基礎(chǔ)課程》、《Git 入門視頻課程》、《帶領(lǐng)女程序員小白:一小時(shí)輕松掌握GIT入門知識(shí)》
具備以上基礎(chǔ)和技能,將有助于你更好地理解和應(yīng)用教程中的內(nèi)容,從而成功地創(chuàng)建一個(gè)數(shù)據(jù)大屏項(xiàng)目。
項(xiàng)目準(zhǔn)備
進(jìn)入 IDE 之后,注冊(cè)登錄進(jìn)入主頁(yè)。
當(dāng)你選擇創(chuàng)建一個(gè) Vue 項(xiàng)目后,會(huì)初始化一個(gè)項(xiàng)目,點(diǎn)擊 RUN 即可運(yùn)行。
瀏覽 package.json
文件,發(fā)現(xiàn)默認(rèn)創(chuàng)建的是 Vue3+Vite 構(gòu)建的項(xiàng)目。雖然官方提供的模板是 Vue3 的,但如果你希望使用 Vue2 也可以通過 Github 導(dǎo)入項(xiàng)目。
畫大屏必不可少的就是 ECharts,通過 npm 安裝速度較慢,所以使用鏡像及其命令 cnpm。因?yàn)槎拱麺arsCode IDE 內(nèi)置了 AI 助手,提供代碼自動(dòng)補(bǔ)全與生成、問題修復(fù)、代碼優(yōu)化等能力,安裝了 cnpm 后,IDE 猜到了我是在查看版本,在控制臺(tái)輸入 cnpm 之后就會(huì)自動(dòng)補(bǔ)全 cnpm -v
來查看版本。
通過命令 cnpm install echarts --save
安裝 ECharts,cnpm 的安裝速度就很快了,差不多一分鐘就可以搞定,在項(xiàng)目的 package.json
文件中也可以看到安裝的版本5.5.1.
畫大屏需要靜態(tài)圖片來裝飾整個(gè)大屏,可以通過 upload
批量上傳。
將模板默認(rèn)生成的代碼,簡(jiǎn)單刪一下就變?yōu)橐粋€(gè)空的項(xiàng)目,我們就可以正式開始大屏的制作了。
數(shù)據(jù)大屏的制作
可視化數(shù)據(jù)大屏首先要解決的問題就是適配性,這是一個(gè)比較專業(yè)性的問題。豆包MarsCode 集成了 AI 功能,所以我們可以直接向 AI 助手提問:“想要可視化大屏適配任何多種分辨率的屏幕,前端該如何實(shí)現(xiàn)。
”我們看一下它是怎么回答的。
我選擇的解決方案是:通過 CSS 的 scale
屬性,根據(jù)屏幕大小,對(duì)圖表進(jìn)行整體的等比縮放,從而達(dá)到自適應(yīng)效果。
CSS 的 scale
屬性用于指定元素的縮放比例。它是 transform
屬性的一個(gè)值,可以使用 CSS 中的 transform
屬性來設(shè)置元素的縮放比例。
scale
屬性可以接受一個(gè)或兩個(gè)參數(shù)。如果只提供一個(gè)參數(shù),它將同時(shí)應(yīng)用于元素的寬度和高度,導(dǎo)致元素在兩個(gè)維度上按比例縮放。如果提供兩個(gè)參數(shù),第一個(gè)參數(shù)表示寬度的縮放比例,第二個(gè)參數(shù)表示高度的縮放比例。
/* 元素整體縮放為原來的 50% */transform: scale(0.5);
/* 元素寬度縮放為原來的 75%,高度縮放為原來的 120% */transform: scale(0.75, 1.2);
scale
屬性可以與其他 transform
屬性值結(jié)合使用,比如 translate
、rotate
等,以實(shí)現(xiàn)更復(fù)雜的變形效果。同時(shí),scale
屬性也可以用在 CSS 動(dòng)畫中,通過改變縮放比例來實(shí)現(xiàn)元素的動(dòng)態(tài)縮放效果。 具體代碼如下:
let screen = ref();
// 掛載時(shí)首先去獲取視口的寬高
onMounted(() => {
// 使用ref獲取到的dom對(duì)象調(diào)用時(shí)都需要帶.value
screen.value.style.transform = `scale(${getScale()}) translate(-50%,-50%)`;
console.log(`scale(${getScale()}) translate(-50%,-50%)`, '666');
});
// 創(chuàng)建函數(shù)
function getScale(w = 1920, h = 1080) {
let ww = window.innerWidth / w;
let wh = window.innerHeight / h;
// 按照變化較小者的比例去進(jìn)行縮放
return ww < wh ? ww : wh;
}
// 視口發(fā)生變化時(shí)
window.onresize = () => {
screen.value.style.transform = `scale(${getScale()}) translate(-50%,-50%)`;
}
getScale()
函數(shù)通常用于根據(jù)瀏覽器視口大小計(jì)算一個(gè)縮放因子。這個(gè)因子通常被用作 scale 屬性的值,以確保 screen
元素可以根據(jù)屏幕大小自動(dòng)調(diào)整大小。translate(-50%,-50%)
部分是用于將縮放后的元素居中顯示的樣式, transform-origin: left top
表示 transform
屬性的原點(diǎn)位于元素的左上角。 這段代碼提供了一種響應(yīng)式的方式來調(diào)整頁(yè)面元素的大小和位置,使得頁(yè)面在不同大小的屏幕上都能夠友好地顯示。
先給大家展示下最終效果,我再來一步步演示大屏數(shù)據(jù)圖表的生成。
整個(gè)可視化大屏分為六部分:
兩個(gè)橫向柱狀圖、一個(gè)中國(guó)地圖、一個(gè)折線圖、一個(gè)餅狀圖和一個(gè)熱力圖?
橫向柱狀圖 & 折線圖
x軸配置:
- 類型為
value
,表示x
軸為數(shù)值軸; - 軸標(biāo)簽的顏色為白色;
- 邊界間隙為
[0, 0.01]
,表示x
軸的起始和結(jié)束位置會(huì)留有一定的空白。
y軸配置:
- 類型為
category
,表示y軸為類目軸; - 軸標(biāo)簽的顏色為白色;
y
軸的類目數(shù)據(jù)包括了多個(gè)汽車品牌名稱。
Echarts-category
類目軸,適用于離散的類目數(shù)據(jù)。為該類型時(shí)類目數(shù)據(jù)可自動(dòng)從 series.data
或 dataset.source
中取,或者可通過 yAxis.data
設(shè)置類目數(shù)據(jù)。
series:type:'category'
柱狀圖(或稱條形圖)是一種通過柱形的高度(橫向的情況下則是寬度)來表現(xiàn)數(shù)據(jù)大小的一種常用圖表類型。
type:'line'
折線圖是用折線將各個(gè)數(shù)據(jù)點(diǎn)標(biāo)志連接起來的圖表,用于展現(xiàn)數(shù)據(jù)的變化趨勢(shì)。
xAxis: {
type: 'value',
axisLabel: {
color: 'white',
},
boundaryGap: [0, 0.01],
},
yAxis: {
type: 'category',
axisLabel: {
color: 'white',
},
data: [],
},
series: [
{
name: '',
type: 'bar',
label: {
show: true,
},
data: [],
},
],
熱力圖
ECharts 熱力圖是一種數(shù)據(jù)可視化的圖表類型,它通過顏色的深淺來表示數(shù)據(jù)的大小或密集程度。在熱力圖中,數(shù)據(jù)通常以矩形網(wǎng)格的形式呈現(xiàn),每個(gè)小矩形格子的顏色深淺代表該位置上的數(shù)據(jù)大小,一般使用漸變色來表達(dá)數(shù)據(jù)的強(qiáng)弱。
min
:表示熱力圖數(shù)據(jù)值中的最小值。在熱力圖中,所有小于或等于min
的數(shù)據(jù)值都將被視為該范圍的下限,通常用于確定顏色映射的起始點(diǎn)。max
:表示熱力圖數(shù)據(jù)值中的最大值。相應(yīng)地,所有大于或等于max
的數(shù)據(jù)值都將被視為該范圍的上限,用于確定顏色映射的終點(diǎn)。
可以從實(shí)現(xiàn)的效果圖中看出,熱力圖數(shù)據(jù)基本都是0.xx
,所以我將最大值設(shè)置為1.0
,如果設(shè)置的數(shù)值過大,會(huì)出現(xiàn)所有顏色基本一致的情況,看不出具體差異。
visualMap: {
min: -0.75,
max: 1.0,
calculable: true,
orient: 'horizontal',
left: 'center',
bottom: '15%',
},
series: [
{
name: 'Punch Card',
type: 'heatmap',
data: data,
label: {
show: true,
},
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowColor: 'rgba(0, 0, 0, 0.5)',
},
},
},
],
中國(guó)地圖
注冊(cè)地圖
在 ECharts 中,需要先注冊(cè)地圖類型才能使用。對(duì)于中國(guó)地圖,可以使用 echarts.registerMap
方法注冊(cè)地圖數(shù)據(jù)。注冊(cè)時(shí),需要指定地圖的名稱(如china
)和地圖數(shù)據(jù)(即之前準(zhǔn)備的 JSON 數(shù)據(jù)文件)。
配置地圖選項(xiàng)
通過配置 ECharts 實(shí)例的 option
屬性,可以定義地圖的顯示樣式、數(shù)據(jù)系列、提示框、視覺映射組件(visualMap)等。對(duì)于該地圖,通常需要設(shè)置地圖的標(biāo)題、數(shù)據(jù)系列類型為map
、地圖類型為china
等。同時(shí),還可以通過 series
屬性中的 data
數(shù)組來設(shè)置各個(gè)省份或城市的數(shù)據(jù),這些數(shù)據(jù)將用于控制地圖上的顏色深淺或圖標(biāo)大小等。
渲染地圖
配置完 option
屬性后,調(diào)用 ECharts 實(shí)例的 setOption
方法,將配置對(duì)象傳入,即可渲染出中國(guó)地圖。
此時(shí),地圖將按照配置顯示數(shù)據(jù),并支持交互操作,如縮放、拖動(dòng)等。
myEcharts.setOption({
geo: {
map: 'china', // 中國(guó)地圖
roam: true, // 是否開啟放大縮小/拖拽功能
// 地圖的位置調(diào)試
left: 150,
top: 120,
right: 150,
bottom: 0,
// 縮放比列
zoom: 1.12,
// 地圖中心點(diǎn)位置
layoutCenter: ['50%', '50%'],
// 地圖上的文字的設(shè)置
label: {
show: true,
color: 'white',
fontSize: 14,
},
// itemStyle地圖區(qū)域的多邊形圖形樣式
itemStyle: {
areaColor: '#12235c', // 地圖區(qū)域的顏色
// borderColor: '#2ab8ff', // 圖形的描邊顏色
borderColor: 'rgba(147, 235, 248, 1)',
borderWidth: 0.8,
shadowColor: 'rgba(128, 217, 248, .8)',
shadowOffsetX: -2,
shadowOffsetY: 2,
shadowBlur: 10,
opacity: 0.9,
},
// 地圖高亮的效果
emphasis: {
label: {
color: 'white',
fontSize: 32,
// fontWeight: 'bold',
},
itemStyle: {
// areaColor: '#5470c6',
borderWidth: 2,
borderType: 'dashed', // 高亮?xí)r虛線邊框
},
// focus: 'self', // 鼠標(biāo)移入地區(qū),其余地區(qū)淡出
},
},
// 布局位置
grid: {
left: 0,
top: 0,
right: 0,
bottom: 0,
},
// 航線的設(shè)置
series: [
{
type: 'lines', // 航線的系列
data: [
{
// 北京->河南
coords: [
[116.405285, 39.904989], // 起點(diǎn)
[113.665412, 34.757975], // 終點(diǎn)
],
},
{
// 河南->北京
coords: [
[113.665412, 34.757975],
[116.405285, 39.904989],
],
},
{
// 北京->黑龍江
coords: [
[116.405285, 39.904989],
[126.642464, 45.756967],
],
},
{
// 黑龍江->北京
coords: [
[126.642464, 45.756967],
[116.405285, 39.904989],
],
},
{
// 河南->浙江
coords: [
[113.665412, 34.757975],
[120.153576, 30.287459],
],
},
{
// 浙江->河南
coords: [
[120.153576, 30.287459],
[113.665412, 34.757975],
],
},
{
// 浙江->臺(tái)灣
coords: [
[120.153576, 30.287459],
[121.509062, 25.044332],
],
},
],
// 開啟動(dòng)畫特效
effect: {
show: true,
period: 5, // 箭頭指向速度,值越小速度越快
trailLength: 0, // 特效尾跡長(zhǎng)度[0,1]值越大,尾跡越長(zhǎng)
// symbol: 'arrow', // 箭頭圖標(biāo)
symbol: planePath, // 箭頭圖標(biāo)使用引入的箭頭
symbolSize: 18,
},
// 線路統(tǒng)一的樣式設(shè)置
lineStyle: {
color: '#00eaff',
width: 1.5, // 尾跡線條寬度
opacity: 0.7, // 尾跡線條透明度
curveness: 0.3, // 尾跡線條曲直度
},
},
],
});
到此為止,整個(gè)大屏基本上就開發(fā)完成了!
AI 能力體驗(yàn)
在整個(gè)項(xiàng)目的開發(fā)過程中,真切體會(huì)到豆包MarsCode 內(nèi)置 AI 的強(qiáng)大,于是單獨(dú)列個(gè)模塊再來介紹一下。
AI 對(duì)話視圖
側(cè)邊聊天:側(cè)邊對(duì)話框(Side AI Chat)位于工作區(qū)右側(cè)。你可以通過快捷鍵(macOS:?
+U
;Windows:Ctrl
+U
)喚起對(duì)話框,或直接點(diǎn)擊側(cè)邊欄中的 AI 按鈕喚起。
內(nèi)嵌聊天:當(dāng)我們選中一段代碼之后會(huì)自動(dòng)彈出 AI 功能導(dǎo)航,可以進(jìn)行代碼解釋、注釋、生成單元測(cè)試。
代碼注釋:自己不想寫的時(shí)候可以直接通過 AI 來生成,通過選擇 Y
、N
即可決定是否使用自動(dòng)生成的注釋。
使用 AI 能力
AI 問答:喚起對(duì)話框后,你可以在輸入框中輸入你的問題,然后點(diǎn)擊「發(fā)送
」按鈕或敲擊回車鍵,AI 助手就會(huì)對(duì)你的問題進(jìn)行回答。你可以進(jìn)行多輪問答,不斷補(bǔ)充細(xì)節(jié),從而使 AI 助手的回答更加準(zhǔn)確。
補(bǔ)全代碼: AI 助手支持自動(dòng)補(bǔ)全當(dāng)前代碼。
總結(jié)
豆包MarsCode 編程助手是一款功能強(qiáng)大的開發(fā)工具,它通過集成先進(jìn)的 AI 技術(shù),為開發(fā)者提供了從代碼編寫到測(cè)試、維護(hù)的全流程支持。在整個(gè)開發(fā)流程中,我都真切感受到了在線開發(fā)工具的便捷、高效、流暢。對(duì)于希望提高開發(fā)效率、降低維護(hù)成本并提升軟件質(zhì)量的團(tuán)隊(duì)來說,是一個(gè)值得考慮的選擇!
歡迎感興趣的各位進(jìn)一步查閱其官方文檔和社區(qū)資源,更深入地了解其功能和實(shí)踐。
點(diǎn)擊「豆包MarsCode AI編程助手」即可體驗(yàn)豆包MarsCode~???