From bd5b62917f9544cf1297ea6c0075940df252960d Mon Sep 17 00:00:00 2001 From: aolinwxfx <913976138@qq.com> Date: Tue, 6 Oct 2020 17:57:13 +0800 Subject: [PATCH] update README.md. --- README.md | 138 ++---------------------------------------------------- 1 file changed, 4 insertions(+), 134 deletions(-) diff --git a/README.md b/README.md index 45d127a..7607398 100644 --- a/README.md +++ b/README.md @@ -1,19 +1,10 @@ ## 一、项目描述 -- [**React 版本请点击这里查看,全新界面超级好看!!!(o ゚ v ゚)ノ**](https://gitee.com/MTrun/react-big-screen) -- 一个基于 vue、datav、Echart 框架的 " **数据大屏项目** ",通过 vue 组件实现数据动态刷新渲染,内部图表可实现自由替换。部分图表使用 DataV 自带组件,可进行更改,详情请点击下方 DataV 文档。 +- 一个基于 vue、datav、Echart 框架的 " **数据大屏项目** ", - 项目需要全屏展示(按 F11)。 -- 项目部分区域使用了全局注册方式,增加了打包体积,在实际运用中请使用**按需引入**。 -- 拉取项目之后,建议按照自己的功能区域重命名文件,现以简单的位置进行区分。 - 项目环境:vue-cli-3.0、webpack-4.0、npm-6.13、node-v12.16。 -- 请拉取 master 分支的代码,其余是开发分支。 -友情链接: -1. [Vue 官方文档](https://cn.vuejs.org/v2/guide/instance.html) -2. [DataV 官方文档](http://datav.jiaminghi.com/guide/) -3. [echarts 实例](https://echarts.apache.org/examples/zh/index.html),[echarts API文档](https://echarts.apache.org/zh/api.html#echarts) -4. [项目 gitee 地址(国内速度快)](https://gitee.com/MTrun/big-screen-vue-datav) 项目展示 ![项目展示](https://images.gitee.com/uploads/images/2020/0411/221307_0f8af2e7_4964818.gif '20200411_221020.gif') @@ -34,69 +25,18 @@ ## 三、使用介绍 -### 启动项目 - -需要提前安装好`nodejs`与`npm`,下载项目后在项目主目录下运行`npm/cnpm install`拉取依赖包,然后使用 `vue-cli` 或者直接使用命令`npm run serve`,就可以启动项目,启动项目后需要手动全屏(按 F11)。 - ### 请求数据 - 现在的项目未使用前后端数据请求,建议使用 axios 进行数据请求,在 main.js 位置进行全局配置,在 views/xx.vue 文件里进行前后端数据请求。 + 现在的项目未使用前后端数据请求,建议使用 axios 进行数据请求, - axios 的 main.js 配置参考范例(因人而异) -```js -import axios from 'axios'; - -//把方法放到vue的原型上,这样就可以全局使用了 -Vue.prototype.$http = axios.create({ - //设置20秒超时时间 - timeout: 20000, - baseURL: 'http://172.0.0.1:80080', //这里写后端地址 -}); -``` - -- 在 vue 页面中调用 axios 方法并通过 props 传给 echarts 图表子组件 - -```js -export default { - data() { - ListDataSelf:[] - }, - mounted() { - this.fetchList(); //获取数据 - }, - methods: { - async fetchList(){ - const { code,listData }= await this.$http.get("xx/xx/xx"x); - if(code === 200){ - this.ListDataSelf= listData; - } - } - } - } -``` ### 动态渲染图表 在`components/echart`下的文件,比如`drawPie()`是渲染函数,`echartData`是需要动态渲染的数据,当外界通过`props`传入新数据,我们可以使用`watch()`方法去监听,一但数据变化就调用`this.drawPie()`并触发内部的`.setOption`函数,重新渲染一次图表。 -```js -//这里是子组件内部 - -props: ["listData"], -watch: { - listData(newValue) { - this.echartData= newValue; - this.drawPie(); - }, - }, -methods: { - drawPie() { - ..... - '渲染节点名称'.setOption(option); - } - } -``` + ### 复用图表组件 @@ -104,79 +44,10 @@ methods: { 如:在调用处`views/center.vue`里去定义好数据并传入组件(项目里的所有`id`都不能重复!!!) -```js -//组件调用 -今日任务通过率 - - -今日任务达标率 - - -... -import centerChart from "@/components/echart/center/centerChartRate"; - -data() { - return { - rate: [ - { - id: "centerRate1", - tips: 60, - ... - }, - { - id: "centerRate2", - tips: 40, - colorData: { - ... - } - } - ] - } -} -``` - -然后在复用的组件`components/echart/center/centerChartRate`里进行接收并在用到的地方赋值。 ### 更换边框 - 边框是使用了 DataV 自带的组件,只需要去 views 目录下去寻找对应的位置去查找并替换就可以,具体的种类请去 DavaV 官网查看 - 如: - -```html - - - -``` - -### 更换图表 - - 直接进入 `components/echart` 下的文件修改成你要的 echarts 模样,可以去[echarts 官方社区](https://gallery.echartsjs.com/explore.html#sort=rank~timeframe=all~author=all)里面查看案例。 - -### Mixins 注入的 - - 使用 mixins 注入解决了图表重复书写响应式适配的代码,如果要更换(新增)图形,需要将`echarts.init()`函数赋值给`this.chart`,然后 mixins 才会自动帮你注入响应式功能。 - -### 屏幕适配 - - 本项目借助了 flexible 插件,通过改变 rem 的值来进行适配,原设计为 1920px。 ,适配区间为:1366px ~ 2560px,本项目有根据实际情况进行源文件的更改,小屏幕(如:宽为 1366px)需要自己舍弃部分动态组件进行适配,如'动态文字变换组件'会影响布局,需要手动换成一般节点, - -```js -// flexible文件位置: `common/flexible.js`,修改部分如下 -function refreshRem() { - var width = docEl.getBoundingClientRect().width; - // 最小1366px,最大适配2560px - if (width / dpr < 1366) { - width = 1366 * dpr; - } else if (width / dpr > 2560) { - width = 2560 * dpr; - } - // 原项目是1920px我设置成24等份,这样1rem就是80px - var rem = width / 24; - docEl.style.fontSize = rem + 'px'; - flexible.rem = win.rem = rem; -} -``` - + 边框是使用了 DataV 自带的组件, ## 四、更新情况 1. 增加了 Echart 组件复用的功能,如:中间任务达标率的两个百分比图使用的是同一个组件。 @@ -187,4 +58,3 @@ function refreshRem() { ## 五、其余 -这个项目是个人的作品,难免会有问题和 BUG,如果有问题请进行评论,我也会尽力去更新,自己也在前端学习的路上,欢迎交流,非常感谢! -- Gitee