summaryrefslogtreecommitdiff
path: root/UI source code/dns_mapping_ui-master/src/components/Echarts/Do53Fwdrdns.vue
diff options
context:
space:
mode:
authorunknown <[email protected]>2022-06-24 17:11:23 +0800
committerunknown <[email protected]>2022-06-24 17:11:23 +0800
commit8565e1bb597b481447d33bac6d8c48c2c45215de (patch)
treea4f10c8f7f85a1a8b5c947f7d0d2f967d808a9c4 /UI source code/dns_mapping_ui-master/src/components/Echarts/Do53Fwdrdns.vue
parent8165dfcc7bdb0b2e6f1c05f8e7c93553c0e7911e (diff)
upload UI source codeHEADmain
Diffstat (limited to 'UI source code/dns_mapping_ui-master/src/components/Echarts/Do53Fwdrdns.vue')
-rw-r--r--UI source code/dns_mapping_ui-master/src/components/Echarts/Do53Fwdrdns.vue166
1 files changed, 166 insertions, 0 deletions
diff --git a/UI source code/dns_mapping_ui-master/src/components/Echarts/Do53Fwdrdns.vue b/UI source code/dns_mapping_ui-master/src/components/Echarts/Do53Fwdrdns.vue
new file mode 100644
index 0000000..0be12ba
--- /dev/null
+++ b/UI source code/dns_mapping_ui-master/src/components/Echarts/Do53Fwdrdns.vue
@@ -0,0 +1,166 @@
+<template>
+ <div class="wrapper">
+ <div id="chart4" class="chart" />
+ </div>
+</template>
+
+<script>
+import echarts from 'echarts'
+export default {
+ props: ['do53fwdrdns'],
+ data() {
+ return {}
+ },
+ mounted() {
+ this.getWorld(this.do53fwdrdns)
+ var myChartContainer = document.getElementById('chart4')
+ // 获取自适应的高度和宽度
+ var resizeMyChartContainer = function() {
+ // myChartContainer.style.height = window.innerHeight * 0.65 + 'px';
+ // myChartContainer.style.width = window.innerWidth * 0.75 + 'px';
+ myChartContainer.style.height = 300 + 'px'
+ myChartContainer.style.width = 600 + 'px'
+ if (window.innerWidth > 768 && window.innerWidth < 1370) {
+ myChartContainer.style.width = 500 + 'px'
+ }
+ }
+ // 设置容器高和宽
+ resizeMyChartContainer()
+ var myChart = echarts.init(myChartContainer)
+ const option = {}
+ myChart.setOption(option)
+ },
+ methods: {
+ changeKey(arr, key) {
+ const newArr = []
+ arr.forEach((item, index) => {
+ const newObj = {}
+ for (var i = 0; i < key.length; i++) {
+ newObj[key[i]] = item[Object.keys(item)[i]]
+ }
+ newArr.push(newObj)
+ })
+ return newArr
+ },
+ getWorld(data) {
+ const list = this.changeKey(this.do53fwdrdns, ['name', 'value'])
+ var that = this
+ // const {ctx} = getCurrentInstance()
+ this.$axios.get('/sjData/word.json').then(function(res) {
+ // console.log(list,111);
+ const namemap = res.data.namemap
+ const dataArr = list
+ // let dataArr = data.data
+ that.drawChart(namemap, dataArr)
+ })
+ },
+ drawChart(name, data) {
+ // 基于准备好的dom,初始化echarts实例
+ const chart = echarts.init(document.getElementById('chart4'))
+
+ // 监听屏幕变化自动缩放图表
+ window.addEventListener('resize', function() {
+ chart.resize()
+ })
+ // 绘制图表
+ chart.setOption({
+ // 图表主标题
+ // title: {
+ // text: '世界地图', // 主标题文本,支持使用 \n 换行
+ // top: 10, // 定位 值: 'top', 'middle', 'bottom' 也可以是具体的值或者百分比
+ // left: 'center', // 值: 'left', 'center', 'right' 同上
+ // textStyle: { // 文本样式
+ // fontSize: 24,
+ // fontWeight: 600,
+ // color: '#000'
+ // }
+ // },
+
+ grid: {
+ width: '100%',
+ height: '100%',
+ left: '0%',
+ right: '0%',
+ bottom: '0%',
+ containLabel: true
+ },
+ // 提示框组件
+ tooltip: {
+ trigger: 'item', // 触发类型, 数据项图形触发,主要在散点图,饼图等无类目轴的图表中使用
+ // 提示框浮层内容格式器,支持字符串模板和回调函数两种形式
+ // 使用函数模板 传入的数据值 -> value: number | Array
+ formatter: function(val) {
+ if (val.data == null) return
+ return val.data.name + ': ' + val.data.value
+ }
+ },
+ // 视觉映射组件
+ visualMap: {
+ min: 0,
+ max: 10000,
+ text: ['max', 'min'],
+ realtime: false,
+ calculable: true,
+ color: ['#4608AD', '#d9e4ff']
+ },
+ series: [
+ {
+ type: 'map', // 类型
+ // 系列名称,用于tooltip的显示,legend 的图例筛选 在 setOption 更新数据和配置项时用于指定对应的系列
+ name: '世界地图',
+ mapType: 'world', // 地图类型
+ // 是否开启鼠标缩放和平移漫游 默认不开启 如果只想要开启缩放或者平移,可以设置成 'scale' 或者 'move' 设置成 true 为都开启
+ roam: true,
+ // 图形上的文本标签
+ label: {
+ show: false // 是否显示对应地名
+ },
+ zoom: 1.2,
+ // 地图区域的多边形 图形样式
+ itemStyle: {
+ // areaColor: '#7B68EE', // 地图区域的颜色 如果设置了visualMap,areaColor属性将不起作用
+ borderWidth: 0.5, // 描边线宽 为 0 时无描边
+ borderColor: '#000', // 图形的描边颜色 支持的颜色格式同 color,不支持回调函数
+ borderType: 'solid' // 描边类型,默认为实线,支持 'solid', 'dashed', 'dotted'
+ },
+ // 高亮状态下的多边形和标签样式
+ emphasis: {
+ label: {
+ show: true, // 是否显示标签
+ color: '#fff' // 文字的颜色 如果设置为 'auto',则为视觉映射得到的颜色,如系列色
+ },
+ itemStyle: {
+ areaColor: '#FF6347' // 地图区域的颜色
+ }
+ },
+ // 自定义地区的名称映射
+ nameMap: name,
+ // 地图系列中的数据内容数组 数组项可以为单个数值
+ data: data
+ }
+ ]
+ })
+ }
+ }
+}
+</script>
+<style lang="scss">
+.wrapper {
+ width: 100%;
+}
+.wrapper .chart1{
+ width: 60%;
+ /* margin:0 auto; */
+ height: 400px;
+ /* border: 1px solid #eeeeee; */
+ /* background: url(../../public/static/bg.png) no-repeat; 背景图设置*/
+ background-size: 100% 100%;
+ background-color: #fff;
+}
+.chart1 {
+ width: 100%;
+ height: 100%;
+ background-color: yellow;
+
+}
+</style>