laravel框架在数据统计绘图的实现
发布时间 - 2018-07-31 00:00:00 点击率:次在这一篇文章中,我给大家分享的内容是关于利用laravel框架来实现一个数据统计图,代码很清晰,有一定的参考价值,希望可以帮助到有需要的朋友。
1. 前端vue
使用vue-highcharts
data() {
return {
options: {
title: {
text: ''
},
xAxis: {
categories: []
},
yAxis: {
title: {
text: ''
},
plotLines: [{
value: 0,
width: 1,
color: '#808080'
}]
},
legend: {
layout: 'horizontal',
align: 'center',
verticalAlign: 'bottom',
borderWidth: 0
},
credits: {
enabled: false // 去掉highcharts商标
},
series: []
}
}
},请求数据处理:
getTimingHistoryAct(time) {
getTimingHistory(time).then(response => {
const curHour = new Date().getHours()
const hoursArr = []
const dayArr = []
const seriesData = []
switch (time) {
case 1:
seriesData.length = 0
for (let i = 0; i <= curHour; i++) {
hoursArr.push(i < 10 ? '0' + i : '' + i)
seriesData[i] = 0
}
this.options.xAxis.categories = hoursArr.map(x => x + ':00')
response.data.forEach(record => {
const index = hoursArr.indexOf(record.hour)
if (index > -1) {
seriesData[index] = record.count
}
})
break
case 7:
seriesData.length = 0
for (let i = 0; i < 7; i++) {
const ymd = new Date(new Date() - 24 * 60 * 60 * 1000 * i).toLocaleString().split(' ')[0]
const ymdarr = ymd.split('/')
if (ymdarr[1] * 1 < 10) {
ymdarr[1] = '0' + ymdarr[1]
}
if (ymdarr[2] * 1 < 10) {
ymdarr[2] = '0' + ymdarr[1]
}
seriesData[i] = 0
dayArr.unshift(ymdarr.join('-'))
}
this.options.xAxis.categories = dayArr.map(x => x.substr(5))
response.data.forEach(record => {
const index = dayArr.indexOf(record.date)
if (index > -1) {
seriesData[index] = r
ecord.count
}
})
break
case 30:
// 同7天
break
}
this.options.series = [{
name: '商品点击',
data: seriesData
}]
})
},2. 后台laravel
mysql测试数据:
1 5440935 1 2018-07-28 19:20:49 2 5440935 1 2018-07-29 15:26:21 3 5440935 1 测试方案1 2018-07-29 15:38:43 ...
public function getTimingHistory($time)
{
switch ($time) {
case '1':
$data = StatsPlanClick::where('created_at','<', Carbon::now())->where('created_at','>', Carbon::today())->select([DB::raw('DATE_FORMAT(created_at,\'%H\') as hour'), DB::raw('COUNT("*") as count')])->groupBy('hour')->get();
break;
case '7':
$data = StatsPlanClick::where('created_at','<', Carbon::now())->where('created_at','>', Carbon::today()->subDays(7))->select([DB::raw('DATE(created_at) as date'), DB::raw('COUNT("*") as count')])->groupBy('date')->get();
break;
case '30':
$data = StatsPlanClick::where('created_at','<', Carbon::now())->where('created_at','>', Carbon::today()->subDays(30))->select([DB::raw('DATE(created_at) as date'), DB::raw('COUNT("*") as count')])->groupBy('date')->get();
break;
default:
# code...
break;
}
return $this->successWithData($data);
}以上就是本篇文章的全部内容了,更多laravel内容请关注laravel框架入门教程。
相关文章推荐 :
实时聊天室:基于Laravel+Pusher+Vue通过事件广播实现
相关课程推荐:
2017年最新的五个Laravel视频教程推荐
# vue.js
# laravel
# 事件
# 在这
# 有一定
# 相关文章
# 我给
# 数据处理
# 来实现
# 可以帮助
# 一篇文章
# 很清晰
# 聊天室
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
香港网站服务器数量如何影响SEO优化效果?
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
如何注册花生壳免费域名并搭建个人网站?
Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用
长沙企业网站制作哪家好,长沙水业集团官方网站?
js代码实现下拉菜单【推荐】
重庆市网站制作公司,重庆招聘网站哪个好?
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
高性能网站服务器部署指南:稳定运行与安全配置优化方案
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
昵图网官网入口 昵图网素材平台官方入口
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
智能起名网站制作软件有哪些,制作logo的软件?
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
深圳网站制作平台,深圳市做网站好的公司有哪些?
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
如何快速搭建支持数据库操作的智能建站平台?
微信h5制作网站有哪些,免费微信H5页面制作工具?
音乐网站服务器如何优化API响应速度?
如何在建站之星网店版论坛获取技术支持?
Android自定义listview布局实现上拉加载下拉刷新功能
香港服务器如何优化才能显著提升网站加载速度?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
如何在万网主机上快速搭建网站?
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析
如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
如何在阿里云域名上完成建站全流程?
网易LOFTER官网链接 老福特网页版登录地址
javascript基本数据类型及类型检测常用方法小结
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
Laravel如何为API编写文档_Laravel API文档生成与维护方法
Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
Laravel怎么判断请求类型_Laravel Request isMethod用法
jQuery中的100个技巧汇总
手机网站制作与建设方案,手机网站如何建设?
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
大连 网站制作,大连天途有线官网?
javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】
Win11怎么设置默认图片查看器_Windows11照片应用关联设置
南京网站制作费用,南京远驱官方网站?
如何打造高效商业网站?建站目的决定转化率
如何在IIS中新建站点并解决端口绑定冲突?
,交易猫的商品怎么发布到网站上去?
如何用虚拟主机快速搭建网站?详细步骤解析


ecord.count
}
})
break
case 30:
// 同7天
break
}
this.options.series = [{
name: '商品点击',
data: seriesData
}]
})
},