欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue+ECharts+高德地圖API實現(xiàn)天氣預(yù)報數(shù)據(jù)可視化的教程

 更新時間:2023年06月18日 15:54:30   作者:一拾九  
所謂數(shù)據(jù)可視化,我們可以理解為從宏觀角度來看一眼就能看出來整個數(shù)據(jù)的占比,走向,對于數(shù)據(jù)可視化,很多互聯(lián)網(wǎng)公司是很看重這一塊的,包括大廠,本就將給大家介紹如何通過Vue+ECharts+高德地圖API實現(xiàn)天氣預(yù)報數(shù)據(jù)可視化

前言

所謂數(shù)據(jù)可視化,我們可以理解為從宏觀角度來看一眼就能看出來整個數(shù)據(jù)的占比,走向。對于數(shù)據(jù)可視化,很多互聯(lián)網(wǎng)公司是很看重這一塊的,包括大廠;就比如阿里的淘寶,雙十一的時候往往就需要將消費者的一些數(shù)據(jù)通過圖的形式展現(xiàn)出來。接下來我們就來實現(xiàn)一個天氣的數(shù)據(jù)可視化(移動端開發(fā)),看如下效果圖(iPhone6/7/8)。

準備工作

  • 注冊一個高德地圖API賬號,選擇開發(fā)支持,地圖 JS API。

  • 登錄控制臺成為開發(fā)者并創(chuàng)建 key

  • 進入安全密鑰使用說明,找到方式二。

  • 創(chuàng)建一個vue項目,將vue的一些默認組件和樣式刪除,在views下新建一個Index.vue,并且在index.js下配置路由。目錄結(jié)構(gòu)如下所示:

  • 通過npm install echarts --save安裝一個依賴,這樣就可以使用echarts了。

開始(細分11步)

  • 將準備工作第三步找到的方式二的兩個<script>引入到index.html中,將你自己申請的key值和安全密鑰粘貼到里面去。這樣就可以使用高德地圖 JS API 開發(fā)地圖應(yīng)用。

  • 設(shè)置頭部樣式和背景色,時間和切換城市用到了彈性布局。

  //html
  <div class="container">
        <div class="nav">
            <div class="time">7:41</div>
            <div class="city">切換城市</div>
        </div>
  <div>
 //css
  .container {
    min-height: 100vh;
    background: #000;
    opacity: 0.7;
    color: #fff;
}
.nav {
    display: flex;
    justify-content: space-between;
    padding: 10px;
}
  • 設(shè)置我們需要的天氣數(shù)據(jù)展示的html+css結(jié)構(gòu),這主要考查的是切頁面能力。
 //html
 <div class="city-info">
            <p class="city">{{}}</p>
            <p class="weather">{{}}</p>
            <h2 class="temp">
                <em></em>℃
            </h2>
            <div class="detail">
                <span>風(fēng)力:{{
                }}</span>|
                <span>風(fēng)向:{{ }}</span>|
                <span>空氣濕度:{{  }}</span>
            </div>
        </div>
        <div class="future">
            <div class="group" v-if="futureData.length > 0">
                明天:
                <span class="tm">白天:{{ }}℃ {{ 
                }} {{  }}風(fēng) {{ }} </span>
                <span class="tm"> 夜間:{{
                }}℃ {{  }} {{  }}風(fēng) {{ 
}}
                </span>
            </div>
            <div class="group" v-if="futureData.length > 0">
                后天:
                <span class="tm">白天:{{ }}℃ {{ 
                }} {{  }}風(fēng) {{  }} </span>
                <span class="tm"> 夜間:{{ 
                }}℃ {{  }} {{  }}風(fēng) {{ 
}}
                </span>
            </div>
        </div> 
//css
.city-info {
    text-align: center;
    .temp {
        font-size: 26px;
        em {
            font-size: 34px;
            font-style: normal;
        }
    }
}
.future {
    padding: 0 10px;
    margin-top: 30px;
    .group {
        height: 44px;
        line-height: 44px;
        background: rgba(255, 255, 255, 0.3);
        margin-bottom: 10px;
        padding: 0 10px;
        font-size: 13px;
        border-radius: 5px;
    }
}
  • 再放一個div 用于存放折線圖。
//html
<div class="echart-container"> </div>
//css
.echart-container {
    width: 100%;
    height: 50vh;
}
  • watchEffectonMounted來獲取天氣數(shù)據(jù)。

  • 想要獲取天氣情況我們先要獲得定位,這是需要用到高德地圖API,我們來到這個位置:開發(fā) > 地圖 JS API v2.0 > 教程 > 服務(wù) > 定位,找到IP定位獲取當前城市信息。

將這段代碼復(fù)制到onMounted的回調(diào)函數(shù)中,這樣我們就能獲取到定位信息。

  • 接下來就可以來獲取天氣了,我們把獲取天氣封裝成一個函數(shù)getWeather。同樣的我們來到:開發(fā) > 地圖 JS API v2.0 > 教程 > 服務(wù) > 天氣,找到實時天氣查詢。

把上圖中的代碼復(fù)制到獲取天氣的函數(shù)中,并將它放在獲取定位成功后執(zhí)行,傳入定位的城市,這樣就可以獲得定位的城市的天氣情況了。

  • 同樣的,我們來獲取未來幾天的天氣情況,通過下面的代碼就可以獲取到。
weather.getForecast('cityName', function(err, data) {
console.log(err, data); });

注意:此時輸出的未來天氣是一個數(shù)組。

  • 我們已經(jīng)獲取到了天氣數(shù)據(jù)了,接下來就要把這些數(shù)據(jù)存起來,把它變成響應(yīng)式的,然后把它放到頁面上展示出來。
 const state = reactive({
            today: {},
            futureData: [],
        })
  state.today = data
  state.futureData = data.forecasts
   return {
            ...toRefs(state),
        }

 把數(shù)據(jù)放到頁面上我理解的是挖坑然后埋數(shù)據(jù),就像下面這樣:

 <p class="city">{{ today.city }}</p>
 <p class="weather">{{ today.weather }}</p>

注意:由于futureData是一個數(shù)組,我們要在它放數(shù)據(jù)的div上加一個v-if="futureData.length > 0",要不然會報錯。

<div class="group" v-if="futureData.length > 0">
                明天:
<span class="tm">白天:{{ futureData[1].dayTemp }}℃ {{ futureData[1].dayWeather}} {{ futureData[1].dayWindDir }}風(fēng) {{ futureData[1].dayWindPower }} </span>
<span class="tm"> 夜間:{{ futureData[1].nightTemp }}℃ {{ futureData[1].nightWeather }} {{ futureData[1].nightWindDir }}風(fēng) {{ futureData[1].nightWindPower
}}
                </span>
            </div>

定義一個方法initEchart來完成圖的繪制(這里定義了一個空數(shù)組來獲取未來幾天的溫度)

  const tempArr = ref([])
   data.forecasts.forEach(item => {
                        tempArr.value.push(item.dayTemp)
                    })
  const echartContainer = ref(null)
  const initEchart = () => {
            const myChat = echarts.init(echartContainer.value);
            let option = {
                xAxis: {
                    type: 'category',
                    data: ['今天', '明天', '后天', '大后天'],
                    lineStyle: {
                        color: '#fff'
                    },
                    axisTick: {
                        show: false
                    },
                },
                yAxis: {
                    type: 'value',
                    show: false
                },
                series: [
                    {
                        data: tempArr.value,
                        type: 'line'
                    }
                ]
            };
            myChat.setOption(option)
        }
   return {
            echartContainer
        }

別忘了在裝這幅圖的div上掛一個ref="echartContainer"喲。

這樣就能幫我們初始化一個折線圖了。

  • 最后直接在獲取未來天氣中調(diào)用initEchart就可以了。

部分代碼

<script>
import { toRefs, watchEffect, reactive, ref, onMounted } from 'vue';
import * as echarts from 'echarts';
export default {
    setup() {
        const echartContainer = ref(null)
        const state = reactive({
            today: {},
            futureData: [],
        })
        const tempArr = ref([])
        onMounted(() => {
            //1.獲取定位
            AMap.plugin('AMap.CitySearch', function () {
                var citySearch = new AMap.CitySearch()
                citySearch.getLocalCity(function (status, result) {
                    // console.log(status);
                    if (status === 'complete' && result.info === 'OK') {
                        // 查詢成功,result即為當前所在城市信息
                        //console.log(result.city);
                        getWeather(result.city)
                    }
                })
            })
        })
        const getWeather = (cityName) => {
            //加載天氣查詢插件
            AMap.plugin('AMap.Weather', function () {
                //創(chuàng)建天氣查詢實例
                var weather = new AMap.Weather();
                //執(zhí)行實時天氣信息查詢
                weather.getLive(cityName, function (err, data) {
                    console.log(err, data);
                    state.today = data
                });
                //未來的天氣
                weather.getForecast(cityName, function (err, data) {
                    console.log(err, data);
                    state.futureData = data.forecasts
                    data.forecasts.forEach(item => {
                        tempArr.value.push(item.dayTemp)
                    })
                    initEchart()
                });
            });
        }
        const initEchart = () => {
            const myChat = echarts.init(echartContainer.value);
            let option = {
                xAxis: {
                    type: 'category',
                    data: ['今天', '明天', '后天', '大后天'],
                    lineStyle: {
                        color: '#fff'
                    },
                    axisTick: {
                        show: false
                    },
                },
                yAxis: {
                    type: 'value',
                    show: false
                },
                series: [
                    {
                        data: tempArr.value,
                        type: 'line'
                    }
                ]
            };
            myChat.setOption(option)
        }
        return {
            ...toRefs(state),
            echartContainer
        }
    }
}
</script>

結(jié)語

ECharts中的一些圖表是很好用的,我們可以自己動手多去嘗試嘗試。未來的學(xué)習(xí)之旅還很長,對于數(shù)據(jù)的可視化我們還可以做成3D的效果。本文如有錯失,歡迎大家指正,最后感謝大家的觀看,點個免費的贊吧??。

以上就是Vue+ECharts+高德地圖API實現(xiàn)天氣預(yù)報數(shù)據(jù)可視化的教程的詳細內(nèi)容,更多關(guān)于Vue+ECharts+高德地圖API 數(shù)據(jù)可視化的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue之帶參數(shù)跳轉(zhuǎn)打開新頁面、新窗口

    vue之帶參數(shù)跳轉(zhuǎn)打開新頁面、新窗口

    這篇文章主要介紹了vue之帶參數(shù)跳轉(zhuǎn)打開新頁面、新窗口方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 解決vue自定義指令導(dǎo)致的內(nèi)存泄漏問題

    解決vue自定義指令導(dǎo)致的內(nèi)存泄漏問題

    這篇文章主要介紹了解決vue自定義指令導(dǎo)致的內(nèi)存泄漏問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue+echarts實現(xiàn)中國地圖流動效果(步驟詳解)

    vue+echarts實現(xiàn)中國地圖流動效果(步驟詳解)

    這篇文章主要介紹了vue+echarts實現(xiàn)中國地圖流動效果(步驟詳解),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • vue+axios實現(xiàn)圖片上傳識別人臉的示例代碼

    vue+axios實現(xiàn)圖片上傳識別人臉的示例代碼

    本文主要介紹了vue+axios實現(xiàn)圖片上傳識別人臉,這里采用的是vant的文件上傳組件,通過上傳圖片后端識別圖片里的人臉,感興趣的可以了解一下
    2021-11-11
  • vue遞歸實現(xiàn)自定義tree組件

    vue遞歸實現(xiàn)自定義tree組件

    這篇文章主要為大家詳細介紹了vue遞歸實現(xiàn)自定義tree組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • el-tree樹組件懶加載(后端上千條數(shù)據(jù)前端進行處理)

    el-tree樹組件懶加載(后端上千條數(shù)據(jù)前端進行處理)

    本文主要介紹了el-tree樹組件懶加載(后端上千條數(shù)據(jù)前端進行處理),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Vue路由組件的緩存keep-alive和include屬性的具體使用

    Vue路由組件的緩存keep-alive和include屬性的具體使用

    :瀏覽器頁面在進行切換時,原有的路由組件會被銷毀,通過緩存可以保存被切換的路由組件,本文主要介紹了Vue路由組件的緩存keep-alive和include屬性的具體使用,感興趣的可以了解一下
    2023-11-11
  • 深入理解vue中的$set

    深入理解vue中的$set

    這篇文章主要介紹了深入理解vue中的$set,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Vue3中使用mock.js模擬數(shù)據(jù)的示例詳解

    Vue3中使用mock.js模擬數(shù)據(jù)的示例詳解

    前后端同時開發(fā)的時候,后端接口數(shù)據(jù)沒有出來,前端可以使用mock模擬假數(shù)據(jù),所以下面小編就來為大家詳細介紹一下如何在Vue3中使用mock.js模擬數(shù)據(jù)吧
    2025-03-03
  • Electron采集桌面共享和系統(tǒng)音頻(桌面捕獲)實例

    Electron采集桌面共享和系統(tǒng)音頻(桌面捕獲)實例

    這篇文章主要為大家介紹了Electron采集桌面共享和系統(tǒng)音頻(桌面捕獲)實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10

最新評論