components/card.vue:
components/bottomLeftChart/chart.vue:
components/bottomLeftChart/index.vue:
views/bottomLeft.vue:
views/index.vue:
主要参考项目:
vue-big-screen: 🔥一个基于 vue、datav、Echart 框架的大数据可视化(大屏展示)模板,提供数据动态刷新渲染、屏幕适应、内部图表自由替换、Mixins注入等功能,持续更新....
DataV官网:
DataV
chart官网:
实例 | Charts
echarts主题下载:
主题编辑器 - Apache ECharts
好看的echarts图表:
https://www.makeapie.com/explore.html#sort=rank~timeframe=all~author=all
推荐文章:
推荐在线演示项目:
首先在这里(
vue_base: 包含element-ui ,axios,qs
)把vue基础项目下载下来
然后再执行以下安装插件:
cnpm i -S dayjs [email protected] vue-awesome @jiaminghi/data-view
结构目录:
main.js:
import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
Vue.config.productionTip = false
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
Vue.use(ElementUI)
//全局注册axios
import http from '@/api/axios.js'
Vue.prototype.$axios = http
import dataV from '@jiaminghi/data-view';
Vue.use(dataV);
// 按需引入vue-awesome图标
import Icon from 'vue-awesome/components/Icon';
import 'vue-awesome/icons/chart-bar.js';
import 'vue-awesome/icons/chart-area.js';
import 'vue-awesome/icons/chart-pie.js';
import 'vue-awesome/icons/chart-line.js';
import 'vue-awesome/icons/align-left.js';
// 全局注册图标
Vue.component('icon', Icon);
import dayjs from "dayjs"
Vue.prototype.$dayjs = dayjs;
// 适配flex
import '@/common/flexible.js';
//引入echart
import echarts from 'echarts'
Vue.prototype.$echarts = echarts
// 引入全局css
import './assets/scss/style.scss';
new Vue({
router,
store,
render: h => h(App)
}).$mount('#app')
flexible.js:
注意里面的refreshRem()函数,这里是已经修改过了的)
(function(win, lib) {
var doc = win.document;
var docEl = doc.documentElement;
var metaEl = doc.querySelector('meta[name="viewport"]');
var flexibleEl = doc.querySelector('meta[name="flexible"]');
var dpr = 0;
var scale = 0;
var tid;
var flexible = lib.flexible || (lib.flexible = {});
if (metaEl) {
console.warn("将根据已有的meta标签来设置缩放比例");
var match = metaEl
.getAttribute("content")
// eslint-disable-next-line no-useless-escape
.match(/initial\-scale=([\d\.]+)/);
if (match) {
scale = parseFloat(match[1]);
dpr = parseInt(1 / scale);
} else if (flexibleEl) {
var content = flexibleEl.getAttribute("content");
if (content) {
// eslint-disable-next-line no-useless-escape
var initialDpr = content.match(/initial\-dpr=([\d\.]+)/);
// eslint-disable-next-line no-useless-escape
var maximumDpr = content.match(/maximum\-dpr=([\d\.]+)/);
if (initialDpr) {
dpr = parseFloat(initialDpr[1]);
scale = parseFloat((1 / dpr).toFixed(2));
if (maximumDpr) {
dpr = parseFloat(maximumDpr[1]);
scale = parseFloat((1 / dpr).toFixed(2));
if (!dpr && !scale) {
// eslint-disable-next-line no-unused-vars
var isAndroid = win.navigator.appVersion.match(/android/gi);
var isIPhone = win.navigator.appVersion.match(/iphone/gi);
var devicePixelRatio = win.devicePixelRatio;
if (isIPhone) {
// iOS下,对于2和3的屏,用2倍的方案,其余的用1倍方案
if (devicePixelRatio >= 3 && (!dpr || dpr >= 3)) {
dpr = 3;
} else if (devicePixelRatio >= 2 && (!dpr || dpr >= 2)) {
dpr = 2;
} else {
dpr = 1;
} else {
// 其他设备下,仍旧使用1倍的方案
dpr = 1;
scale = 1 / dpr;
docEl.setAttribute("data-dpr", dpr);
if (!metaEl) {
metaEl = doc.createElement("meta");
metaEl.setAttribute("name", "viewport");
metaEl.setAttribute(
"content",
"initial-scale=" +
scale +
", maximum-scale=" +
scale +
", minimum-scale=" +
scale +
", user-scalable=no"
if (docEl.firstElementChild) {
docEl.firstElementChild.appendChild(metaEl);
} else {
var wrap = doc.createElement("div");
wrap.appendChild(metaEl);
doc.write(wrap.innerHTML);
function refreshRem() {
var width = docEl.getBoundingClientRect().width;
// 最小1366px,最大适配2560px
if (width / dpr < 1366) {
width = 1366 * dpr;
} else if (width / dpr > 2560) {
width = 2560 * dpr;
// 设置成24等份,设计稿时1920px的,这样1rem就是80px
var rem = width / 24;
docEl.style.fontSize = rem + "px";
flexible.rem = win.rem = rem;
win.addEventListener(
"resize",
function() {
clearTimeout(tid);
tid = setTimeout(refreshRem, 300);
false
win.addEventListener(
"pageshow",
function(e) {
if (e.persisted) {
clearTimeout(tid);
tid = setTimeout(refreshRem, 300);
false
if (doc.readyState === "complete") {
doc.body.style.fontSize = 12 * dpr + "px";
} else {
doc.addEventListener(
"DOMContentLoaded",
// eslint-disable-next-line no-unused-vars
function(e) {
doc.body.style.fontSize = 12 * dpr + "px";
false
refreshRem();
flexible.dpr = win.dpr = dpr;
flexible.refreshRem = refreshRem;
flexible.rem2px = function(d) {
var val = parseFloat(d) * this.rem;
if (typeof d === "string" && d.match(/rem$/)) {
val += "px";
return val;
flexible.px2rem = function(d) {
var val = parseFloat(d) / this.rem;
if (typeof d === "string" && d.match(/px$/)) {
val += "rem";
return val;
})(window, window["lib"] || (window["lib"] = {}));
_variables.scss:
// 颜色
$colors: ( "primary": #db9e3f, "info-1": #4394e4, "info": #4b67af, "white": #ffffff, "light": #f9f9f9, "grey-1": #999999, "grey": #666666, "dark-1": #5f5f5f, "dark": #222222, "black-1": #171823, "black": #000000, );
// 字体大小
$base-font-size: 0.2rem;
$font-sizes: ( sm: 0.7, md: 0.8, lg: 0.9, xl: 1, xxl: 2, xxxl: 3);
// 宽高
.w-100 {
width: 100%;
.h-100 {
height: 100%;
//flex
.d-flex {
display: flex;
.flex-column {
flex-direction: column;
.flex-wrap {
flex-wrap: wrap;
.flex-nowrap {
flex-wrap: nowrap;
$flex-jc: ( start: flex-start, end: flex-end, center: center, between: space-between, around: space-around, evenly: space-evenly);
$flex-ai: ( start: flex-start, end: flex-end, center: center, stretch: stretch, );
.flex-1 {
flex: 1;
//.mt-1 => margin top
//spacing
$spacing-types: ( m: margin, p: padding, );
$spacing-directions: ( t: top, r: right, b: bottom, l: left, );
$spacing-base-size: 0.2rem;
$spacing-sizes: ( 0: 0, 1: 0.25, 2: 0.5, 3: 1, 4: 1.5, 5: 3, );
style.scss:
@import "./variables";
// 全局样式
margin: 0;
padding: 0;
list-style-type: none;
box-sizing: border-box;
outline: none;
html {
margin: 0;
padding: 0;
body {
font-family: Arial, Helvetica, sans-serif;
line-height: 1.2em;
background-color: #f1f1f1;
margin: 0;
padding: 0;
color: #343440;
text-decoration: none;
.clearfix {
&::after {
content: "";
display: table;
height: 0;
line-height: 0;
visibility: hidden;
clear: both;
.float-r {
float: right;
.float-l {
float: left;
// 字体加粗
.fw-b {
font-weight: bold;
//icon颜色
.icon-color {
color: #5cd9e8
//文章一行显示,多余省略号显示
.title-item {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
.bg-color-black {
background-color: rgba(19, 25, 47, 0.6);
.bg-color-blue {
background-color: #1a5cd7;
.colorBlack {
color: #272727 !important;
&:hover {
color: #272727 !important;
.colorGrass {
color: #33cea0;
&:hover {
color: #33cea0 !important;
.colorRed {
color: #ff5722;
&:hover {
color: #ff5722 !important;
.colorYellowOrange {
color: #ffc107;
&:hover {
color: #ffc107 !important;
.colorYellowGreen {
color: yellowgreen;
&:hover {
color: yellowgreen !important;
.colorText {
color: #d3d6dd !important;
&:hover {
color: #d3d6dd !important;
.colorBlue {
color: #257dff !important;
&:hover {
color: #257dff !important;
// $colors: ( "primary": #db9e3f, "info-1": #4394e4, "info": #4b67af, "white": #ffffff, "light": #f9f9f9, "grey-1": #999999, "grey": #666666, "dark-1": #5f5f5f, "dark": #222222, "black-1": #171823, "black": #000000, );
@each $colorkey,
$color in $colors {
.text-#{$colorkey} {
color: $color;
.bg-#{$colorkey} {
background-color: $color;
@each $var in (left, center, right) {
.text-#{$var} {
text-align: $var !important;
//flex
@each $key,
$value in $flex-jc {
.jc-#{$key} {
justify-content: $value;
// 效果如下:
// .jc-start{
// justify-content: start;//start: flex-start, end: flex-end, center: center, between: space-between, around: space-around, evenly: space-evenly
@each $key,
$value in $flex-ai {
.ai-#{$key} {
align-items: $value;
// 效果如下:
// .ai-start{
// align-items: start; //start|center|end|stretch
@each $fontkey,
$fontvalue in $font-sizes {
.fs-#{$fontkey} {
font-size: $fontvalue * $base-font-size;
// 效果如下:
// .fs-sm{
// font-size: 0.7*0.2rem; //sm: 0.7, md: 0.8, lg: 0.9, xl: 1, xxl: 2, xxxl: 3
// $spacing-types: (
// m: margin,
// p: padding,
// );
// $spacing-directions: (
// t: top,
// r: right,
// b: bottom,
// l: left,
// );
// $spacing-base-size: 0.2rem;
// $spacing-sizes: (
// 0: 0,
// 1: 0.25,
// 2: 0.5,
// 3: 1,
// 4: 1.5,
// 5: 3,
// );
@each $typekey,
$type in $spacing-types {
//.m-1
@each $sizekey,
$size in $spacing-sizes {
.#{$typekey}-#{$sizekey} {
#{$type}: $size * $spacing-base-size;
//效果如下:
// .m-2{
// margin: 0.5*0.2rem;
//.mx-1
@each $sizekey,
$size in $spacing-sizes {
.#{$typekey}x-#{$sizekey} {
#{$type}-left: $size * $spacing-base-size;
#{$type}-right: $size * $spacing-base-size;
.#{$typekey}y-#{$sizekey} {
#{$type}-top: $size * $spacing-base-size;
#{$type}-bottom: $size * $spacing-base-size;
//效果如下:
// .mx-2{
// margin-left: 0.5*0.2rem;
// margin-right: 0.5*0.2rem;
//.mt-1
@each $directionkey,
$direction in $spacing-directions {
@each $sizekey,
$size in $spacing-sizes {
.#{$typekey}#{$directionkey}-#{$sizekey} {
#{$type}-#{$direction}: $size * $spacing-base-size;
//如下效果:
// .mt-2{
// margin-top:0.5*0.2rem ;
.#{$typekey} {
#{$type}: 0;
//效果如下:
// .m{
// margin: 0;
index.scss:(这个内容就是根据具体项目而来了)
#index {
color: #d3d6dd;
background-color: #000000;
width: 100%;
height: 100%;
.bg {
padding: 0.2rem 0.2rem 0 0.2rem;
background-image: url("../assets/pageBg.png");
background-size: cover;
background-position: center center;
.host-body {
.title {
position: relative;
width: 6.25rem;
text-align: center;
background-size: cover;
background-repeat: no-repeat;
.title-text {
font-size: 0.3rem;
position: relative;
top: 0.4rem;
.title-bototm {
position: relative;
left: 50%;
bottom: -0.575rem;
transform: translate(-50%);
.react-left {
cursor: pointer;
font-size: 0.225rem;
width: 6.25rem;
height: 0.625rem;
line-height: 0.625rem;
text-align: center;
transform: skewX(45deg);
background-color: #0f1325;
.react-before {
position: absolute;
left: -0.3125rem;
top: 0;
height: 0.625rem;
width: 0.625rem;
background-color: #0f1325;
transform: skewX(-45deg);
.text {
display: inline-block;
transform: skewX(-45deg);
.react-right {
cursor: pointer;
font-size: 0.225rem;
width: 6.25rem;
height: 0.625rem;
line-height: 0.625rem;
text-align: center;
transform: skewX(-45deg);
background-color: #0f1325;
.react-after {
position: absolute;
right: -0.3125rem;
top: 0;
height: 0.625rem;
width: 0.625rem;
background-color: #0f1325;
transform: skewX(45deg);
.text {
display: inline-block;
transform: skewX(45deg);
.body-box {
margin-top: 0.2rem;
//下方区域的布局
.content-box {
display: grid;
grid-template-columns: 2fr 3fr 5fr 3fr 2fr;
// 底部数据
.bottom-box {
margin-top: 0.125rem;
display: flex;
common/echart/index.vue:
<template>
<div :id="id" :class="className" :style="{ height: height, width: width }" />
</template>
<script>
import tdTheme from './theme.json' // 引入默认主题
import resizeMixins from "@/utils/resizeMixins";
export default {
name: 'echart',
mixins: [resizeMixins],
props: {
className: {
type: String,
default: 'chart'
id: {
type: String,
default: 'chart'
width: {
type: String,
default: '100%'
height: {
type: String,
default: '2.5rem'
options: {
type: Object,
default: ()=>({})
data () {
return {
chart: null
watch: {
options: {
handler (options) {
// 设置true清空echart缓存
this.chart.setOption(options, true)
deep: true
mounted () {
this.$echarts.registerTheme('tdTheme', tdTheme); // 覆盖默认主题
this.initChart();
methods: {
initChart () {
// 初始化echart
this.chart = this.$echarts.init(this.$el, 'tdTheme')
this.chart.setOption(this.options, true)
</script>
<style>
</style>
utils/resizeMixins.js:
// 混入代码 resize-mixins.js
import { debounce } from '@/utils';
const resizeChartMethod = '$__resizeChartMethod';
export default {
data() {
// 在组件内部将图表 init 的引用映射到 chart 属性上
return {
chart: null,
created() {
window.addEventListener('resize', this[resizeChartMethod], false);
activated() {
// 防止 keep-alive 之后图表变形
if (this.chart) {
this.chart.resize()
beforeDestroy() {
window.removeEventListener('resize', this[resizeChartMethod]);
methods: {
// 防抖函数来控制 resize 的频率
[resizeChartMethod]: debounce(function() {
if (this.chart) {
this.chart.resize();
}, 300)
utils/index.js:
* @param {Function} fn 防抖函数
* @param {Number} delay 延迟时间
export function debounce(fn, delay) {
var timer;
return function() {
var context = this;
var args = arguments;
clearTimeout(timer);
timer = setTimeout(function() {
fn.apply(context, args);
}, delay);
app.vue:
<template>
<div id="app">
<router-view />
</template>
<style lang="scss">
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
</style>
router/index.js:
import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)
const routes = [{
path: '/',
name: 'index',
component: () =>
import ('@/views/index.vue')
const router = new VueRouter({
mode: "history",
routes
export default router
components/card.vue:
<template>
<div class="card">
<div class="background" :style="{height:bgHeight}">
<div class="d-flex pt-2 pl-2">
<span class="icon-color">
<slot name="icon">
<icon name="chart-pie"></icon>
</slot>
</span>
<div class="d-flex">
<span class="fs-md colorText mx-2">{{title}}</span>
<div style="width:1.25rem;height:.25rem; position:relative;top:-.0375rem;">
<slot name="decoration">
<!-- <dv-decoration-1/> -->
</slot>
<slot name="content">
</slot>
</template>
<script>
export default {
data() {
return {};
props:{
title:{
type:String,
default:"title"
bgHeight:{
type: String,
default:"4.8125rem"
components: {
mounted() {},
methods: {}
</script>
<style lang="scss">
.card {
padding: 0.2rem;
height: 5.125rem;
min-width: 3.75rem;
border-radius: 0.0625rem;
.background {
border-radius: 0.125rem;
background-color: rgba(19, 25, 47, 0.6);
</style>
components/bottomLeftChart/chart.vue:
<template>
<Echart
:options="options"
id="bottomLeftChart"
height="6.2rem"
width="100%"
></Echart>
</template>
<script>
import Echart from '@/common/echart'
export default {
data () {
return {
options: {},
components: {
Echart,
props: {
cdata: {
type: Object,
default: () => ({})
watch: {
cdata: {
handler (newData) {
this.options = {
title: {
text: "",
tooltip: {
trigger: "axis",
backgroundColor: "rgba(255,255,255,0.1)",
axisPointer: {
type: "shadow",
label: {
show: true,
backgroundColor: "#7B7DDC"
legend: {
data: ["已贯通", "计划贯通", "贯通率"],
textStyle: {
color: "#B4B4B4"
top: "0%"
grid: {
x: "8%",
width: "88%",
y: "4%"
xAxis: {
data: newData.category,
axisLine: {
lineStyle: {
color: "#B4B4B4"
axisTick: {
show: false
yAxis: [
splitLine: { show: false },
axisLine: {
lineStyle: {
color: "#B4B4B4"
axisLabel: {
formatter: "{value} "
splitLine: { show: false },
axisLine: {
lineStyle: {
color: "#B4B4B4"
axisLabel: {
formatter: "{value} "
series: [
name: "贯通率",
type: "line",
smooth: true,
showAllSymbol: true,
symbol: "emptyCircle",
symbolSize: 8,
yAxisIndex: 1,
itemStyle: {
normal: {
color: "#F02FC2"
data: newData.rateData
name: "已贯通",
type: "bar",
barWidth: 10,
itemStyle: {
normal: {
barBorderRadius: 5,
color: new this.$echarts.graphic.LinearGradient(0, 0, 0, 1, [
{ offset: 0, color: "#956FD4" },
{ offset: 1, color: "#3EACE5" }
data: newData.barData
name: "计划贯通",
type: "bar",
barGap: "-100%",
barWidth: 10,
itemStyle: {
normal: {
barBorderRadius: 5,
color: new this.$echarts.graphic.LinearGradient(0, 0, 0, 1, [
{ offset: 0, color: "rgba(156,107,211,0.8)" },
{ offset: 0.2, color: "rgba(156,107,211,0.5)" },
{ offset: 1, color: "rgba(156,107,211,0.2)" }
z: -12,
data: newData.lineData
immediate: true,
deep: true
</script>
components/bottomLeftChart/index.vue:
<template>
<Chart :cdata="cdata" />
</template>
<script>
import Chart from './chart.vue'
export default {
data () {
return {
cdata: {
category: [
"市区",
"万州",
"江北",
"南岸",
"北碚",
"綦南",
"长寿",
"永川",
"璧山",
"江津",
"城口",
"大足",
"垫江",
"丰都",
"奉节",
"合川",
"江津区",
"开州",
"南川",
"彭水",
"黔江",
"石柱",
"铜梁",
"潼南",
"巫山",
"巫溪",
"武隆",
"秀山",
"酉阳",
"云阳",
"忠县",
"川东",
lineData: [
18092,
20728,
24045,
28348,
32808,
36097,
39867,
44715,
48444,
50415,
56061,
62677,
59521,
67560,
18092,
20728,
24045,
28348,
32808,
36097,
39867,
44715,
48444,
50415,
36097,
39867,
44715,
48444,
50415,
50061,
32677,
49521,
32808
barData: [
4600,
5000,
5500,
6500,
7500,
8500,
9900,
12500,
14000,
21500,
23200,
24450,
25250,
33300,
4600,
5000,
5500,
6500,
7500,
8500,
9900,
22500,
14000,
21500,
8500,
9900,
12500,
14000,
21500,
23200,
24450,
25250,
rateData: []
components: {
Chart,
mounted () {
this.setData();
methods: {
// 根据自己的业务情况修改
setData () {
for (let i = 0; i < this.cdata.barData.length -1; i++) {
let rate = this.cdata.barData[i] / this.cdata.lineData[i];
this.cdata.rateData.push(rate.toFixed(2));
</script>
<style lang="scss" scoped>
</style>
views/bottomLeft.vue:
<template>
<card id="bottomLeft" title="数据统计图" bgHeight="6.0625rem">
<icon name="chart-bar" slot="icon"></icon>
<dv-decoration-1 slot="decoration" />
<div slot="content">
<BottomLeftChart/>
</card>
</template>
<script>
import card from "@/components/card"
import BottomLeftChart from "@/components/bottomLeftChart";
export default {
data() {
return {
components: {
BottomLeftChart,
mounted() {},
methods: {}
</script>
<style lang="scss" scoped>
#bottomLeft {
padding: 0.3rem 0.2rem;
height: 6.5rem;
</style>
views/index.vue:
<template>
<div id="index">
<dv-full-screen-container class="bg">
<dv-loading v-if="loading">Loading...</dv-loading>
<div v-else class="host-body">
<!-- 第一行 标题 -->
<div class="d-flex jc-center">
<dv-decoration-10 style="width:33.3%;height:.0625rem;" />
<div class="d-flex jc-center">
<dv-decoration-8 :color="['#568aea', '#000000']" style="width:2.5rem;height:.625rem;" />
<div class="title">
<div class="title-text">大数据可视化平台</div>
<dv-decoration-6
class="title-bototm"
:reverse="true"
:color="['#50e3c2', '#67a1e5']"
style="width:3.125rem;height:.1rem;"
<dv-decoration-8
:reverse="true"
:color="['#568aea', '#000000']"
style="width:2.5rem;height:.625rem;"
<dv-decoration-10 style="width:33.3%;height:.0625rem; transform: rotateY(180deg);" />
<!-- 第二行 导航栏 -->
<div class="d-flex jc-between px-2">
<div class="d-flex" style="width: 40%;">
<div class="react-left ml-4">
<span class="react-before"></span>
<span class="text">数据分析1</span>
<div class="react-left ml-3">
<span class="text colorBlue">数据分析2</span>
<div style="width: 40%" class="d-flex">
<div class="react-right bg-color-blue mr-3">
<span class="text fw-b">vue-big-screen</span>
<div class="react-right mr-4" >
<span class="react-after"></span>
<span class="text">{{dateYear}} {{dateWeek}} {{dateDay}}</span>
<dv-border-box-13 style="width:10rem">
<bottomLeft />
</dv-border-box-13>
</dv-full-screen-container>
</template>
<script>
import bottomLeft from "./bottomLeft";
export default {
data () {
return {
loading: true,
dateDay: null,
dateYear: null,
dateWeek: null,
weekday: ["周日", "周一", "周二", "周三", "周四", "周五", "周六"],
timer:null
components: {
bottomLeft,
mounted () {
this.timer =setInterval(() => {
const date=this.$dayjs(new Date())
this.dateDay = date.format('HH:mm:ss');
this.dateYear = date.format('YYYY-MM-DD');
this.dateWeek = date.format(this.weekday[date.day()]);
}, 1000)
this.cancelLoading();
methods: {
cancelLoading () {
setTimeout(() => {
this.loading = false;
}, 500);
beforeDestroy(){
if(this.timer){
clearInterval(this.timer)
</script>
<style lang="scss">
@import '../assets/scss/index.scss';
</style>
目录main.js:flexible.js:_variables.scss:style.scss:index.scss:(这个内容就是根据具体项目而来了)common/echart/index.vue:utils/resizeMixins.js:utils/index.js:app.vue:router/index.js:components/card.vue:components/bottomLeftChart/chart.vue:components/
datav模版
内容概要:组件库基于Vue ,主要用于构建大屏(全屏)数据展示页面即数据可视化,具有多种类型组件可供使用,主要包含三个大屏demo案例。
适合人群:具备一定编程基础,组件库的开发和调试都使用Chrome浏览器
能学到什么:
①边框、装饰、图表和其他大屏控件等都是怎么在Vue中体现的;
②基于Vue的dataV 项目demo案例。
阅读建议:此资源提供dataV demo案例,不仅是代码编写实现也更注重内容上的需求分析和方案设计,所以在学习的过程要结合这些内容一起来实践,并调试对应的代码。
在我们使用框架开发项目的时候,会发现各种不同种类的框架可以帮我们提高开发效率,比如我们的element,iview,mint-ui,vant等等,当然,大屏也是有框架的,就是我们要说的dataV.
官网地址:vue入口 react 入口
官方示例:
演示效果:
http://datav.jiaminghi.com/demo/construction-data/index.html
6. 创建一个新的组件用于展示DataV可视化大屏。你可以在`src/components`目录下创建一个新的组件文件,例如`DataVScreen.vue`,然后在该文件中编写DataV可视化大屏的代码。
7. 在需要展示DataV可视化大屏的地方使用该组件。例如,在`App.vue`文件中添加以下代码:
```vue
<template>
<div id="app">
<DataVScreen />
</template>
<script>
import DataVScreen from './components/DataVScreen.vue';
export default {
name: 'App',
components: {
DataVScreen,
</script>
8. 运行项目,可以使用以下命令启动开发服务器:
npm run serve
这样,你就可以使用Vue来实现DataV可视化大屏了。当然,具体的可视化效果和功能需要根据你的需求进行定制和开发。希望对你有所帮助!如果有任何问题,请随时提问。