echarts折线柱状图等legend图例,自定义为图片或者设置为复选框多选框checkbox的样式

echarts折线柱状图等legend图例,自定义为图片或者设置为复选框多选框checkbox的样式
中心思想,想要把lengend图例设置为复选框checkbox那样的样式,直接设置是行不通的,只有通过设置为选中图片,未选中的图片;我们需要把复选框的两种选中未选中的复选框切成图片,然后把图片转为 64位的,就可以实现了
在这里插入图片描述

下面是复选框的两类情况的 64的图片,因为我的项目中基本上都是用的这个,所以专门用了一个js文件存放,你们在用的时候可以直接复制相关信息即可

const icon = {
  checked:  //复选框选中样式图片65位
    "image://",
  normol: //复选框未选中样式图片65位
    "image://"
};

export default icon;

下面就是在legend中的配置

legend: {
          data: ["A相", "B相", "C相"],
          textStyle: { color: "white" },
          x: "middle",
          padding: [10, 50, 0, 0]
        },
        icon:icon.checked//初始状态默认选中样式

下面就是切换点击了

var myChart = echarts.init(this.$refs["jyxn_qtYL"]);
myChart.setOption(option, true);
   //点击切换icon
myChart.on("legendselectchanged", function(obj) {
	var selected = obj.selected;
	if (!selected.A) {
   		option.legend[0].data[0].icon = icon.normol;
	}
	myChart.setOption(option);
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 C# 中使用 echarts,可以通过以下步骤动态添加或删除多条 y 轴: 1. 在 HTML 文件中,定义好 echarts 图表的容器和相关的 checkbox 复选框。 ```html <div id="chart" style="width: 100%; height: 400px;"></div> <input type="checkbox" id="yAxis1" onchange="onYAxisChanged()" checked> Y轴1 <input type="checkbox" id="yAxis2" onchange="onYAxisChanged()" checked> Y轴2 ``` 2. 在 C# 代码中,通过 `StringBuilder` 构建 echarts 的配置项,包括 xAxis、yAxis、series 等。 ```csharp StringBuilder sb = new StringBuilder(); sb.Append("option = {"); sb.Append("xAxis: {"); sb.Append("type: 'category',"); sb.Append("data: ['A', 'B', 'C', 'D', 'E', 'F']"); sb.Append("},"); sb.Append("yAxis: ["); if (yAxis1.Checked) { sb.Append("{"); sb.Append("type: 'value',"); sb.Append("name: 'Y轴1'"); sb.Append("},"); } if (yAxis2.Checked) { sb.Append("{"); sb.Append("type: 'value',"); sb.Append("name: 'Y轴2'"); sb.Append("},"); } // 删除最后一个逗号 sb.Remove(sb.Length - 1, 1); sb.Append("],"); sb.Append("series: ["); sb.Append("{"); sb.Append("name: 'Series1',"); sb.Append("type: 'bar',"); sb.Append("data: [5, 20, 36, 10, 10, 20]"); sb.Append("},"); sb.Append("{"); sb.Append("name: 'Series2',"); sb.Append("type: 'line',"); sb.Append("yAxisIndex: 1,"); sb.Append("data: [10, 30, 50, 60, 70, 80]"); sb.Append("}"); sb.Append("]"); sb.Append("};"); ``` 3. 在 C# 代码中,定义 `onYAxisChanged` 函数,在复选框状态改变时,重新渲染 echarts 图表。 ```csharp protected void onYAxisChanged() { StringBuilder sb = new StringBuilder(); sb.Append("option.yAxis = ["); if (yAxis1.Checked) { sb.Append("{"); sb.Append("type: 'value',"); sb.Append("name: 'Y轴1'"); sb.Append("},"); } if (yAxis2.Checked) { sb.Append("{"); sb.Append("type: 'value',"); sb.Append("name: 'Y轴2'"); sb.Append("},"); } // 删除最后一个逗号 sb.Remove(sb.Length - 1, 1); sb.Append("];"); // 渲染图表 chartPage.ClientScript.RegisterStartupScript(this.GetType(), "chart", sb.ToString(), true); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值