使用echarts柱状图实现select下拉刷新数据

目录
  • echarts柱状图实现select下拉刷新数据
  • 表格的下拉框中包含echarts图表的demo

echarts柱状图实现select下拉刷新数据

废话少说,直接上代码

    <div>月度
  <select id="year_data">
      <option value="1" class="active">3月</option>
      <option value="2">4月</option>
  </select>
</div>
    <div id="chart_box" style="width: 1250px;height:550px;margin:0 auto;"></div>
<script src="js/bsyd.js"></script>
  <script>
    $(function () {//使用on进行事件绑定事件。
        mychart1('year1');

        $("select").on('click',function(){
            if($("select").val()==1){
            mychart1('year1');
            }
            else if($("select").val()==2){
                // mychart1.clear();
            mychart1('year2');
            }
                })  ;
        $("#time_sec").on('click',function(){
            //alert('请求时间段的数据');

            myChart1.clear();            //清空原来的图表
            mychart1('time_sec');   //重新加载图表,之前必须要清空原来的,否则没有动画效果
        });
    });
  </script>
</body>
</html>

所需js

  // 基于准备好的dom,初始化echarts实例
var myChart1 = echarts.init(document.getElementById('chart_box'));
function mychart1(time){
    if(time=='year1'){
        var renShu = [ 80.00, 79.10, 81.45, 90.20, 89.30, 91.20, 88.30, 91.30, 90.65, 91.20, 90.30, 89.20, 87.30, 91.30, 90.65];
    }else if(time=='year2'){
        var renShu = [ 50.00, 90.00, 61.45, 78, 59.30, 95.00, 88.30, 61.30, 43.00, 51.20, 92.00, 69.20, 78.00, 91.30, 94.00];
    }else{
        //请求时间段数据
        //模拟时间段数据
        alert(time);
        var renShu = [80.00, 79.10, 81.45, 90.20, 89.30, 91.20, 88.30, 91.30, 90.65, 91.20, 90.30, 89.20, 87.30, 91.30, 90.65];
    };
        //配置及数据
        optionyear = {
            title: {
                text : "标室月度使用率",
                padding: [10, 100, 10, 500] , // 标题位置
                subtext : ""
            },
            tooltip: {
                formatter: '{c}%',
                trigger: 'axis',    //提示触发类型      'item':数据项图形触发,主要在散点图,饼图等无类目轴的图表中使用。
                                                //'axis':坐标轴触发,主要在柱状图,折线图等会使用类目轴的图表中使用。
                                                //'none':什么都不触发。
                show:true,     //是否显示提示框组件 默认为true
                axisPointer: {
                    type: 'cross',
                    crossStyle: {
                        color: '#999'
                    }
                }
            },
            legend: {
                data:['']
            },
            xAxis: [
                {
                    type: 'category',
                    data: ["201","202","203","601","602","603","604","605","606","701","702","703","704","705","706"],
                    axisPointer: {
                        type: 'shadow'
                    }
                }
            ],
            yAxis: [
                {
                    type: 'value',
                    name: '',
                    min:0,
                    max:92.00,
                    splitNumber:10,
                    axisLabel: {
                        formatter: '{value}%',
                    }
                },
            ],
            series: [
                {
                    name:'',
                    type:'bar',         //bar表示柱状图
                    barWidth:20,
                    data:renShu,//数据
                    itemStyle: {    //更多柱状图样式搜索API:series-bar.itemStyle
                  normal: {
                        color: '#1E90FF',//改变柱状的颜色
                                       label: {
                                        show: true, //开启显示
                                        position: 'top', //在上方显示
                                        formatter: '{c}%'  ,   //百分比显示
                                        textStyle: { //数值样式
                                            color: 'black',    //柱上数据颜色
                                            fontSize: 16
                                        }
                                    }
                      }
                    },
                },
            ]
        };
        // 使用刚指定的配置项和数据显示图表。
        myChart1.setOption(optionyear);
}

表格的下拉框中包含echarts图表的demo

右图为左图点击后的效果,下拉框中包含一个echarts图表

echarts.min.js和vue.js是分别从官网下载的文件,下载很方便,在此不做赘述。

<!DOCTYPE html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="echarts.min.js"></script>
<script src="vue.js" type="text/javascript" charset="UTF-8"></script>
<style>
*{padding:0;margin:0;}

.img{width:600px;height:320px;background:#000;}
.img1{background:red;}
#box{
	width:805px;
	margin:100px auto;
	overflow:hidden;
	box-shadow:0 0 10px 1px rgba(0,0,0,0.35);
	}
#box ul li{
	float:left;
	list-style:none;
	width:100%;
    height: 50px;
	position:relative;
	-webkit-transition:all .7s;
	-moz-transition:all .7s;
	-ms-transition:all .7s;
	-o-transition:all .7s;
	border-left:1px solid #ccc;
	}
.title{
	color:#fff;
	font-size:20px;
	width:100%;
	background:rgba(0,0,0,0.5);
	position:absolute;
	top:0;
	left:0;

	line-height:50px;
	}
.container{
	width:600px;
	height:270px;
	position:absolute;
	top:50px;
	left:0;
	}
#box .fill{height:600px;}
.iconclick {
    display: inline-block;
}
</style>
</head>
<body>
<div id="box">
 <ul>
  <li v-for="i in count" class="liget lige">
   <a href=""><div class="img1 img"></div></a>
   <div class="title">
	<p class="iconclick">title{{i}}</p>
    <span  class="iconclick" @click="iconclick(i)">点此展开</span>
	<div class="container"></div>
   </div>
  </li>
 </ul>
</div>

<script type="text/javascript">
	// var a=0;
	 var app=new Vue({
            el:"#box",
            data:{
                count:5
            },
			methods:{
				iconclick(i){
					if (document.getElementsByClassName('lige')[i-1].className=='fill lige') {
						document.getElementsByClassName('lige')[i-1].className='liget lige';
					}else{
					document.getElementsByClassName('lige')[i-1].className='fill lige';
				}
				}
			}
        });
		var divs = document.querySelectorAll(".container");
		for (var i=0;i<divs.length;i++){
			myCharts = echarts.init(divs[i]);
			//基于准备好的DOM,初始化echarts实例
			//var myCharts = echarts.init(document.getElementById("container"));
			//console.log(myCharts);
			var option = {
				title:{
					text:"ECharts 数据统计"
				},
				series:[{
					name:"访问量",
					type:"pie",
					radius:"60%",
					data:[
						{value:'500',name:'Android'},
						{value:'200',name:'IOS'},
						{value:'360',name:'PC'},
						{value:'100',name:'Others'}
					]
				}]
			};
			//使用定制的配置项和数据显示图表
			myCharts.setOption(option);
		}

	</script>
</body>
</html>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • vue.js中使用echarts实现数据动态刷新功能

    在vue使用echarts时,可能会遇到这样的问题,就是直接刷新浏览器,或者数据变化时,echarts不更新? 这是因为Echarts是数据驱动的,这意味着只要我们重新设置数据,那么图表就会随之重新渲染,这是实现本需求的基础.我们再设想一下, 如果想要支持数据的自动刷新,必然需要一个监听器能够实时监听到数据的变化然后告知Echarts重新设置数据. 所幸Vue为我们提供了==watcher==功能,通过它我们可以很方便的实现上述功能: watch:{ option:function(newval

  • vue echarts实现柱状图动态展示

    本文实例为大家分享了vue echarts实现柱状图动态展示的具体代码,供大家参考,具体内容如下 轮播图形式展现 <template> <div class="dan"> <div id="scalesize" :style="{width: '100%', height: '100%'}"></div> </div> </template> <script> i

  • vue中使用echarts实现动态数据绑定以及获取后端接口数据

    目录 前言 1.柱状图 2.折线图 3.饼状图 4.地图 总结 前言 之前几篇echarts的文章是实现了静态的柱状图.折线图.饼状图.地图,在项目中我们肯定是需要获取后端接口,将后端返回的数据显示在图表上,所以这次就记录一下如何实现echarts的动态数据绑定. 简单来讲,就是从接口获取到的数据,需要在图表的方法里再次定义一下,然后用setOption方法就可以获取到了. 1.柱状图 首先看接口传过来的数据,传过来一个数组,第一条年度2021,数量1,第二条年度2022,数量3 因为柱状图的数

  • 详解vue使用Echarts画柱状图

    目录 1 引入Echarts 1.1 安装 1.2 引入 2 基本柱状图 3 多列柱状图 4 柱状图样式设置 4.1 柱条样式 4.2 柱条间距 5 动态排序柱状图 6 总结 1 引入Echarts 1.1 安装 使用如下命令通过 npm 安装 ECharts npm install echarts --save 注:本文安装Echarts版本为:“echarts”: “5.2.1” 1.2 引入 安装完成以后,可以将echarts全部引入,这样一来,我们可以在该页面使用echarts所有组件:

  • 使用echarts柱状图实现select下拉刷新数据

    目录 echarts柱状图实现select下拉刷新数据 表格的下拉框中包含echarts图表的demo echarts柱状图实现select下拉刷新数据 废话少说,直接上代码 <div>月度 <select id="year_data"> <option value="1" class="active">3月</option> <option value="2">4月

  • mui上拉加载更多下拉刷新数据的封装过程

    辗转用mui做了两个项目,空下来把mui上拉加载更多,下拉刷新数据做了一个简单的封装,希望可以帮助到需要的朋友 demo项目的结构 直接贴代码了 index.html mui上拉刷新下拉加载都这里了,两个方法搞定 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device

  • angularjs实现上拉加载和下拉刷新数据功能

    虽说AngularJS 1.x版本中对于上拉加载,下拉刷新数据功能都有做些封装,但还是有些人不清楚.其实我一开始也是不懂的,so.现在把搞懂的记录下免得少走弯路. now,begin:先说下拉刷新吧,原理就是每次下拉都重新去服务器请求过一次新的数据.一般这种刷新功能的响应数据(也就是服务器返回的(json)数据)中都会带有 "rowsOfPage": 3, "currentPage": 1, "totalPages": 10, "tot

  • Swift开发之使用UIRefreshControl实现下拉刷新数据及uirefreshcontrol使用

    想要下拉刷新表格数据,上拉加载新数据,网上有许多第三方的实现类. 而如果仅仅需要实现下拉刷新数据的话,那么使用 UIRefreshControl 就足够了,简单有好用. 1.UIRefreshControl 的使用步骤: (1)创建 UIRefreshControl,并设置文字,颜色等信息. (2)将 UIRefreshControl 添加到tableview视图中. (3)给 UIRefreshControl 添加方法,当值改变的时候调用,用于数据请求刷新. (4)请求数据确认完成之后,调用e

  • Android下拉刷新PtrFrameLayout的使用实例代码

    1.介绍: 可以包含所有的控件 :ListView, GridView, ScrollView, FrameLayout, 甚至 TextView. 可以自定义刷新头(这点非常实用) 使用简单方便 不足就是不支持上拉加载. 2.使用 首先添加依赖到项目 compile 'in.srain.cube:ultra-ptr:1.0.11' 在Xml中使用 <in.srain.cube.views.ptr.PtrFrameLayout xmlns:android="http://schemas.a

  • APP中javascript+css3实现下拉刷新效果

    原生app里的数据列表都会使用下拉刷新的效果,在webapp里可以采用iscroll.swiper等插件或框架实现,那么如何自己编码实现类似的效果呢,下面介绍使用原生js+css3实现的简单效果. html布局 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-

  • 微信小程序 scroll-view实现上拉加载与下拉刷新的实例

    微信小程序 scroll-view实现上拉加载与下拉刷新的实例 实现效果图: 如图,使用小程序的scroll-view实现的上拉加载数据,下拉刷新数据,试下代码如下: js文件代码: var url = "http://192.168.30.4:8080/gtxcx/carrier/getCarrier.action"; var page = 1; var GetList = function (that) { that.setData({ hidden: false }); wx.r

  • Android使用PullToRefresh完成ListView下拉刷新和左滑删除功能

    ListView下刷新刷功能相信从事Android开发的猿友们并不陌生,包括现在Google亲儿子SwipeRefreshLayout实现效果在一些APP上也能看见(不过个人不喜欢官方的刷新效果).本文就带领一些刚入门android的朋友或者一起爱分享的朋友来简单的实现ListView的下拉刷新和左滑删除效果. 一.本文主要内容: 使用PullToRefresh完成ListView下拉.上拉刷新: 扩展PullToRefresh完美的实现ListView左滑删除效果: 注意:本文中的PullTo

  • 微信小程序下拉刷新PullDownRefresh的使用方法

    前言 下拉刷新和上拉加载是业务上一个很常见的需求,在微信小程序里,提供了下拉刷新的方法 onPullDownRefresh .虽然微信的官方文档有很多坑,但下拉刷新介绍的还是很全面的. 微信小程序--下拉刷新.jpg 最近开发一款微信小程序,里面有用到下拉刷新数据的功能.于是,又开始折腾了... 一.onPullDownRefresh回调 初略看了下文档,发现小程序js中有onPullDownRefresh回调,果断重写之... // http://itlao5.com onPullDownRe

  • MUI实现上拉加载和下拉刷新效果

    本文实例为大家分享了MUI实现上拉加载和下拉刷新展示的具体代码,供大家参考,具体内容如下 编写存储过程分页(此处使用T-SQL) CREATE PROC [dbo].[Common_PageList] ( @tab nvarchar(max),---表名 @strFld nvarchar(max), --字段字符串 @strWhere varchar(max), --where条件 @PageIndex int, --页码 @PageSize int, --每页容纳的记录数 @Sort VARC

随机推荐