使用jq来初始化echarts

echarts如何使用请参考http://echarts.baidu.com/examples/

jq版本:1.8.3

echarts版本:3.5.2

下面给出一份演示 

如果要看效果应该引入对应的库文件


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
 <!--引入jq-->
 <script src="jquery.min.js"></script>
 <!--引入echarts-->
 <script src="echarts.js"></script>
</head>
<body>
<div style="width: 500px;height: 500px" id="demo">
 
</div>
<div style="width: 500px;height: 500px" class="demo">
 
</div>
<div style="width: 500px;height: 500px" class="demo">
 
</div>
<div style="width: 500px;height: 500px" class="demo">
 
</div>
<script type="text/javascript">
 $.fn.jqEcharts=function(Obj){
        var defaultObj={
            option:null
 };
 $.extend(defaultObj,Obj);
 var arr= new Array();
 var O =null;
 
 if(this.length==0){
            return console.log("jq is not find element");
 }
        $.each(this,function(){
            O = echarts.init(this);
 O.setOption(defaultObj.option);
 O.ele=this;
 arr.push(O);
 });
 return arr;
 };
 /*初始化单个*/ //单个返回的是一个echarts的对象
 $("#demo").jqEcharts({
        option:  {
            title: {
                text: 'ECharts 入门示例'
 },
 tooltip: {},
 legend: {
                data:['销量']
            },
 xAxis: {
                data: ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"]
            },
 yAxis: {},
 series: [{
                name: '销量',
 type: 'bar',
 data: [5, 20, 36, 10, 10, 20]
            }]
        }
    });
 /*初始化多个*/ //多个返回的是一个echarts的数组
 $(".demo").jqEcharts({
        option:  {
            title: {
                text: '堆叠区域图'
 },
 tooltip : {
                trigger: 'axis',
 axisPointer: {
                    type: 'cross',
 label: {
                        backgroundColor: '#6a7985'
 }
                }
            },
 legend: {
                data:['邮件营销','联盟广告','视频广告','直接访问','搜索引擎']
            },
 toolbox: {
                feature: {
                    saveAsImage: {}
                }
            },
 grid: {
                left: '3%',
 right: '4%',
 bottom: '3%',
 containLabel: true
 },
 xAxis : [
                {
                    type : 'category',
 boundaryGap : false,
 data : ['周一','周二','周三','周四','周五','周六','周日']
                }
            ],
 yAxis : [
                {
                    type : 'value'
 }
            ],
 series : [
                {
                    name:'邮件营销',
 type:'line',
 stack: '总量',
 areaStyle: {normal: {}},
 data:[120, 132, 101, 134, 90, 230, 210]
                },
 {
                    name:'联盟广告',
 type:'line',
 stack: '总量',
 areaStyle: {normal: {}},
 data:[220, 182, 191, 234, 290, 330, 310]
                },
 {
                    name:'视频广告',
 type:'line',
 stack: '总量',
 areaStyle: {normal: {}},
 data:[150, 232, 201, 154, 190, 330, 410]
                },
 {
                    name:'直接访问',
 type:'line',
 stack: '总量',
 areaStyle: {normal: {}},
 data:[320, 332, 301, 334, 390, 330, 320]
                },
 {
                    name:'搜索引擎',
 type:'line',
 stack: '总量',
 label: {
                        normal: {
                            show: true,
 position: 'top'
 }
                    },
 areaStyle: {normal: {}},
 data:[820, 932, 901, 934, 1290, 1330, 1320]
                }
            ]
        }
    });
 /*如果想要让初始化的多个节点的echarts内容不一样应该用返回的数组去修改*/
    /*所有返回对象 或者 对象数组中的对象都新增了一个属性叫ele 表示jq选择到的节点是原生js的dom对象*/
</script>
</body>
</html>

其实echarts采用的节点对象是jq伪数组的元素我们只需要循环节点就可以初始化echarts了

猜你喜欢

转载自blog.csdn.net/baidu_38766085/article/details/79843911
今日推荐