echarts格式化数据formatter,拒绝无效重复渲染useMemo

格式化数据

坐标轴

yAxis: [
  {
 	type: 'value',
    position: 'right',
    axisLabel: {
      textStyle: {
        color: '#223254',
        fontSize: 14,
      },
      formatter: '{value}%', // 加上 %
      // 也可以是函数 (value) => {}
    },
  }
]

悬浮提示框

tooltip: {
  trigger: 'axis',
  formatter: function (params) {
    var str = params[0].name + '<br>';
    for (let item of params) {
      if (item.componentSubType === 'line') {
        str += `${item.marker}${item.seriesName}: ${item.data}%<br>`; // 为折线图时加 %
      } else {
        str += `${item.marker}${item.seriesName}: ${item.data}<br>`; // 保持不变
      }
    }
    return str;
  },
},

数据项

 series: [
   {
       name: 'name',
       type: 'line',
       data: [],
       itemStyle: {
            label: {
                show:true,
                position:'top',
                formatter:'{c}%' // 在柱状图每一项上方显示数据,加上 %
            }
        }
    }
]

拒绝无效重复渲染

// 一个组件内用了echarts图表
const Component = ({data}) => {
	return (
		<div>
			.......
			 <ReactEcharts style={{ width: '100%', height: '100%' }} option={option} />
			 .......
		</div>
	)
}

// 用useMemo封装
const getComponentMemo = useMemo(() => {
    return <Component data={currentData} />;
}, [currentData]);

// 调用封装的函数
<div>{getComponentMemo}</div>

React.memo与useMemo的选用

React.memo是一个高阶组件,useMemo是一个hook。
React.memo可以自定义更新比较方式,但需要注意传参为对象的情况,要进行深度比较

const Page = (props) => {}; // 页面组件

React.memo(Page, (props, nextProps) => {
	// 自定义比较code
  	return JSON.stringify(props) === JSON.stringify(nextProps); // 浅层比较
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值