text.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. <template>
  2. <div class="content">
  3. <div class="map">
  4. <div id="myChart" :style="{width: '700px', height: '700px'}"></div>
  5. </div>
  6. <div class="chart">
  7. <div id="Chart" :style="{width: '500px', height: '700px'}"></div>
  8. </div>
  9. </div>
  10. </template>
  11. <script>
  12. import echarts from 'echarts'
  13. import '../../static/china.js' // 引入中国地图数据
  14. // import 'echarts/map/js/china.js';
  15. export default {
  16. data() {
  17. return {
  18. chart: null,
  19. data: [],
  20. total: 0,
  21. model1:'',
  22. periodList: [
  23. {
  24. value: 1,
  25. label: '学前'
  26. },
  27. {
  28. value: 2,
  29. label: '小学'
  30. },
  31. {
  32. value: 3,
  33. label: '初中'
  34. },
  35. {
  36. value: 4,
  37. label: '高中'
  38. },
  39. {
  40. value: 5,
  41. label: '中职'
  42. },
  43. ],
  44. subjectList: [
  45. {
  46. value: 1,
  47. label: '语文'
  48. },
  49. {
  50. value: 2,
  51. label: '数学'
  52. },
  53. {
  54. value: 3,
  55. label: '英语'
  56. },
  57. {
  58. value: 4,
  59. label: '生物'
  60. },
  61. {
  62. value:5,
  63. label: '化学'
  64. },
  65. ],
  66. teacherList: [
  67. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500'},
  68. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  69. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  70. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  71. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  72. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  73. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  74. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  75. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  76. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  77. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  78. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  79. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  80. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  81. { provice: '四川', subject: '语文', title: '省级名师', name: '周一', period: '小学', text1: '成员', number1: '1000', text2: '资源', number2: '2000', text3: '热度', number3: '1500' },
  82. ],
  83. geoCoordMap: {
  84. "四川省": [104.06, 30.67],
  85. "陕西省": [108.78, 34.40],
  86. "浙江省": [120.04, 30.35],
  87. "广东省": [113.23, 23.22],
  88. "湖北省": [114.12, 30.76],
  89. "宁夏回族自治区": [106.09, 38.62],
  90. "河南省": [113.45, 34.90],
  91. "黑龙江省": [126.48, 45.99],
  92. "甘肃省": [103.67, 36.22],
  93. "河北省": [114.34, 38.22],
  94. "北京市": [116.40, 39.94],
  95. "江苏省": [118.72, 32.24],
  96. "辽宁省": [123.24, 41.95],
  97. "吉林省": [125.23, 43.90],
  98. "安徽省": [117.17, 31.99],
  99. "福建省": [119.16, 26.18],
  100. "江西省": [115.80, 28.77],
  101. "山东省": [116.91, 36.81],
  102. "湖南省": [112.80, 28.47],
  103. "海南省": [110.18, 19.92],
  104. "贵州省": [106.49, 26.84],
  105. "云南省": [102.59, 25.25],
  106. "青海省": [101.60, 36.75],
  107. "西藏自治区": [90.97, 29.84],
  108. },
  109. dataIndex: "",
  110. teacherData:[
  111. {
  112. "name": "高新区",
  113. "value": 80
  114. }, {
  115. "name": "青羊区",
  116. "value": 87
  117. }, {
  118. "name": "天府新区",
  119. "value": 60
  120. }, {
  121. "name": "锦江区",
  122. "value": 40
  123. }, {
  124. "name": "金牛区",
  125. "value": 50
  126. }, {
  127. "name": "郫都区",
  128. "value": 30
  129. }, {
  130. "name": "温江区",
  131. "value": 40
  132. }
  133. ]
  134. }
  135. },
  136. mounted() {
  137. this.drawLine();
  138. this.drawChart();
  139. },
  140. methods: {
  141. drawLine() {
  142. var mapChart = echarts.init(document.getElementById('myChart'));
  143. // mapChart的配置
  144. var option = {
  145. series: [{
  146. type: 'map',
  147. mapType: 'china',
  148. label: {
  149. normal: {
  150. show: false,//显示省份标签
  151. textStyle: { color: "#141414" }//省份标签字体颜色
  152. },
  153. emphasis: {//对应的鼠标悬浮效果
  154. show: true,
  155. textStyle: { color: "#666" }
  156. }
  157. },
  158. lineStyle: {
  159. normal: {
  160. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
  161. offset: 0, color: '#58B3CC'
  162. }, {
  163. offset: 1, color: '#F58158'
  164. }], false),
  165. width: 1,
  166. opacity: 0.2,
  167. curveness: 0.1
  168. }
  169. },
  170. itemStyle: {
  171. normal: {
  172. borderWidth: .5,//区域边框宽度
  173. borderColor: '#666',//区域边框颜色
  174. areaColor: "#fff",//区域颜色
  175. //background-image: linear-gradient(135deg, #f5f7fa 0 %, #c3cfe2 100 %);
  176. },
  177. emphasis: {
  178. borderWidth: .5,
  179. borderColor: '#4b0082',
  180. areaColor: "#008DFF",
  181. }
  182. },
  183. data: [
  184. { name: '四川', selected: true },//福建为选中状态
  185. { name: '广东', selected: true },//福建为选中状态
  186. { name: '湖北', selected: true },//福建为选中状态
  187. ]
  188. }],
  189. }
  190. mapChart.setOption(option);
  191. mapChart.on('click', function (params) {
  192. this.dataIndex = params.dataIndex;
  193. console.log(params);
  194. });
  195. },
  196. drawChart() {
  197. var myChart = echarts.init(document.getElementById('Chart'));
  198. var xData = [],
  199. yData = [];
  200. var min = 50; // 最小值的定义
  201. this.teacherData.map(function (a, b) {
  202. xData.push(a.name);
  203. if (a.value === 0) {
  204. yData.push(a.value + min);
  205. } else {
  206. yData.push(a.value);
  207. }
  208. });
  209. var option = {
  210. //color: ['#3398DB'],
  211. tooltip: {
  212. trigger: 'axis',
  213. axisPointer: {
  214. type: 'line',
  215. lineStyle: {
  216. opacity: 0
  217. }
  218. },
  219. formatter: function (prams) {
  220. return "名师数:" + prams[0].data
  221. }
  222. },
  223. grid: {
  224. left: '0%',
  225. right: '0%',
  226. bottom: '5%',
  227. top: '5%',
  228. height: '50%',
  229. containLabel: true,
  230. z: 22
  231. },
  232. xAxis: [{
  233. type: 'category',
  234. gridIndex: 0,
  235. data: xData,
  236. axisTick: {
  237. alignWithLabel: true
  238. },
  239. axisLine: {
  240. lineStyle: {
  241. color: '#0c3b71'
  242. }
  243. },
  244. axisLabel: {
  245. show: true,
  246. color: 'rgb(170,170,170)',
  247. fontSize: 12
  248. }
  249. }],
  250. yAxis: [{
  251. type: 'value',
  252. gridIndex: 0,
  253. splitLine: {
  254. show: true
  255. },
  256. axisTick: {
  257. show: true
  258. },
  259. max: 150,
  260. axisLine: {
  261. lineStyle: {
  262. color: '#0c3b71'
  263. }
  264. },
  265. axisLabel: {
  266. color: 'rgb(170,170,170)',
  267. formatter: '{value} '
  268. }
  269. },
  270. {
  271. type: 'value',
  272. gridIndex: 0,
  273. max: 200,
  274. }
  275. ],
  276. series: [{
  277. type: 'bar',
  278. barWidth: '20',
  279. xAxisIndex: 0,
  280. yAxisIndex: 0,
  281. itemStyle: {
  282. normal: {
  283. //barBorderRadius: [30, 30, 0, 0],
  284. color: new echarts.graphic.LinearGradient(
  285. 0, 0, 0, 1, [
  286. // {
  287. // offset: 0,
  288. // color: '#00feff'
  289. //},
  290. {
  291. offset: 0.5,
  292. color: '#4da1ff'
  293. },
  294. {
  295. offset: 1,
  296. color: '#4da1ff'
  297. }
  298. ]
  299. )
  300. }
  301. },
  302. data: yData,
  303. zlevel: 11
  304. },
  305. ]
  306. };
  307. myChart.setOption(option);
  308. }
  309. },
  310. }
  311. </script>
  312. <style scoped>
  313. .content{
  314. display:flex;
  315. }
  316. .map {
  317. width: 50%;
  318. height: 600px;
  319. /*margin-left:150px;*/
  320. padding-left: 250px;
  321. /*background: url("../../assets/image/resource/title-bg.jpg") center 120% no-repeat;*/
  322. /*background-color:aliceblue;*/
  323. }
  324. .chart {
  325. width: 600px;
  326. height: 700px;
  327. /*border: 1px solid red;*/
  328. margin-left: 10px;
  329. /*background-color: aliceblue;*/
  330. }
  331. </style>