建立echart多個聯動demo

鼠標懸浮同時觸發多個echart
  • 效果以下

圖片描述

  • html代碼
<div class="contain">
        <div class="sel">
            <div class="sel1">
                <div class="top">
                    <span>選擇時間間隔</span>
                    <div class="show">
                        <span>one second</span>
                        <i class="glyphicon glyphicon-chevron-right"></i>
                    </div>
                </div>
                <div class="block">
                    <div leap="second">one second</div>
                    <div leap="minute">one minute</div>
                    <div leap="hour">one hour</div>
                    <div leap="day">one day</div>
                    <div leap="week">one week</div>
                    <div leap="month">one month</div>
                    <div class="active" leap="year">one year</div>
                </div>
            </div>
            <div class="sel2">
                <div class="top">
                    <span>選擇數據個數</span>
                    <div class="show">
                        <span>5</span>
                        <i class="glyphicon glyphicon-chevron-right"></i>
                    </div>
                </div>
                <div class="block">
                    <div leap="5">5</div>
                    <div leap="10">10</div>
                    <div leap="15">15</div>
                    <div leap="20">20</div>
                    <div leap="25">25</div>
                    <div leap="30">30</div>
                    <div leap="35">35</div>
                </div>
            </div>
            <div class="zybtn">肯定</div>
        </div>
        <!-- 爲ECharts準備一個具有大小(寬高)的Dom -->
        <div id="main" style="width: 1000px;height:300px;margin-top:45px;"></div>
        <div id="main2" style="width: 1000px;height:300px;"></div>
    </div>
  • css代碼
body {
    margin: 0;
    padding: 0;
    background-color: #eee;
}
.contain {
    padding: 10px;
}
.sel {
    position: absolute;
    height: 250px;
    z-index: 10;
}
.sel>div {
    float: left;
    margin-right: 10px;
}
.top span {
    display: inline-block;
    width: 100px;
    height: 30px;
}
.top .show {
    width: 125px;
    height: 25px;
    float: right;
    border: 1px solid #444;
    padding-left: 5px;
    position: relative;
}

.block {
    float: right;
    position: relative;
    border-radius: 5px;
    padding: 5px;
    width: 120px;
    box-shadow: 1px 1px 5px #444;
    display: none;
    background-color: #fff;
}
.block>div {
    height: 25px;
    line-height: 25px;
    padding-left: 5px;
    border-radius: 5px;
    cursor: pointer;
}
.block>div:hover {
    background-color: #D3E3E5;
}
.block>div.active {
    background-color: #087C90;
    color: #fff;
}
.zybtn {
    width: 80px;
    height: 30px;
    border-radius: 5px;
    background-color: #46AD08;
    line-height: 30px;
    text-align: center;
    color: #fff;
    cursor: pointer;
}
i.glyphicon {
    top: 3px;
    right: 5px
}
  • js代碼
function drawchart(timearr, dataarr) {
    // 基於準備好的dom,初始化echarts實例
    var myChart1 = echarts.init(document.getElementById('main'));
    var myChart2 = echarts.init(document.getElementById('main2'));

    // 指定圖表的配置項和數據
    var option1 = {
        title: {
            text: 'chart1'
        },
        tooltip: {
            show: true,
            trigger: 'axis',
            axisPointer: {
                type: 'line'
            },
            lineStyle: {
                color: '#000',
            }
        },
        legend: {
            data: ['銷量1']
        },
        grid:{
            y2:140
        },
        xAxis: [{
            type: 'category',
            data: timearr,
            axisLabel: {
                interval: 0, //橫軸信息所有顯示
                rotate: -45, //-30度角傾斜顯示
            }
        }],
        yAxis: [{
            type: 'value',

        }],
        series: [{
            name: '銷量1',
            type: 'line',
            data: dataarr
        }]
    };
    var option2 = {
        title: {
            text: 'chart2'
        },
        tooltip: {
            show: true,
            trigger: 'axis',
            axisPointer: {
                type: 'line'
            },
            lineStyle: {
                color: '#000',
            }
        },
        legend: {
            data: ['銷量2']
        },
        grid:{
            y2:140
        },
        xAxis: [{
            type: 'category',
            data: timearr,
            axisLabel: {
                interval: 0, //橫軸信息所有顯示
                rotate: -45, //-30度角傾斜顯示
            }
        }],
        yAxis: [{
            type: 'value',

        }],
        series: [{
            name: '銷量2',
            type: 'line',
            data: dataarr
        }]
    };

    // 爲echarts對象加載數據
    myChart1.setOption(option1);
    myChart2.setOption(option2); //聯動配置

    // 分別設置每一個實例的 group id
    myChart1.group = 'group1';
    myChart2.group = 'group1';
    echarts.connect('group1');
    // 或者能夠直接傳入須要聯動的實例數
    // echarts.connect([myChart1,myChart2]);
}
// 獲取x軸時間字符串
function gettimestr(tseconds) {
    var str = '';
    var year = new Date(tseconds).getFullYear();
    var month = new Date(tseconds).getMonth() + 1;
    var date = new Date(tseconds).getDate();
    var hour = new Date(tseconds).getHours();
    var minute = new Date(tseconds).getMinutes();
    var second = new Date(tseconds).getSeconds();
    if (month < 10) {
        month = "0" + month
    }
    if (date < 10) {
        date = "0" + date
    }
    if (hour < 10) {
        hour = "0" + hour
    }
    if (minute < 10) {
        minute = "0" + minute
    }
    if (second < 10) {
        second = "0" + second
    }
    str += year + "-" + month + "-" + date + " " + hour + ":" + minute + ":" + second;
    return str;
}
getsel()
// 獲取兩個數值
function getsel() {
    $("i").on("click", function () {
        var that = $(this);
        var block = that.parents(".top").next();
        // 點擊i觸發函數,判斷類型
        if ($(this).hasClass("glyphicon-chevron-right")) {
            $(this).removeClass("glyphicon-chevron-right");
            $(this).addClass("glyphicon-chevron-down")
            block.children("div").each(function () {
                $(this).removeClass("active")
            });
            block.slideDown();

        } else if ($(this).hasClass("glyphicon-chevron-down")) {
            $(this).removeClass("glyphicon-chevron-down");
            $(this).addClass("glyphicon-chevron-right")
            block.slideUp()
        }
        block.children("div").on("click", function () {
            $(this).addClass("active");
            that.prev("span").html($(this).html())
            that.removeClass("glyphicon-chevron-down");
            that.addClass("glyphicon-chevron-right")
            block.slideUp()
        });
    });
    var val1 = 1000;
    var val2 = 5;
    $(".zybtn").on("click", function () {
        switch ($(".sel1 .show span").html()) {
            case 'one second':
                val1 = 1000;
                break;
            case 'one minute':
                val1 = 1000 * 60;
                break;
            case 'one hour':
                val1 = 1000 * 3600;
                break;
            case 'one day':
                val1 = 1000 * 3600 * 24;
                break;
            case 'one week':
                val1 = 1000 * 3600 * 24 * 7;
                break;
            case 'one month':
                val1 = 1000 * 3600 * 24 * 30;
                break;
            case 'one year':
                val1 = 1000 * 3600 * 24 * 365;
                break;
        }
        switch ($(".sel2 .show span").html()) {
            case '5':
                val2 = 5;
                break;
            case '10':
                val2 = 10;
                break;
            case '15':
                val2 = 15;
                break;
            case '20':
                val2 = 20;
                break;
            case '25':
                val2 = 25;
                break;
            case '30':
                val2 = 30;
                break;
            case '35':
                val2 = 35;
                break;
        }
        changedata(val1, val2)
    })
    changedata(val1, val2)
}

function changedata(sel1, sel2) {
    // 獲取當前日期
    var getdate = new Date();
    var tseconds = getdate.getTime();

    var timearr = [];
    var dataarr = [];
    for (var i = 0; i < sel2; i++) {
        timearr.push(gettimestr(tseconds - sel1 * i))
        dataarr.push(Math.ceil(Math.random() * 10))
    }

    drawchart(timearr, dataarr)
}
相關文章
相關標籤/搜索