漏刻有时数据可视化大屏(16)数据指标KPI和柱图折线图混排

news2024/9/30 22:36:36

在这里插入图片描述

CSS样式表

/*面板*/
.pannel {
    width: 100%;
    margin-top: 30px;
    clear: both;
}

.item_l {
    float: left;
    width: 20%; /*3格=60%*/
    margin: 0;
}

.item_r {
    float: left;
    width: 10%; /*4格=40%*/
    margin: 0;
}

.item_child {
    float: left;
    width: 50%;
}

.item_child_b {
    float: left;
    width: 100%;
}

.item_title {
    font-size: 18px;
    font-weight: bold;
    margin-left: 20px;
}

.item_num {
    margin: 5px 20px;
    font-size: 24px;
    font-weight: bold;
    color: #18a1e9;
}

.item_norm {
    font-size: 14px;
    font-weight: 500;
}

.divider {
    border-right: 1px solid #C5C7CA;
}

HTML布局

<!--KPI指标-->
<div class="pannel">
    <div class="item_l">
        <div class="item_child">
            <p class="item_title">当月委托单</p>
            <p class="item_num" id="zb1">1320</p>
        </div>
        <div class="item_child">
            <p class="item_norm">已完成:320</p>
            <p class="item_norm">未完成:640</p>
            <p class="item_norm">超 时:630</p>
        </div>
    </div>

    <div class="item_l">
        <div class="item_child">
            <p class="item_title">当月样品数</p>
            <p class="item_num" id="zb2">1320</p>
        </div>
        <div class="item_child">
            <p class="item_norm">已完成:320</p>
            <p class="item_norm">未完成:640</p>
            <p class="item_norm">超 时:630</p>
        </div>
    </div>

    <div class="item_l">
        <div class="item_child">
            <p class="item_title">当月检测数</p>
            <p class="item_num" id="zb3">1320</p>
        </div>
        <div class="item_child">
            <p class="item_norm">已完成:320</p>
            <p class="item_norm">未完成:640</p>
            <p class="item_norm">超 时:630</p>
        </div>
    </div>

    <div class="item_r divider">
        <div class="item_child_b">
            <p class="item_title">平均合格率</p>
            <p class="item_num"><label id="zb4"></label>%</p>
        </div>
    </div>
    <div class="item_r">
        <div class="item_child_b">
            <p class="item_title">设备使用</p>
            <p class="item_num"><label id="zb5"></label>小时</p>
        </div>
    </div>

    <div class="item_r">
        <div class="item_child_b">
            <p class="item_title">成本</p>
            <p class="item_num"><label id="zb6"></label>万元</p>
        </div>
    </div>

    <div class="item_r">
        <div class="item_child_b">
            <p class="item_title">利润</p>
            <p class="item_num"><label id="zb7"></label>万元</p>
        </div>
    </div>
</div>

<!--Echarts图表-->
<div class="pannel">
    <div id="echart1" style="width:100%;height: 600px;"></div>
</div>

Echarts图表

/*Echarts图表封装函数*/
function getDetailLine(id) {
    var myChart = echarts.init(document.getElementById(id));
    var option = {
        tooltip: {
            trigger: 'axis',
            axisPointer: {
                type: 'shadow'
            }
        },
        grid: {
            top: '16%',
            right: '3%',
            left: '2%',
            bottom: '5%',
            containLabel: true
        },
        dataZoom: [{
            show: true,
            start: 0,
            end: 40,
            bottom: 0,
            handleSize: '40%',
            backgroundColor: 'rgba(0,0,0,0.1)',
            fillerColor: 'rgba(0,0,0,0.3)'
        }],
        legend: {
            data: ['委托单', '样品数', '检测数', '合格率(单位:%)'],
            left: '10',
            top: '5%'
        },
        xAxis: {
            type: 'category',
            boundaryGap: true,
            axisLabel: {
                show: true,
                textStyle: {color: 'rgba(0,0,0,.6)'}
            },
            axisLine: {lineStyle: {color: 'rgba(0,0,0,0.5)'}},
            data: ['1日', '2日', '3日', '4日', '5日', '6日', '7日', '8日', '9日', '10日', '11日', '12日', '13日', '14日', '15日', '16日', '17日', '18日', '19日', '20日', '21日', '22日', '23日', '24日', '25日', '26日', '27日', '28日', '29日', '30日']
        },
        yAxis: [
            {
                type: "value",
                name: "数量",
                axisLabel: {show: true},
                axisLine: {lineStyle: {color: 'rgba(0,0,0,0.5)'}},
                splitLine: {show: true, lineStyle: {color: 'rgba(0,0,0,.2)'}}
            },
            {
                type: "value",
                name: "百分比",
                axisLabel: {show: true},
                axisLine: {lineStyle: {color: 'rgba(0,0,0,0.5)'}},
                splitLine: {show: false}
            },
        ],
        series: [{
            name: '委托单',
            yAxisIndex: 0,
            type: 'bar',
            barWidth: '15%',
            itemStyle: {
                color: "#18a1e9",
                barBorderRadius: 5,
            },
            data: [18203, 23489, 29034, 104970, 131744, 630230, "", "", 18203, 23489, 29034, 104970, 131744, 630230, 29034, 18203, 23489, 29034, 104970, 131744, 630230, "", "", 18203, 23489, 29034, 104970, 131744, 630230, 29034]
        }, {
            name: '样品数',
            yAxisIndex: 0,
            type: 'bar',
            barWidth: '15%',
            itemStyle: {
                color: "#e2a236",
                barBorderRadius: 5,
            },
            data: [18203, 23489, 29034, 104970, 131744, 630230, "", "", 18203, 23489, 29034, 104970, 131744, 630230, 29034, 18203, 23489, 29034, 104970, 131744, 630230, "", "", 18203, 23489, 29034, 104970, 131744, 630230, 29034]
        }, {
            name: '检测数',
            yAxisIndex: 0,
            type: 'bar',
            barWidth: '15%',
            itemStyle: {
                color: "#60b234",
                barBorderRadius: 5,
            },
            data: [18203, 23489, 29034, 104970, 131744, 630230, "", "", 18203, 23489, 29034, 104970, 131744, 630230, 29034, 18203, 23489, 29034, 104970, 131744, 630230, "", "", 18203, 23489, 29034, 104970, 131744, 630230, 29034]
        }, {
            name: '合格率(单位:%)',
            yAxisIndex: 1,
            symbolSize: 6,
            itemStyle: {
                color: "#53bafc",
            },
            lineStyle: {
                color: "#53bafc",
            },
            data: [12, 23, 30, 43, 59, 63, 70, 12, 23, 12, 23, 30, 43, 59, 63, 70, 12, 23, 12, 23, 30, 43, 59, 63, 70, 12, 23, 70, 12, 23],
            type: 'line',
            smooth: true
        }]
    };

    myChart.setOption(option);
    window.addEventListener("resize", function () {
        myChart.resize();
    });
}

数据指标

  //数据指标;
    rollNum("zb1", 0, "2320", 0);
    rollNum("zb2", 0, "2569", 0);
    rollNum("zb3", 0, "2318", 0);
    rollNum("zb4", 0, "96.8", 1);
    rollNum("zb5", 0, "275", 0);
    rollNum("zb6", 0, "645", 0);
    rollNum("zb7", 0, "320", 0);
    //渲染图表;
    getDetailLine("echart1");

    /*
     *elId = 目标元素的 ID;
     startVal = 开始值;
     endVal = 结束值;
     decimals = 小数位数,默认值是0;
     duration = 动画延迟秒数,默认值是2;
     */
    function rollNum(elId, startVal, endVal, decimalNum) {
        var n = decimalNum || 0;
        var countUp = new CountUp(elId, startVal, endVal, n, 2.5, {
            useEasing: true, // 使用缓和
            useGrouping: true, // 使用分组(是否显示千位分隔符,一般为 true)
            separator: ',',// 分隔器(千位分隔符,默认为',')
            decimal: '.',// 十进制(小数点符号,默认为 '.')
            prefix: '',	            // 字首(数字的前缀,根据需要可设为 $,¥,¥ 等)
            suffix: ''              // 后缀(数字的后缀 ,根据需要可设为 元,个,美元 等)

        });

        if (!countUp.error) {
            countUp.start();
        } else {
            console.error(countUp.error);
        }
    }

@漏刻有时

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

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

相关文章

OLED透明拼接屏,在包头市的市场表现与应用领域

包头&#xff0c;作为内蒙古自治区的重要城市之一&#xff0c;以其丰富的煤炭资源和快速发展的经济而闻名于世。 包头拥有着独特的地理位置和良好的交通条件&#xff0c;吸引了大量的投资和企业进驻&#xff0c;推动了城市的不断发展和现代化建设。 随着科技的不断进步&#…

深度学习基础知识 使用torchsummary、netron、tensorboardX查看模参数结构

深度学习基础知识 使用torchsummary、netron、tensorboardX查看模参数结构 1、直接打印网络参数结构2、采用torchsummary检测、查看模型参数结构3、采用netron检测、查看模型参数结构3、使用tensorboardX 1、直接打印网络参数结构 import torch.nn as nn from torchsummary im…

Linux入门攻坚——2、基础命令学习

Linux就是命令集的操作系统&#xff0c;精通Linux&#xff0c;就要先精通各种命令。 date &#xff1a; date [OPTION] ... [FORMAT] &#xff1a; 显示日期时间&#xff08;系统时钟&#xff09; FORMAT&#xff1a;格式符号 %D&#xff1a;月/日/年…

优思学院|零库存:丰田精益管理的成功之道(CLMP)

在如今竞争激烈的商业世界中&#xff0c;企业需要不断寻求新的方法来提高效率、降低成本&#xff0c;并确保产品的高质量。其中一种成功的策略是实施零库存管理&#xff0c;而日本汽车制造巨头丰田公司就以其独特的零库存策略而闻名全球。优思学院在本文中将会深入探讨什么是零…

Android Studio: unrecognized Attribute name MODULE

错误完整代码&#xff1a; &#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd; (1.8.0_291) &#xfffd;г&#xfffd;&#xfffd;&#xfffd;&#xfffd;쳣&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xff…

C++对象模型(3)-- 类对象所占用的空间

类对象所占用的空间可以用sizeof()函数获取&#xff0c;在C对象模型中&#xff0c;类对象所占用的空间规则如下&#xff1a; (1) 空类占1字节&#xff0c;以使该类对象在内存得以配置一个地址。 (2) 对象所占用的空间由3个因素决定&#xff1a;非静态成员变量、虚函数、字节填…

图形学 -- Rasterization栅格化

参考视频&#xff1a;Lecture 05 Rasterization 1 (Triangles)_哔哩哔哩_bilibili 视锥&#xff1a; 定义一个垂直角度&#xff0c;定义宽高比 投到[-1,1]^3之后要呈现到屏幕上 屏幕 屏幕&#xff08;一个二位数组&#xff09; 屏幕是个典型的光栅成像设备 定义屏幕空间 映…

【每日一练】勾股定理困难版

目录 题目官方给的解题思路源代码附最大公因数辗转相除法更相减损术 所有因数参考文献 题目 给定斜边z的值&#xff0c;求所有直角边x和y的组合数&#xff08;x、y和z都是正整数&#xff09;。 仅有一行输入&#xff0c;即斜边z的值&#xff08;z是正整数&#xff0c;且z<1…

23种经典设计模式:单例模式篇(C++)

前言&#xff1a; 博主将从此篇单例模式开始逐一分享23种经典设计模式&#xff0c;并结合C为大家展示实际应用。内容将持续更新&#xff0c;希望大家持续关注与支持。 什么是单例模式&#xff1f; 单例模式是设计模式的一种&#xff08;属于创建型模式 (Creational Pa…

将本地代码提交到git新仓库

建仓 首先需要新建一个仓库&#xff0c;注意一定要是空仓库&#xff0c;不要选任何初始化 在代码所在目录右击&#xff0c;进入Git Bash Here 初始化git仓库 git init将文件添加进库 git add .进行提交&#xff0c;-m 后面引号中的内容是本次提交内容&#xff0c;自行填写…

STM32F103 最小系统 PCB 设计与原理

这篇文章是来自我学习&#xff1a; ​​​​​​带着你从手册开始画板 STM最小系统板教程系列(一)_哔哩哔哩_bilibili​​​​​​ 这套教程的笔记&#xff0c;同时本文中也参考了其他教程以及我遇到的困惑与自答&#xff0c;最终汇总。 一、单片机最小系统 单片机最小系统是由…

Centos7中安装Jenkins教程

1.必须先配置jdk环境&#xff0c;安装jdk参考 Linux配置jdk 2.先卸载Jenkins # rpm卸载 rpm -e jenkins # 检查是否卸载成功 rpm -ql jenkins # 彻底删除残留文件 find / -iname jenkins | xargs -n 1000 rm -rf 3.安装Jenkins 在 /usr/ 目录下创建 jenkins文件夹 mkdir -p je…

Fastadmin 子级菜单展开合并,分类父级归纳

这里踩过一个坑&#xff0c;fastadmin默认的展开合并预定义处理的变量是pid。 所以建表时父级id需要是pid&#xff1b; 当然不是pid也没关系&#xff0c;这里以cat_id为例&#xff0c;多加一步处理一样能实现。 废话少说上代码&#xff1a; 首先在控制器&#xff0c; 引用…

使用HbuilderX运行uniapp中小程序项目

下载HbuilderX&#xff0c;下载链接&#xff1a; HBuilderX-高效极客技巧 导入相关项目。下载微信开发者工具。使用微信开发者工具打开&#xff1a;注意&#xff1a;如果是第一次使用&#xff0c;需要先配置小程序ide的相关路径&#xff0c;才能运行成功。如下图&#xff0c;需…

国产开源无头CMS,MyCms v4.7 快捷生成接口开发后台

MyCms 是一款基于 Laravel 开发的开源免费的开源多语言商城 CMS 企业建站系统。 MyCms 基于 Apache2.0 开源协议发布&#xff0c;免费且可商业使用&#xff0c;欢迎持续关注我们。技术交流 QQ 群&#xff1a;887522124 加群请备注来源&#xff1a;如gitee、github、官网等 v4…

什么是智能档案柜?如何使用智能档案柜?

智能档案柜是一种具有智能化功能的文件存储设备&#xff0c;它通过应用现代科技&#xff0c;集成了电子锁、自动化控制、智能管理系统技术&#xff0c;具有自动识别、高效存储、安全可靠等特点&#xff0c;提高档案管理的效率和安全性。适用于企业单位、图书馆等需要储存文件资…

(自学)黑客技术方法——网络安全篇

如果你想自学网络安全&#xff0c;首先你必须了解什么是网络安全&#xff01;&#xff0c;什么是黑客&#xff01;&#xff01; 1.无论网络、Web、移动、桌面、云等哪个领域&#xff0c;都有攻与防两面性&#xff0c;例如 Web 安全技术&#xff0c;既有 Web 渗透2.也有 Web 防…

JRebel在IDEA中实现热部署 (JRebel实用版)

JRebel简介&#xff1a; JRebel是与应用程序服务器集成的JVM Java代理&#xff0c;可使用现有的类加载器重新加载类。只有更改的类会重新编译并立即重新加载到正在运行的应用程序中&#xff0c;JRebel特别不依赖任何IDE或开发工具&#xff08;除编译器外&#xff09;。但是&…

Pyside6 QRadioButton

Pyside6 QRadioBox QRadioButton使用QRadioButton分组QRadioButton设置文本代码设置界面设置 QRadioButton禁用和启用代码设置界面设置 QRadioButton设置默认值代码设置界面设置 读取QRadioButton状态QRadioButton样式设计代码设置界面设置 完整程序界面程序主程序 QRadioButto…