
<template>
<div ref="chart" :style="{ width, height }" class="container">00000</div>
</template>
<script>
export default {
props: {
width: {
type: String,
default: "500px",
},
height: {
type: String,
default: "300px",
},
data: {
type: Array,
required: true,
},
options: {
required: true,
},
},
data() {
return {
symbol:
"image://",
};
},
mounted() {
let option = {
xAxis: {
type: "category",
data: ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"],
},
yAxis: {
type: "value",
},
grid: {
left: "3%",
right: "4%",
bottom: "3%",
top: 0,
containLabel: true,
},
series: [
{
data: [150, 100, 224, 218, 135, 147, 260],
type: "line",
markPoint: {
symbol: "path://m 0,0 h 48 v 20 h -30 l -6,10 l -6,-10 h -6 z",
symbolSize: 50,
symbolOffset: ["34%", "-50%"],
symbolKeepAspect: true,
label: {
position: "insideTop",
distance: 7,
},
data: [{
value:100,
coord: [1, 100],
}]
},
},
],
};
this.initChart(this.$refs.chart, option, (data) => {
console.log(data);
});
},
methods: {
textSize(text, fontSize) {
var span = document.createElement("span");
var result = {
width: span.offsetWidth,
height: span.offsetHeight,
};
span.style.visibility = "hidden";
span.style.fontSize = fontSize || "14px";
document.body.appendChild(span);
if (typeof span.textContent != "undefined")
span.textContent = text || "国";
else span.innerText = text || "国";
result.width = span.offsetWidth - result.width;
result.height = span.offsetHeight - result.height;
span.parentNode.removeChild(span);
return result;
},
toHSpeed(speed, fix) {
if (isNaN(speed)) return speed;
if (!fix && fix != 0) fix = 2;
if (speed >= 125000000) {
speed /= 125000000;
speed = speed.toFixed(fix) + "Gbps";
} else if (speed >= 125000) {
speed /= 125000;
speed = speed.toFixed(fix) + "Mbps";
} else if (speed >= 125) {
speed /= 125;
speed = speed.toFixed(fix) + "Kbps";
} else {
speed *= 8;
speed = speed.toFixed(fix) + "bps";
}
return speed;
},
},
};
</script>
<style lang="scss" scoped >
.container {
width: 500px;
height: 300px;
}
</style>