thinkphp使用echarts_Thinkphp 与Echarts-php 使用

这里推荐大家使用composer 依赖管理工具 导入Echarts-php库

{

"name": "hisune/echarts-php",

"version": "1.0.10",

"version_normalized": "1.0.10.0",

"source": {

"type": "git",

"url": "https://github.com/hisune/Echarts-PHP.git",

"reference": "46f3f3b689eb737ab4c0e85e615466234ae78ddd"

},

"dist": {

"type": "zip",

"url": "https://files.phpcomposer.com/files/hisune/Echarts-PHP/46f3f3b689eb737ab4c0e85e615466234ae78ddd.zip",

"reference": "46f3f3b689eb737ab4c0e85e615466234ae78ddd",

"shasum": ""

},

"require": {

"php": ">=5.3.0"

},

"time": "2017-03-31T06:44:15+00:00",

"type": "library",

"installation-source": "dist",

"autoload": {

"psr-4": {

"Hisune\\EchartsPHP\\": "src/"

}

},

"notification-url": "https://packagist.org/downloads/",

"license": [

"MIT"

],

"authors": [

{

"name": "Hisune",

"email": "hi@hisune.com",

"homepage": "http://hisune.com",

"role": "Developer"

}

],

"description": "A php wrapper for echarts javascript libraries",

"homepage": "http://hisune.com",

"keywords": [

"charts",

"echarts",

"javascript",

"php"

]

}

引入Echarts-php库

這里我只用到Echarts和YAxix

require 'vendor/autoload.php';

use Hisune\EchartsPHP\ECharts;

use Hisune\EchartsPHP\Doc\IDE\YAxis;

這里我写了一个通用的图表方法

里面的参数 就不一一介绍大家可以去官网了解

Model总定义Search_General方法

public function Search_General($text,$color,$legend,$Xdata,$axisLabel,$SeriesData,$id){

$echart = new Echarts();

$echart->title=array(

"left"=>'left',

"text"=>$text

);

$echart->color=$color;

$echart->tooltip=array(

"trigger"=>'axis',

"axisPointer"=>array("animation"=>false),

);

$echart->legend=$legend;

$echart->grid=array(

"left"=>'2%',

"right"=>'4%',

"bottom"=>'10%',

"containLabel"=>true

);

$echart->dataZoom=array(

array(

"type"=>'inside',

"start"=>70,

"end"=>100,

"xAxisIndex"=>0

)

);

$echart->xAxis=array(

"type"=>'category',

"boundaryGap"=>false,

"data"=>$Xdata

);

$yAxis = new YAxis();

$yAxis->type="value";

$yAxis->axisLabel = $axisLabel;

$echart->addYAxis($yAxis);

$echart->series=$SeriesData ;

return $echart->render($id);

}

這里主要介绍一下几个参数

return $echart->render($id);

render中的id就是页面div中定义的id

dataZoom区域缩放组件

start数据开始显示的位置

end截至

同样dataZoom也可以同时X Y轴同时区域缩放

这里有列子

$echart->dataZoom=array(

array(

"type"=>'inside',

"start"=>70,

"end"=>100,

"xAxisIndex"=>0

)

);

//

Events-Received-Rate 是我传的id名字

这里注意个一个小地方,legend 总的data值 和servies name是同样的,不然会显示不出来

Controller中调用Echarts 访问Search_General 传参

$times = array('2017-08-14','2017-08-15','2017-08-16','2017-08-17','2017-08-18');

$Events_Received_Rate = array(113,456,34,78,343);

$color1 = array('#E8488B'); //折线图 线颜色

$axisLabel1 = array("formatter"=>'{value}/s'); //单位/s

$legend1 = array(

"data"=>array('Events Received Rate'),

"left"=>20,

'bottom'=>18

); // 控制折线图显示隐藏按钮 left bottom 调动显示位置

$series1=array(

"name"=>"Events Received Rate",

"type"=>"line",

"data"=>$Events_Received_Rate //Y轴数据

);

$Received_Rate = D('Echarts')->Search_General("Events Received Rate(/s)",$color1,$legend1,$times,$axisLabel1,$series1,"Events-Received-Rate");

通过ajax 传到页面显示

$this -> ajaxReturn($Received_Rate );

定义一个div

初始化的访问

$(function() {

querySearch();

});

function querySearch() {

$.ajax({

type : "post",

url : "/index.php/Home/Echarts/index",

dataType:'json',

success : function(data){

$('#Events_Received_Rate').html(data);

}

});

}

edit

edit

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/440540.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

创建文件夹 java_java怎么建文件夹

Java文件类以抽象的方式代表文件名和目录路径名。该类主要用于文件和目录的创建、文件的查找和文件的删除等。File对象代表磁盘中实际存在的文件和目录。下面我们来看一下java中创建文件夹的方法:示例:package com.zz;import java.io.File;import java.i…

【Gym - 101986F】Pizza Delivery(Dijkstra最短路,建图方式,反向建图,Tarjan求桥,图论模板)

题干: 题目大意: 一个有向图,编号1~n的n个点,m条边,规定1为起点,2为终点,问对于每一条边,反转它的方向,最短路会不会发生改变,如果变短了,输出HA…

【CF#505B】Mr. Kitayuta's Colorful Graph (并查集或Floyd或BFS)

题干: Mr. Kitayuta has just bought an undirected graph consisting of n vertices and m edges. The vertices of the graph are numbered from 1 to n. Each edge, namely edge i, has a color ci, connecting vertex ai and bi. Mr. Kitayuta wants you to p…

java data jpa_Spring Data JPA(一)简介

Spring Data JPA介绍可以理解为JPA规范的再次封装抽象,底层还是使用了Hibernate的JPA技术实现,引用JPQL(Java Persistence Query Language)查询语言,属于Spring整个生态体系的一部分。随着Spring Boot和Spring Cloud在市场上的流行&#xff0…

【CodeForces - 438D】The Child and Sequence(线段树区间取模操作)

题干: At the childrens day, the child came to Pickss house, and messed his house up. Picks was angry at him. A lot of important things were lost, in particular the favorite sequence of Picks. Fortunately, Picks remembers how to repair the sequ…

java 自定义xml_6.1 如何在spring中自定义xml标签

dubbo自定义了很多xml标签,例如,那么这些自定义标签是怎么与spring结合起来的呢?我们先看一个简单的例子。一 编写模型类1 packagecom.hulk.testdubbo.model;23 public classHero {4 privateString name;5 private intage;67 publicString ge…

java 模块设计模式_Java9模块化学习笔记二之模块设计模式

模块设计的原则:1、防止出现编译时循环依赖(主要是编译器不支持),但运行时是允许循环依赖的,比如GUI应用2、明确模块的边界几种模块设计:API模块,聚合模块(比如java.base)可选依赖两种方式:1、可选的编译时依赖(类似于maven的provided scope)…

java 手写签名_Android 自定义View手写签名并保存图片

GIF压缩有问题,运行很顺滑!!!1.自定义View——支持设置画笔颜色,画笔宽度,画板颜色,清除画板,检查是否有签名,保存画板图片(复制粘贴可直接使用)/*** Created by YyyyQ o…

【2019第十届蓝桥杯省赛C/C++B组题解】(非官方题解)

A。 数数题。 答案:490 B。 26进制模拟。 答案:BYQ C。 类似fib数列求值,递推一下就好。 答案:4659 D。 注意两个坑点,一个是正整数,所以枚举要从1开始。第二个坑点是互不相同的,为了达到这…

java对象模型 指令_深入理解多线程(二)—— Java的对象模型

上一篇文章中简单介绍过synchronized关键字的方式,其中,同步代码块使用monitorenter和monitorexit两个指令实现,同步方法使用ACC_SYNCHRONIZED标记符实现。后面几篇文章会从JVM源码的角度更加深入,层层剥开synchronized的面纱。在…

java 学生课程成绩_Java课设--学生成绩管理系统一

写在前面这个项目是Java课程的课设,一共花了5天的时间去完成它,在这期间感谢一些博主的帮助,让我了解到了一些新的技术知识,所以打算写这一系列博客来介绍一整个课设项目,也为了帮助之后的人,如有错误&…

java调用cplex案例_【CPLEX教程03】java调用cplex求解一个TSP问题模型

前面我们已经搭建好cplex的java环境了,相信大家已经跃跃欲试,想动手写几个模型了。今天就来拿一个TSP的问题模型来给大家演示一下吧~CPLEX系列教程可以关注我们的公众号哦!获取更多精彩消息!01 TSP寤烘ā关于TSP建模,就…

java 自动启动监听_Spring Boot 启动事件和监听器,太强大了!

大家都知道,在 Spring 框架中事件和监听无处不在,打通了 Spring 框架的任督二脉,事件和监听也是 Spring 框架必学的核心知识之一。一般来说,我们很少会使用到应用程序事件,但我们也不要忘了它们的存在,比如…

java day_Java_Day7(上)

Java learning_Day7(上)内容常用类枚举类型常用类String 类java.lang.String 类代表不可变的字符序列。String 类的常见构造方法:String(String original)创建一个 String 对象为 original 的拷贝。String(char[] value)用一个字符数组创建一个 String 对象。String…

java关键字 valotile_Java内存模型-jsr133规范介绍,java中volatile关键字的含义

最近在看《深入理解Java虚拟机:JVM高级特性与最佳实践》讲到了线程相关的细节知识,里面讲述了关于java内存模型,也就是jsr 133定义的规范。系统的看了jsr 133规范的前面几个章节的内容,觉得受益匪浅。废话不说,简要的介…

Java重载和重写6_深入理解Java中的重写和重载

深入理解Java中的重写和重载重载(Overloading)和重写(Overriding)是Java中两个比较重要的概念。但是对于新手来说也比较容易混淆。本文通过两个简单的例子说明了他们之间的区别。定义重载简单说,就是函数或者方法有同样的名称,但是参数列表不相同的情形&…

python 协程池gevent.pool_进程池\线程池,协程,gevent

目录1. 进程池与线程池2. 协程3. gevent4. 单线程下实现并发的套接字通信首先写一个基于多线程的套接字服务端:from socket import *from threading import Threaddef comunicate(conn):while True: # 通信循环try:data conn.recv(1024)if len(data) 0: breakconn.send(data.…

java poi 3.13_Java 读取Excl文件 (poi-3.13)

最近做项目遇到了读取Excel数据到数据库做数据的初始化。于是找一个。发现(poi-3.13)可以解决问题。可以解析两种格式(xlsx和xls)以下是实现的步骤1.下载poi3.13包,地址(http://poi.apache.org/download.html#POI-3.13)2.学习APi。接下来是还是demo来说明问题吧&…

【CodeChef - CLIQUED 】Bear and Clique Distances(建图,缩点技巧,思维)

题干: 解题报告: 主要就是在于怎么处理那个前K个点:组成一个团。换句话说,缩成一个点。先直接当成每个点多了k条边来处理,T了。想想也是啊,要是K1e5,那就是1e10条边了。。刚开始尝试了半天缩点&…

【HDU - 5649】DZY Loves Sorting(线段树,区间更新区间查询,思维,01缩数变换,线段树分割)

题干: DZY has a sequence a[1..n]a[1..n]. It is a permutation of integers 1∼n1∼n. Now he wants to perform two types of operations: 0lr0lr: Sort a[l..r]a[l..r] in increasing order. 1lr1lr: Sort a[l..r]a[l..r] in decreasing order. After doin…