日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

echarts默认高亮省市区联动

發(fā)布時間:2024/3/13 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 echarts默认高亮省市区联动 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

選中省份聯(lián)動對應的二級市或三級區(qū)縣,有項目的地區(qū)進行高亮標點,浮窗顯示具體數(shù)值

//main.js 引入echarts import * as echarts from 'echarts'; Vue.prototype.$echarts = echarts <!--父組件 全國地圖--> <div class="map" id="map"></div> <script>//引用地址在下方import china from '/public/json/china.json'import { Mapprovinces, MapprovincesText } from "./provinces.js";export default {data(){return{Mapprovinces,MapprovincesText,provinceInfo: {},projectMapVis:false}},mounted(){this.init()},methods:{// 該需求為通過點擊省份獲取該省份下的所有市(二級)/區(qū)縣(三級)init(){this.$echarts.registerMap('china', china);const provinceList = china.features;// axios 獲取后端數(shù)據(jù),通過循環(huán)對比獲取對應的經(jīng)緯度,進行標點/**let res = 'api/xxxxxxx'provinceList.filter(pl => {res.filter(al => {if (al.areaCode === pl.id) {projectNums.push({name: pl.properties.name,value: al.num,})effectScatterData.push({name: pl.properties.name,value: pl.properties.cp,num: al.num})}})})*/// 所需數(shù)據(jù)格式let projectNums = [{name:'云南',value:5},{name:'廣西',value:1}]; // 項目省份let effectScatterData = [{name:'云南',value:[101.712251, 24.040609],num:5},{name:'廣西',value:[108.720004, 23.82402],num:1}]; //散點數(shù)據(jù)const myChart = this.$echarts.init(document.getElementById('map'), null, {renderer: 'svg'});let option = {tooltip: {//提示框組件trigger: 'item',formatter: function (item) {if (item.componentSubType == 'map' && item.value) {return item.name + `<strong style="fontStyle:normal">${item.value}</strong>`} else if (item.componentSubType == 'effectScatter' && item.data.num) {return item.name + `<strong style="fontStyle:normal">${item.data.num}</strong>`} else {return item.name}},show: true,borderColor: '#fff',padding: [4, 15],textStyle: {color: "#262F3F",fontSize: 10}},geo: {map: 'china',aspectScale: 0.75,selectedMode: false,layoutCenter: ["50%", "50%"], layoutSize: '100%',regions: [{name: '南海諸島',itemStyle: {areaColor: 'rgba(0, 10, 52, 1)',borderColor: '#aee9fb',normal: {opacity: 0,label: {show: false,color: "#009cc9",}},},label: {show: false,color: '#262F3F',fontSize: 10,},}],},visualMap: {show: false,min: 1,inRange: {color: ['#EFF4F9']},},series: [// 常規(guī)地圖{type: 'map',mapType: 'china',aspectScale: 0.75, layoutCenter: ["50%", "50%"], layoutSize: '100%', label: {show: true, //區(qū)域formatter: '',color: '#262F3F',fontSize: 10,},itemStyle: { // 區(qū)域樣式normal: {areaColor: {type: 'linear',x: 0,y: 0,x2: 1,y2: 1,colorStops: [{offset: 0, color: '#D7E0EC' }, {offset: 1, color: '#D1DBE8' }],global: false }, // 背景borderColor: '#A1AFC6',borderWidth: 1},emphasis: { // 區(qū)域hover樣式areaColor: 'pink',label: {color: "#262F3F"}},},select: { // 區(qū)域選中樣式itemStyle: {areaColor: 'pink'},label: {color: "#262F3F"}},data: projectNums},{type: 'effectScatter',coordinateSystem: 'geo',symbolSize: 4,rippleEffect: { //點動畫color: '#0051D9',period: 3,scale: 5,brushType: 'fill'},// 坐標點data: effectScatterData,symbolOffset: ['-150%', '-150%'] // 光標偏移},]};let that = thismyChart.on('click', function (params) {if (params.name == '南海諸島') { return }provinceList.filter(pl => {if (pl.properties.name === params.name) {params.areaCode = pl.id}})//點擊省份顯示二級或三級(市、區(qū)縣地圖)that.projectMapVis = true;myChart.setOption(option);that.provinceInfo = params // 子組件用});myChart.setOption(option);window.addEventListener("resize", function () {myChart.resize();});}}} </script> <!--子組件 根據(jù)所選省份聯(lián)動的市/區(qū)縣地圖--> <div class="map" id="provinceMap"></div> <script> import axios from "axios"; import { MapprovincesText, Mapprovinces } from "./provinces.js"; export default {data () {return {MapprovincesText,Mapprovinces}},methods:{// 省份點擊后調(diào)用 傳遞 provinceInfo 參數(shù)getCity(params){for (var i = 0; i < this.MapprovincesText.length; i++) {if (params.name == this.MapprovincesText[i]) {//點擊獲取對應城市數(shù)據(jù) const name = this.Mapprovinces[i]//JSON數(shù)據(jù)在下方 來源datavlet url = '/json/province/' + name + '.json';axios.get(url).then(res => {this.canvasProvinceMap(name, params.areaCode, res.data)})break;}}},//繪制canvasProvinceMap: function (name, areaCode, mapData) {let _this = this;const params = {queryRange: "province",queryValue: areaCode}axios.get('xxxxxx').then(res => {const regionMapData = mapData.features;let projectNumData = [];let effectScatterData = [];regionMapData.filter(pl => {res.filter(al => {if (al.areaCode == pl.properties.adcode) {projectNumData.push({name: pl.properties.name,value: al.num,areaCode: al.areaCode})effectScatterData.push({areaCode: al.areaCode,name: pl.properties.name,// value: al.coordinate.split(','),value: pl.properties.centroid,num: al.num})}})})const provinceChart = this.$echarts.init(document.getElementById('provinceMap'), null, { renderer: 'svg' });this.$echarts.registerMap(name, mapData);//移除點擊事件provinceChart.off('click')// 繪制圖表let option = {tooltip: {trigger: 'item',formatter: function (item) {if (item.componentSubType == 'map' && item.value) {return item.name + item.value} else if (item.componentSubType == 'effectScatter' && item.data.num) {return item.name + item.data.num} else {return item.name}},show: true,borderColor: '#fff',padding: [4, 15],textStyle: {color: "#262F3F",fontSize: 8}},geo: {type: 'map',map: name, //省份selectedMode: false,aspectScale: 0.75,layoutCenter: ["50%", "50%"],layoutSize: '100%',roam: true, //是否平游或縮放scaleLimit: { //滾輪縮放的極限控制min: 1,max: 30},label: {show: true, //區(qū)域名稱樣式color: '#262F3F',fontSize: 8},itemStyle: { // 區(qū)域樣式normal: {areaColor: '#EFF4F9',// 背景borderColor: '#A1AFC6',borderWidth: 1},emphasis: { // 區(qū)域hover樣式areaColor: 'pink',label: {color: "#262F3F",fontSize: 8,}},},select: { // 選中樣式itemStyle: {areaColor: '#BCDAFF'}},},visualMap: {show: false,min: 1,inRange: {color: ['#BCDAFF']},},series: [{type: 'map',mapType: name,geoIndex: 0,aspectScale: 0.75,layoutCenter: ["50%", "50%"],layoutSize: '100%',data: projectNumData},// 區(qū)域散點圖{type: 'effectScatter',coordinateSystem: 'geo',symbolSize: 3,rippleEffect: { //點動畫color: '#0051D9',period: 3,scale: 3,brushType: 'fill'},data: effectScatterData}]};//散點點擊事件provinceChart.on('click', function (params) {});provinceChart.clear();setTimeout(() => {provinceChart.setOption(option);}, 300)window.addEventListener("resize", function () {provinceChart.resize();});})},} } </script>

靜態(tài)資源

//provinces.js const iconRQ = "image://" const Mapprovinces = ['shanghai', 'hebei', 'shanxi', 'neimenggu', 'liaoning', 'jilin', 'heilongjiang', 'jiangsu', 'zhejiang', 'anhui', 'fujian', 'jiangxi', 'shandong', 'henan', 'hubei', 'hunan', 'guangdong', 'guangxi', 'hainan', 'sichuan', 'guizhou', 'yunnan', 'xizang', 'shanxi1', 'gansu', 'qinghai', 'ningxia', 'xinjiang', 'beijing', 'tianjin', 'chongqing', 'xianggang', 'aomen', 'taiwan']; const MapprovincesText = ['上海', '河北', '山西', '內(nèi)蒙古', '遼寧', '吉林', '黑龍江', '江蘇', '浙江', '安徽', '福建', '江西', '山東', '河南', '湖北', '湖南', '廣東', '廣西', '海南', '四川', '貴州', '云南', '西藏', '陜西', '甘肅', '青海', '寧夏', '新疆', '北京', '天津', '重慶', '香港', '澳門', '臺灣']; export {iconRQ,Mapprovinces,MapprovincesText, };

全國地圖數(shù)據(jù)及省市json數(shù)據(jù)

總結(jié)

以上是生活随笔為你收集整理的echarts默认高亮省市区联动的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。