ECharts圖座標軸文字換行問題處理

竹林聽雨行發表於2019-12-24

js map()函式

概念:

map()方法定義在JavaScript的Array中,它返回一個新的陣列,陣列中的元素為原始陣列呼叫函式處理後的值

示例:
var array = [1, 2, 3, 4, 5];
​
var newArray = array.map((item) => {
    return item * item;
})
​
console.log(newArray)  // [1, 4, 9, 16, 25]複製程式碼

ECharts座標註文字換行程式碼

<!DOCTYPE html>
<html>
​
<head>
    <meta charset="utf-8">
    <title>ECharts</title>
    <!-- 引入 echarts.js -->
    <script src="echarts.min.js"></script>
</head>
​
<body>
    <!-- 為ECharts準備一個具備大小(寬高)的Dom -->
    <div id="main" style="width: 600px;height:400px;"></div>
    <script type="text/javascript">
        // 基於準備好的dom,初始化echarts例項
        var myChart = echarts.init(document.getElementById('main'));
​
        // 指定圖表的配置項和資料
        var option = {
            title: {
                text: 'ECharts 入門示例'
            },
            tooltip: {},
            legend: {
                data: ['銷量']
            },
            xAxis: {
                data: ["襯衫", "羊毛衫", "雪紡衫", "褲子", "高跟鞋", "襪子"].map( params=> {
​
                    // var newParamsName = "";
                    // var paramsNameNumber = params.length;
                    // var provideNumber = 2;
                    // var rowNumber = Math.ceil(paramsNameNumber / provideNumber);
                    // if (paramsNameNumber > provideNumber) {
                    //     for (var p = 0; p < rowNumber; p++) {
                    //         var tempStr = "";
                    //         var start = p * provideNumber;
                    //         var end = start + provideNumber;
                    //         if (p == rowNumber - 1) {
                    //             tempStr = params.substring(start, paramsNameNumber);
                    //         } else {
                    //             tempStr = params.substring(start, end) + "\n";
                    //         }
                    //         newParamsName += tempStr;
                    //     }
                    // } else {
                    //     newParamsName = params;
                    // }
                   
                    return formatParams(params);
                })
            },
            yAxis: {},
            series: [{
                name: '銷量',
                type: 'bar',
                data: [5, 20, 36, 10, 10, 20]
            }]
        };
        // 使用剛指定的配置項和資料顯示圖表。
        myChart.setOption(option);
​
​
        function formatParams(params) {
            var newParamsName = "";
            var paramsNameNumber = params.length;
            var provideNumber = 2;
            var rowNumber = Math.ceil(paramsNameNumber / provideNumber);
            if (paramsNameNumber > provideNumber) {
                for (var p = 0; p < rowNumber; p++) {
                    var tempStr = "";
                    var start = p * provideNumber;
                    var end = start + provideNumber;
                    if (p == rowNumber - 1) {
                        tempStr = params.substring(start, paramsNameNumber);
                    } else {
                        tempStr = params.substring(start, end) + "\n";
                    }
                    newParamsName += tempStr;
                }
            } else {
                newParamsName = params;
            }
            return newParamsName;
        }
    </script>
</body>
</html>複製程式碼

附:ECharts網址

echarts.apache.org/zh/index.ht…


相關文章