echartLine1.vue 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. <template>
  2. <div class="echartLine">
  3. <div class="line" ref="line"></div>
  4. </div>
  5. </template>
  6. <script lang="ts" setup>
  7. import * as echarts from 'echarts'
  8. import { ref, nextTick, reactive, watch,defineProps } from 'vue';
  9. let props = defineProps({
  10. echartDataSg: {
  11. type: Object,
  12. }
  13. })
  14. //获取dom元素节点
  15. let line = ref<any>()
  16. let echartDataSgs=reactive({})
  17. watch(() => props.echartDataSg, (data) => {
  18. echartDataSgs = Object.assign({},data)
  19. getOption()
  20. }, { immediate: true,deep:true })
  21. function getOption() {
  22. nextTick(() => {
  23. const myChart = echarts.init(line.value)
  24. let option = {
  25. grid: {
  26. top: '8%',
  27. left: '5%',
  28. bottom: '14%',
  29. right: '5%',
  30. // containLabel: true,
  31. },
  32. tooltip: {
  33. trigger: 'axis',
  34. },
  35. xAxis: [
  36. {
  37. type: 'category',
  38. boundaryGap: false,
  39. axisLabel: {
  40. // formatter: '{value}',
  41. fontSize: 14,
  42. margin: 10,
  43. textStyle: {
  44. color: '#b3b8cc',
  45. },
  46. // interval: 0,
  47. formatter: function (params) {
  48. let newParamsName = ref('') // 最终拼接成的字符串
  49. let paramsNameNumber =ref(params.length ) // 实际标签的个数
  50. let provideNumber =ref(10) // 每行能显示的字的个数
  51. let rowNumber = Math.ceil(paramsNameNumber.value / provideNumber.value) // 换行的话,需要显示几行,向上取整
  52. /**
  53. * 判断标签的个数是否大于规定的个数, 如果大于,则进行换行处理 如果不大于,即等于或小于,就返回原标签
  54. */
  55. // 条件等同于rowNumber>1
  56. if (paramsNameNumber.value > provideNumber.value) {
  57. /** 循环每一行,p表示行 */
  58. for (var p = 0; p < rowNumber; p++) {
  59. var tempStr = '' // 表示每一次截取的字符串
  60. var start = p * provideNumber.value // 开始截取的位置
  61. var end = start + provideNumber.value // 结束截取的位置
  62. // 此处特殊处理最后一行的索引值
  63. if (p == rowNumber - 1) {
  64. // 最后一次不换行
  65. tempStr = params.substring(start, paramsNameNumber.value)
  66. } else {
  67. // 每一次拼接字符串并换行
  68. tempStr = params.substring(start, end) + '\n'
  69. }
  70. newParamsName.value += tempStr // 最终拼成的字符串
  71. }
  72. } else {
  73. // 将旧标签的值赋给新标签
  74. newParamsName.value = params
  75. }
  76. //将最终的字符串返回
  77. return newParamsName.value
  78. }
  79. },
  80. axisLine: {
  81. lineStyle: {
  82. color: '#244a94',
  83. },
  84. },
  85. splitLine: {
  86. show: true,
  87. lineStyle: {
  88. color: '#0d2973',
  89. type: 'dashed',
  90. },
  91. },
  92. axisTick: {
  93. show: false,
  94. },
  95. data: echartDataSgs.xData,
  96. },
  97. ],
  98. yAxis: [
  99. {
  100. boundaryGap: false,
  101. name: '(%)',
  102. type: 'value',
  103. max: 2000,
  104. axisLabel: {
  105. textStyle: {
  106. color: '#b3b8cc',
  107. },
  108. },
  109. nameTextStyle: {
  110. color: '#fff',
  111. fontSize: 12,
  112. lineHeight: 2,
  113. },
  114. splitLine: {
  115. lineStyle: {
  116. color: '#0d2973',
  117. type: 'dashed',
  118. },
  119. },
  120. axisLine: {
  121. show: true,
  122. lineStyle: {
  123. color: '#244a94',
  124. },
  125. },
  126. axisTick: {
  127. show: false,
  128. },
  129. },
  130. ],
  131. series: [
  132. {
  133. name: echartDataSgs.lengedData ? echartDataSgs.lengedData : '',
  134. type: 'line',
  135. smooth: false,
  136. showSymbol: false,
  137. symbolSize: 8,
  138. zlevel: 3,
  139. itemStyle: {
  140. color: '#02f2de',
  141. borderColor: '#a3c8d8',
  142. },
  143. lineStyle: {
  144. normal: {
  145. width: 3,
  146. color: '#02f2de',
  147. },
  148. },
  149. areaStyle: {
  150. normal: {
  151. color: new echarts.graphic.LinearGradient(
  152. 0,
  153. 0,
  154. 0,
  155. 1,
  156. [
  157. {
  158. offset: 0,
  159. color: 'rgba(2, 242, 222,0.8)',
  160. },
  161. {
  162. offset: 0.5,
  163. color: 'rgba(2, 242, 222,0.4)',
  164. },
  165. {
  166. offset: 0.9,
  167. color: 'rgba(2, 242, 222,0)',
  168. },
  169. ],
  170. false
  171. ),
  172. },
  173. },
  174. data: echartDataSgs.yData,
  175. },
  176. ],
  177. }
  178. myChart.setOption(option)
  179. window.onresize = function () {
  180. myChart.resize()
  181. }
  182. })
  183. }
  184. </script>
  185. <style scoped lang='less'>
  186. .echartLine {
  187. width: 100%;
  188. height: 100%;
  189. .line {
  190. width: 100%;
  191. height: 100%;
  192. }
  193. }
  194. </style>