Electron + Vue跨平台应用(十一)可视化(二)

Electron + Vue + Vscode构建跨平台应用(一)知识点补充
Electron + Vue + Vscode构建跨平台应用(二)Electron + Vue环境搭建
Electron + Vue + Vscode构建跨平台应用(三)利用webpack搭建vue项目
Electron + Vue + Vscode构建跨平台应用(四)利用Electron-Vue构建Vue应用详解
Electron + Vue + Vscode构建跨平台应用(五)Electron-Vue项目源码分析
Electron + Vue跨平台应用(六)效果还不错的登录页面
Electron + Vue跨平台应用(七)基础技法(一)
Electron + Vue跨平台应用(八)基础技法(二)
Electron + Vue跨平台应用(八)基础技法(三)
Electron + Vue跨平台应用(九)基础技法(四)
Electron + Vue跨平台应用(十)可视化(一)

1. Echarts的基本用法

  1.1.1 安装使用

2. Echarts 关系图

  2.1 关系图如何固定某些节点的位置

  2.2 优化关系图节点过多加载过慢


Echarts官网

1. Echarts的基本用法

  1.1.1 安装使用

  • 在main.js文件中全局引入
import echarts from 'echarts'
Vue.prototype.$echarts = echarts
  • 在vue页面中引入div,并完成Echarts的初始化
<div id="myChart" :style="{width: '600px', height: '400px'}"></div>
    initEcharts () {
      this.echart = this.$echarts.init(document.getElementById('myChart'))
    },
  • 最后一步就是填充Echarts数据,完整代码如下
<template>
  <div class="main">
    <div id="myChart" :style="{width: '600px', height: '400px'}"></div>
  </div>
</template>

<script>
export default {
  name: 'EchartsActivity',
  data () {
    return {
      echart: null,
      option: {},
      graphData: [{
        name: '节点1',
        id: 1
      }, {
        name: '节点2',
        id: 2
      }, {
        name: '节点3',
        id: 3
      }, {
        name: '节点4',
        id: 4
      }, {
        name: '节点5',
        id: 5
      }, {
        name: '节点6',
        id: 6
      }],
      graphLinks: [{
        source: '1',
        target: '2'
      }, {
        source: '2',
        target: '3'
      }, {
        source: '2',
        target: '4'
      }, {
        source: '3',
        target: '5'
      }, {
        source: '4',
        target: '6'
      }]
    }
  },
  mounted () {
    this.initEcharts()
    this.setOption()
    this.reFreshEcharts()
  },
  methods: {
    initEcharts () {
      this.echart = this.$echarts.init(document.getElementById('myChart'))
    },
    setOption () {
      let graphOption = {
        title: {
          text: '关系图示例'
        },
        tooltip: {},
        series: [
          {
            type: 'graph',
            layout: 'force',
            data: this.graphData,
            links: this.graphLinks,
            force: {
              repulsion: 500
            },
            lineStyle: {
              opacity: 0.9,
              width: 2,
              curveness: 0
            }
          }
        ]
      }
      this.option = graphOption
    },
    reFreshEcharts () {
      this.$nextTick(() => {
        this.echart.setOption(this.option)
      })
    }
  }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
</style>

显示效果如下
在这里插入图片描述

2. Echarts 关系图

  2.1 关系图如何固定某些节点的位置

  在Echarts中,关系图的节点可以携带坐标,也可以不携带坐标;在上面的示例中,我们的节点就是没有固定坐标的。

  那没有固定坐标的关系图的节点位置是如何确定的? 其实他是根据力导图算法动态分布的。

  那如果我们需要 固定某些节点要如何处理尼?

通过查看Echarts配置项可知,关系图的data数据有如下部分属性
在这里插入图片描述
所以我们只要通过设置data的数据fixed属性为true,并且设置对应x和y的坐标即可固定节点位置,完整代码如下

<template>
  <div class="main">
    <div id="myChart" :style="{width: '600px', height: '400px'}"></div>
    <button>关系图</button>
    <button>仪表盘</button>
  </div>
</template>

<script>
export default {
  name: 'EchartsActivity',
  data () {
    return {
      echart: null,
      option: {},
      graphData: [{
        name: '节点1',
        id: 1,
        fixed: true,
        x: 100,
        y: 50
      }, {
        name: '节点2',
        id: 2,
        fixed: true,
        x: 180,
        y: 50
      }, {
        name: '节点3',
        id: 3
      }],
      graphLinks: [{
        source: '1',
        target: '2'
      }, {
        source: '2',
        target: '3'
      }]
    }
  },
  mounted () {
    this.initEcharts()
    this.setOption()
    this.reFreshEcharts()
  },
  methods: {
    initEcharts () {
      this.echart = this.$echarts.init(document.getElementById('myChart'))
    },
    setOption () {
      let graphOption = {
        title: {
          text: '关系图示例'
        },
        tooltip: {},
        series: [
          {
            type: 'graph',
            layout: 'force',
            data: this.graphData,
            links: this.graphLinks,
            force: {
              repulsion: 500
            },
            lineStyle: {
              opacity: 0.9,
              width: 2,
              curveness: 0
            }
          }
        ]
      }
      this.option = graphOption
    },
    reFreshEcharts () {
      this.$nextTick(() => {
        this.echart.setOption(this.option)
      })
    }
  }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
</style>

显示效果如下:
在这里插入图片描述
通过上面你的属性设置就完成了关系图固定节点的功能,同时我们也可以知道关系图中坐标系的(0,0)点屏幕左上角

  2.2 优化关系图节点过多加载过慢

  当关系图中的力导图如果节点过多,在绘制的时候性能比较慢,那我们要如何加快这种渲染速度?

   通过上面的代码我们发现,series对象里面的data是组成关系图的重要数据,而series是一个数组对象,所以为了优化过多节点的渲染速度,我们可以为series就像分片数据一样设置多个数据,完整代码如下

<template>
  <div class="main">
    <div id="myChart" :style="{width: '600px', height: '400px'}"></div>
    <button>关系图</button>
    <button>仪表盘</button>
  </div>
</template>

<script>
export default {
  name: 'EchartsActivity',
  data () {
    return {
      echart: null,
      option: {},
      graphData: [{
        name: '节点1',
        id: 1
      }, {
        name: '节点2',
        id: 2
      }, {
        name: '节点3',
        id: 3
      }],
      graphLinks: [{
        source: '1',
        target: '2'
      }, {
        source: '2',
        target: '3'
      }]
    }
  },
  mounted () {
    this.initEcharts()
    this.setOption()
    this.reFreshEcharts()
  },
  methods: {
    initEcharts () {
      this.echart = this.$echarts.init(document.getElementById('myChart'))
    },
    setOption () {
      let graphOption = {
        title: {
          text: '关系图示例'
        },
        tooltip: {},
        series: [
          {
            type: 'graph',
            layout: 'force',
            data: this.graphData,
            links: this.graphLinks,
            force: {
              repulsion: 500
            },
            lineStyle: {
              opacity: 0.9,
              width: 2,
              curveness: 0
            }
          }, {
            type: 'graph',
            layout: 'force',
            data: this.graphData,
            links: this.graphLinks,
            force: {
              repulsion: 500
            },
            lineStyle: {
              opacity: 0.9,
              width: 2,
              curveness: 0
            }
          }, {
            type: 'graph',
            layout: 'force',
            data: this.graphData,
            links: this.graphLinks,
            force: {
              repulsion: 500
            },
            lineStyle: {
              opacity: 0.9,
              width: 2,
              curveness: 0
            }
          }
        ]
      }
      this.option = graphOption
    },
    reFreshEcharts () {
      this.$nextTick(() => {
        this.echart.setOption(this.option)
      })
    }
  }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
</style>

显示效果如下
在这里插入图片描述
补充说明一个在使用关系图常见的异常

Cannot set property 'dataIndex' of undefined

出现这个异常的原因是在你的关系图中出现了重复数据,一般是指id重复

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Electron是一个基于Chromium和Node.js的框架,可以帮助开发者使用Web技术(HTML,CSS,JavaScript)来构建跨平台桌面应用程序。VueCli是一个基于Vue.js的命令行工具,可以帮助开发者快速构建Vue.js项目。使用Electron7+VueCli4开发跨平台桌面应用的过程如下: 1. 安装Node.js和npm 在安装ElectronVueCli之前,需要先安装Node.js和npm。Node.js是一个基于Chrome V8引擎的JavaScript运行环境,npm是Node.js的包管理器。安装Node.js和npm可以让你在本地开发环境中运行和管理ElectronVueCli。 2. 安装Electron 在安装Electron之前,需要先创建一个空目录作为项目根目录,然后在命令行中切换到该目录下,执行以下命令: ``` npm init -y npm install electron --save-dev ``` 以上命令会创建一个package.json文件,并将Electron安装到本地项目中。 3. 创建Electron应用 在项目根目录下创建一个名为main.js的文件,这是Electron应用的主进程文件。在main.js中添加以下代码: ```javascript const { app, BrowserWindow } = require('electron') function createWindow () { // 创建浏览器窗口 const win = new BrowserWindow({ width: 800, height: 600, webPreferences: { nodeIntegration: true } }) // 加载index.html文件 win.loadFile('index.html') } app.whenReady().then(() => { createWindow() }) ``` 以上代码创建了一个Electron窗口,并加载了一个名为index.html的文件。在项目根目录下创建一个名为index.html的文件,并添加以下代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Hello World!</title> </head> <body> <h1>Hello World!</h1> </body> </html> ``` 以上代码创建了一个包含“Hello World!”文本的HTML页面。 4. 安装VueCli 在命令行中执行以下命令安装VueCli: ``` npm install -g @vue/cli ``` 以上命令会全局安装VueCli。 5. 创建Vue.js应用 在项目根目录下执行以下命令创建一个Vue.js应用: ``` vue create renderer ``` 以上命令会创建一个名为renderer的子目录,并在其中初始化一个Vue.js项目。 6. 集成Vue.js应用 在main.js中添加以下代码将Vue.js应用集成到Electron应用中: ```javascript const { app, BrowserWindow } = require('electron') const path = require('path') function createWindow () { // 创建浏览器窗口 const win = new BrowserWindow({ width: 800, height: 600, webPreferences: { nodeIntegration: true, preload: path.join(__dirname, 'preload.js') // 加载preload.js文件 } }) // 加载renderer/index.html文件 win.loadFile(path.join(__dirname, 'renderer', 'dist', 'index.html')) } app.whenReady().then(() => { createWindow() }) ``` 以上代码添加了一个preload.js文件,并将Vue.js应用的入口文件设置为renderer/dist/index.html。 7. 编译Vue.js应用 在renderer目录下执行以下命令编译Vue.js应用: ``` npm run build ``` 以上命令会生成一个名为dist的子目录,并在其中包含一个编译后的Vue.js应用。 8. 运行应用 在命令行中执行以下命令启动Electron应用: ``` npm start ``` 以上命令会启动Electron应用,并在Electron窗口中显示“Hello World!”文本和一个Vue.js应用。通过Electron7+VueCli4开发跨平台桌面应用,你可以使用Web技术来构建跨平台桌面应用程序,为用户提供更好的体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值