使用Bootstrap与ShieldUI创建销售业绩仪表板

2015 年 1 月 26 日

今天,让我们来创建一个基于Bootstrap框架的仪表板(dashboard)应用程序。

Bootstrap是一套非常流行的前端框架,它旨在帮助开发者解决开发过程中的一些主要问题,例如元素的定位、应用的响应式能力以及在多种设备上进行输出。这个仪表板应用程序的元素包括一系列的可视化图形,它们各自代表了各种关键性能指标,例如预算、访问量及其它一些关键指标。

如果你想要实现的应用不仅仅能够简单地表现数据,还能以一种具有竞争力及优秀的表现形式进行呈现,则需要通过以下两个步骤进行实现。

首先,我们需要以小部件(widget)的形式呈现所有底层的数据,并提供一种额外的交互层次,例如提示(tooktip)、选项(selection)及鼠标放置(hover)效果。某些数据还可以使用经过编码的 QR 码形式进行呈现,它所适用的场合包括:展现一个很长的超链接,或是对某个特定的条目需要显示额外的细节信息。

可以使用 ShieldUI 这套 web 开发框架实现这一任务,这套框架提供了我们所需的各种小部件。我们将使用这套框架中的 jQuery 小部件,例如图表(chart)、网格(grid)、QR 码以及评分部件,这些部件提供了非常优秀的客户端性能以及影响式的能力。

其次,我们需要确保将仪表板中的所有元素都呈现在页面中相互分离的各个区域。不仅如此,我们还需要确保所有这些区域在定位上都是相连的,并且在任何设备上都能够良好地进行呈现。一般来说,实现这个任务是非常复杂的。但幸运的是,Bootstrap框架能够大大地简化这一任务,只需正确地使用某些 CSS 类便可实现了。

你可以在这里找到该示例的完整代码下载。完成的应用程序界面请见下图:

(单击图片以放大)

应用程序结构

一个完整的仪表板或许会包括无数种小部件与页面布局的组合,我在这里选择的是最常见的组合。从布局的角度来说,该应用的页面共分为五个响应式的面板,这些面板的定位是由Bootstrap 的布局系统所决定的。在较小的屏幕尺寸上,每个区域都会充分占据所有可用的空间。

该应用中所用到的小部件包括jQuery QR 码、jQuery 评分控件、两种不同布局的图形控件、一个jQuery 图表插件,一个环形的进度条,以及一个网格控件。在开发的角度上,我创建了一个简单的html 文件,将所有必需的代码都放在该文件中。

必需的资源文件

该应用程序的** head区域引用了所需的全部资源文件,包括Bootstrap的 CDN 资源,它会负责加载所有必需的 CSS 类,以及 jQuery 和 ShieldUI 的脚本文件引用。Head 区域的最后是一段JSON** 文件的引用,它包含了网格组件所需的原始数据。

以下是完整的 **head** 区域的内容:

复制代码
<head>
<title>Bootstrap Dashboard</title>
<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href=" />
<link rel="stylesheet" type="text/css" href=" />
<link rel="stylesheet" type="text/css" href=" />
<script type="text/javascript" src="></script>
<script type="text/javascript" src="></script>
<script src="gridData.js"></script>
</head>

当所有的资源文件都准备好之后,我们就可以着手打造该页面了。我会依次讲解该页面中所有面板的功能。

用户个人信息

该区域将使用一个标准的 Bootstrap 面板以呈现基本的用户信息细节:包括用户 / 雇员名称、所属部门以及职位。在该面板的注脚部分包含了一个 QR 码,其中包含了额外的用户信息,也可对它进行扩展,以经过编码的 URL 形式表示完整的用户信息或其它相关数据的对应页面。

这块区域是由以下代码所生成的:

复制代码
<div class="col-sm-6 col-lg-3">
<div class="panel panel-primary">
<div class="panel-heading">
<h4 class="text-center">User Profile<span class="glyphicon glyphicon-user
pull-right"></span></h4>
</div>
<div class="panel-body text-center">
<p class="lead">
<strong>Mike Smith</strong>
</p>
</div>
<ul class="list-group list-group-flush">
<li class="list-group-item liitem"><strong>Position:</strong>
<span class="pull-right">Developer</span>
</li>
<li class="list-group-item liitem"><strong>Company:</strong>
<span class="pull-right">EasyTech</span>
</li>
<li class="list-group-item liitem"><strong>Department:</strong>
<span class="pull-right">Dataviz</span>
</li>
<li class="list-group-item liitem"><strong>Project Duration:</strong>
<span class="pull-right">12 months</span>
</li>
</ul>
<div class="panel-footer">
<div class="row">
<div class="col-xs-4 col-sm-3 col-md-4 col-lg-2">
</div>
<div class="col-xs-2 col-sm-4 col-md-4 col-lg-4" id="qr1">
</div>
<div class="col-xs-6 col-sm-5 col-md-4 col-lg-6">
</div>
</div>
</div>
</div>
</div>

这个面板的注脚部分包含了一个 id 为“qr1”的 div,在页面进行加载时,QR 码会在该 div 中进行初始化。其它所有 html 元素都应用了标准的 Bootstrap 类,这些类会负责处理与定位和响应式编码,这就为开发者解决了大量的问题与开发过程中可能遇到的挑战。

用户细节

页面中的这部分内容与前文所述的用户信息非常相似,但它所列举的是用户的个人技能信息。每一项个人技能的右方是一个评分组件,描述了每一项内容的个人专业程度。将鼠标移至该评分元素上,并单击选择,就可以对每一项评分的值进行变更。

与第一个面板相同,注脚部分同样包含了一个 QR 码,包含了经过编码的额外信息,例如某个独立的页面或 Url。

这一区域是由以下代码所创建的:

复制代码
<div class="panel panel-primary">
<div class="panel-heading">
<h4 class="text-center">Skills<span class="glyphicon glyphicon-saved
pull-right"></span></h4>
</div>
<div class="panel-body text-center">
<p class="lead">
<strong>Technology Overview</strong>
</p>
</div>
<ul class="list-group list-group-flush">
<li class="list-group-item liitem">
<div class="skillLineDefault">
<div class="skill pull-left text-center">HTML5</div>
<div class="rating" id="rate1"></div>
</div>
</li>
<li class="list-group-item liitem">
<div class="skillLineDefault">
<div class="skill pull-left text-center">CSS</div>
<div class="rating" id="rate2"></div>
</div>
</li>
<li class="list-group-item liitem">
<div class="skillLineDefault">
<div class="skill pull-left text-center">jQuery</div>
<div class="rating" id="rate3"></div>
</div>
</li>
<li class="list-group-item liitem">
<div class="skillLineDefault">
<div class="skill pull-left text-center">C#</div>
<div class="rating" id="rate4"></div>
</div>
</li>
</ul>
<div class="panel-footer">
<div class="row">
<div class="col-xs-4 col-sm-3 col-md-4 col-lg-2">
</div>
<div class="col-xs-2 col-sm-4 col-md-4 col-lg-4" id="qr2">
</div>
<div class="col-xs-6 col-sm-5 col-md-4 col-lg-6">
</div>
</div>
</div>
</div>

包括 QR 码与评分控件在内的所有小部件元素,都是由一个包含了唯一的 ID 的简单的 div 元素进行展现的。页面在运行时会通过该 ID 创建一个相应的小部件。

季度业绩区域

仪表板中的这一区域将通过一个 jQuery 图表插件展现该季度的数据。这段示例中包括了两个序列的数据,可用以绘制个人、员工或公司数据。可以对序列的数量进行调整,以适应对更多数据展现的需要。不过应尽可能将序列的数量控制在最小范围内,以确保良好的阅读体验。

这一区域是由以下代码所创建的:

复制代码
<div class="col-sm-12 col-md-12 col-lg-6">
<div class="panel panel-primary" style="height: 491px;">
<div class="panel-heading">
<h4 class="text-center">Quarterly Performance<span
class="glyphicon glyphicon-screenshot pull-right"></span></h4>
</div>
<div id="chart1">
</div>
</div>
</div>

这个面板中仅包含了两个区域的内容,因此对应的 html 代码也十分简单易懂。图表小部件在运行时加载数据,它的整体结构是由以下 JavaScript 代码专用所定义的:

复制代码
function initializeChart1() {
var data1 = getRandomArray(20, 1, 50);
var data2 = getRandomArray(20, 20, 70);
$("#chart1").shieldChart({
theme: "light",
exportOptions: {
image: false,
print: false
},
primaryHeader: {
text: "Performance Data"
},
tooltipSettings: {
axisMarkers: {
enabled: true,
mode: 'x',
width: 2,
zIndex: 3,
drawColor: "white"
}
},
dataSeries: [
{
seriesType: 'bar',
collectionAlias: 'Achieved',
data: data1
},
{
seriesType: 'line',
collectionAlias: 'Target',
data: data2
}
]
});
}

出于本文的篇幅考虑,这段示例使用的是随机数据,但也可对其进行扩展,从其它任何渠道获取数据。代码中的 **dataSeries** 属性用于描述该图表中所呈现的两种类型的序列,即线状图与饼图。

整体业绩区域

该区域也是一个包含了可视化数据的面板,其中使用了一个进度条控件,可表现业绩数据,或是某个任务或目标的完成进度百分比。它为用户提供了一种查看某个目标能否及时完成的快速的可视化参考。

通过对这段代码进行简单的扩展,可以使用不同的颜色集,例如以绿色表示目标达成,或是以红色表示进度落后。

全公司业绩区域

这个区域的代码相比其它几个区域有所增加,因此可以参考本文所附带的示例,以获取完整的内容。从结构的角度来说,该面板区域共包含了三个子区域。

  • 文本子区域可以让用户快速地了解该面板对应了哪种可视化的数据,在本例中它表示的是预算的趋势。
  • 第二个子区域中包含了三个图表及简单的布局,即以数据曲线所表现的趋势数据。
  • 最后一个子区域中是一个高度可见的文本区域,它直接反应了每一行所对应的数值。

完整的公司数据区域

该区域包含了一个标准的网格表,以多个行的形式表现数据。可以在该网格中展现公司数据,或用以展现某个公司的全体员工列表。该组件内置了对排序及分页的支持。

(单击图片以放大)

该区域所对应的 html 部分代码如下所示:

复制代码
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<div class="panel panel-primary" style="height: 472px; min-width: 597px;">
<div class="panel-heading">
<h4 class="text-center">Full Company Data<span class="glyphicon
glyphicon-eye-open pull-right"></span></h4>
</div>
<div id="grid1" style="max-height: 393px;">
</div>
</div>
</div>
</div>

这段代码包含了面板的声明,包括 header 与 body。除此之外,其中还包含了一个 id 为“grid1”的 div,它将在运行时呈现整个表格的布局。

初始化小部件

每个小部件都与一个 JavaScript 函数所对应,后者会负责进行初始化工作。举例来说,前文中所提到的网格小部件是由以下函数进行初始化的:

复制代码
function initializeGrid1() {
$("#grid1").shieldGrid({
dataSource: {
data: gridData
},
sorting: {
multiple: false
},
paging: {
pageSize: 8,
pageLinksCount: 10
},
selection: {
type: "row",
multiple: true,
toggle: false
},
columns: [
{ field: "id", title: "ID" },
{ field: "name", title: "Person Name" },
{ field: "company", title: "Company Name" },
{ field: "email", title: "Email Address" }
]
});
}

为了本文的简洁性,我没有列举出完整的代码,但逻辑是相同的:即每个这样的函数都将对一个独立的小部件进行初始化,而每个小部件会进一步进行可视化与交互的相关操作。

至此,页面的装配工作以及大部分的元素已准备就绪。欢迎读者下载示例的代码,在本机进行尝试,或进一步探索每个区域、元素或小部件的功能。

关于作者

David Johnson来自于英国伦敦,他是一位 37 岁的开发者。过去的 15 年间,他主要工作于 web 技术的领域,而近 10 年间,他主要专注于 ASP.NET 和 MVC 平台。David 作为一名外包开发者参与过许多项目,最近的职位是在 ShieldUI 担任首席开发者。

查看英文原文: Article: Creating a Sales Dashboard with Bootstrap and ShieldUI

2015 年 1 月 26 日 22:565479
用户头像

发布了 428 篇内容, 共 148.0 次阅读, 收获喜欢 20 次。

关注

评论

发布
暂无评论
发现更多内容

ViewportFrame demo

katichar

Week 5命题作业

balsamspear

极客大学架构师训练营

性能测试,简单的压测工具

garlic

极客大学架构师训练营

Flink 1.11 与 Hive 批流一体数仓实践

Apache Flink

flink 流计算 实时计算

互联网审判中区块链存证技术的应用进路

CECBC区块链专委会

互联网 电子存证

Android 一行代码接入扫码功能 (CameraX + zxing)

Java android kotlin zxing camera

英特尔首批独显笔记本亮相,非凡S3x纵享轻薄新体验

intel001

阿里P8对Thread核心源码讲解

Java架构师迁哥

我去!三面字节竟全败在Redis上,带薪摸鱼刷1949页进阶笔记

996小迁

Java redis 架构 面试 程序人生

Week 5学习总结

balsamspear

极客大学架构师训练营

【Knative系列】一文读懂 Knative Serving扩缩容的原理

Chumper

Serverless knative autoscaler kantive

英特尔进军独显领域,第一批搭载锐炬®Xe MAX独显轻薄本已问世!

intel001

数字货币交易所开发技术,场外币币交易平台搭建app

WX13823153201

数字货币交易所开发

“十三五”收官,区块链赋能能源电力路在何方?

CECBC区块链专委会

区块链 电力 能源

天源迪科受邀出席“第四届央企电商化采购发展高峰论坛"

DT极客

【性能优化】纳尼?内存又溢出了?!是时候总结一波了!!

冰河

性能优化 内存泄露 高并发 高性能 内存溢出

响应式编程简介之:Reactor

程序那些事

响应式编程 reactor Reactive 程序那些事 响应式系统

手动造轮子——为Ocelot集成Nacos注册中心

yi念之间

nacos ASP.NET Core Ocelot

训练营第三周作业

大脸猫

极客大学架构师训练营

诈骗?通证项目方的危局

CECBC区块链专委会

区块链 法律

darknet A版安装

Dreamer

DDIA 读书笔记(5)数据分区方案

莫黎

读书笔记

Dubbo-go Server端开启服务过程

apache/dubbo-go

dubbo dubbo-go dubbogo

搭载设计师级独显英特尔Xe MAX,非凡S3x体验全能创作

intel001

手动造轮子——基于.NetCore的RPC框架DotNetCoreRpc

yi念之间

RPC ASP.NET Core

http请求中get和post方法的区别

测试人生路

HTTP post GET

全球首批搭载英特尔Xe MAX独显惊艳上市,非凡S3x尽显创作魅力

intel001

线上Java程序占用 CPU 过高,请说一下排查方法?

古时的风筝

Java JVM cpu 100%

JVM真香系列:.java文件到.class文件

田维常

JVM

25个小众的Java库

GuoYaxiang

Java 开发工具

蚂蚁金融推迟上市:互联网金融是否要遭遇滑铁卢

石头IT视角

使用Bootstrap与ShieldUI创建销售业绩仪表板-InfoQ