根据返回数据动态创建DOM元素,Echarts等

2 篇文章 0 订阅
2 篇文章 0 订阅

需求:根据所获取数据,显示每个机器实时运转状况,Echarts显示最近9笔数据,数据框以及运行状态显示最新一笔数据

效果:效果图点击查看

逻辑:

1,根据后台数据创建DOM,则前台基本不用写标签了,前台aspx代码如下:(本需求使用LayUI.JS框架)

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="ProductionKanBan.aspx.cs" Inherits="KanBanManage_ProductionKanBan" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>生产看板</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="../layuicms2.0/layui/css/layui.css" media="all" />
    <script type="text/javascript" src="../layuicms2.0/layui/layui.js"></script>
    <script type="text/javascript" src="../layuicms2.0/jquery/jquery-1.7.2.min.js"></script>
    <script type="text/javascript" src="JScript/AHDataChose.js"></script>
    <script src="JScript/echarts-all.js"></script>
    <script src="JScript/infographic.js"></script>
    <%--提前将样式写好--%>
    <style>
    .Number {
        margin:auto;
        width:26vw;
        font-size:20px;
        text-align:center;
        line-height:30px;
    }
    .layui-data{
       float:left;
    }
    .staion {
        display:inline-block;
        float:right;
        margin-top:4px;
    }
    .ui-jqgrid {
        display:none;
    }
    .layui-data {
        display:inline-block;
        margin-left:4px;
        border-right:1px solid #E0DEDB;
        border-bottom:1px solid #E0DEDB;
        width:calc(32vw + 3px);
        height:44vw;
    }
    .layui-form-label {
        padding:6px;
        width:5vw;
        font-size:12px;
        text-align:center;
    }
    .layui-input-block {
        display:inline-block;
        width:10vw;
    }
    .echarts{
        margin-left:-42px;
        height: 300px;
        width:39vw
    }
   .layui-badge {
       display:inline-block;
       float:right;
       margin-top:4px;
       font-size:14px;
       height:24px;
       line-height:24px;
       width:52px;
    }
    input {
        width:8vw;
        margin-top:6px;
    }
    .layui-table-box{
        display:none;
    }
    .PutDataLeft {
        display:inline-block;
        width:16vw;
        float:left;
        
    }
</style>
</head>
<body>
    <%--使用Layui readerTable方法访问数据库,为什么,看JS就会明白--%>
    <table id="gridList" style="display:none"></table>
    <%--动态创建DOM元素的容器--%>
    <div class="panel panel-default" style="margin-bottom: 10px;">
    </div>
</body>
</html>

2,JS文件则需要大做文章,获取数据,更具数据渲染DOM,并赋值对应DOM中,代码如下:

window.onload = function () {
    var table = layui.table;
    var i = 0;
    var Station;
    var MacCodedata = [];
    //获取各个机台最新的五笔数据
    $.ajax({
        type: "post",
        datatype: "json",
        url: "Handler/ProductionHandler.ashx?action=GetGatherData",
        error: function (result) {
        },
        success: function (result) {
            MacCodedata = result;
            //成功获取数据后调用创建DOM元素函数
            CreatDom();
        }
    });
    function CreatDom() {
        //根据Layui  table.render函数获取各个机台最新的一笔数据
        layui.use('table', function () {
            var table = layui.table;
            table.render({
                elem: '#gridList',
                url: '../../WebService.asmx/getGatherData',
                method: 'post',
                cols: [[
                    {
                        //前台创建Table标签是为了引用其cols参数,因该参数中templet,是根据数据循环渲染,这样即可省去我们进行一一赋值的烦恼,精确而节省代码
                        templet: function (d) {
                            i++;
                            //每次循环清空Echarts数据
                            var EchartTime = [];
                            var EchartRespeed = [];
                            var EchartMespeed = [];
                            var EchartMeter = [];
                            //根据State数据返回机台是运行或停止中状态,即返回对应标签
                            if (d.State == 1) {
                                Station = '<span class=\"layui-badge layui-bg-green\">运行中</span>\n';
                            } else if (d.State == 0) {
                                Station = '<span class=\"layui-badge\">停机中</span>\n';
                            }
                            //根据第一个$.ajax方法获取了MacCodedata数据,这里就可以通过判断机台编号对应,那些数据是有用的,即那些机台此时有在线上运作
                            for (var j = 0; j < MacCodedata.length; j++) {
                                if (d.MacCode == MacCodedata[j].MacCode) {
                                    //获取Echarts各个数据push至数组中
                                    EchartTime.push((MacCodedata[j].Intime))
                                    EchartRespeed.push((MacCodedata[j].Rspeed))
                                    EchartMespeed.push((MacCodedata[j].Mspeed))
                                    EchartMeter.push((MacCodedata[j].Meter))
                                }
                            }
                            //将所需要创建的DOM元素Append至panel-default中
                            $(".panel-default").append(
                               '<div class="layui-data" >\n' +
                               '     <div class="Number" >\n' +
                               '        ' + d.MacCode + '  \n' +
                                        Station +
                               '     </div>\n' +
                               '     <div class="PutDataLeft">\n' +
                               '         <label class="layui-form-label">绞距</label>\n' +
                               '         <input type="text"  readonly="true" value=' + '"' + d.Lays + '"' + '>\n' +
                               '     </div>\n' +
                               '     <div class="PutDataLeft">\n' +
                               '         <label class="layui-form-label">收线张力</label>\n' +
                               '         <input type="text"  readonly="true" value=' + '"' + d.TakeUpTension + '"' + '>\n' +
                               '     </div>\n' +
                               '     <div class="PutDataLeft">\n' +
                               '         <label class="layui-form-label">转速</label>\n' +
                               '         <input type="text"  readonly="true" value=' + '"' + d.Rspeed + '"' + '>\n' +
                               '     </div>\n' +
                               '     <div class="PutDataLeft">\n' +
                               '         <label class="layui-form-label">卷包张力</label>\n' +
                               '         <input type="text"  readonly="true" value=' + '"' + d.WAroundTension + '"' + '>\n' +
                               '     </div>\n' +
                               '     <div class="PutDataLeft">\n' +
                               '         <label class="layui-form-label">米数</label>\n' +
                               '         <input type="text"  readonly="true" value=' + '"' + d.Meter + '"' + '>\n' +
                               '     </div>\n' +
                               '     <div class="PutDataLeft">\n' +
                               '         <label class="layui-form-label">主机转速</label>\n' +
                               '         <input type="text"  readonly="true" value=' + '"' + d.Mspeed + '"' + '>\n' +
                               '     </div>\n' +
                               '     <div id=' + '"AH' + i + '"' + ' class="echarts"></div>\n' +
                               ' </div>'
                             )
                            //调用Echarts函数动态渲染赋值对应Echarts
                            CreateEchart(i, EchartTime, EchartRespeed, EchartMespeed, EchartMeter);
                        }
                    }
                ]]
            })
        });
    }
    function CreateEchart(i, EchartTime, EchartRespeed, EchartMespeed, EchartMeter) {
        var ID = 'AH' + i + ''
        //循环创建对应Echarts
        var myChart = echarts.init(document.getElementById(ID));
        option = {
            tooltip: {
                trigger: 'axis',
                axisPointer: {
                    type: 'cross',
                    crossStyle: {
                        color: '#999'
                    }
                }
            },
            toolbox: {
                feature: {
                    dataView: { show: true, readOnly: false },
                    magicType: { show: true, type: ['line', 'bar'] },
                    restore: { show: true },
                    saveAsImage: { show: true }
                }
            },
            xAxis: [
              {
                  type: 'category',
                  data: EchartTime,
                  axisPointer: {
                      type: 'shadow'
                  }
              }
            ],
            yAxis: [
              {
                  type: 'value',
                  name: 'Mspeed',//主机转速
                  min: 0,
                  max: 10000,
                  interval: 1000,
                  axisLabel: {
                      formatter: '{value}'
                  }
              },
              {
                  type: 'value',
                  name: 'Rspeed',//专速
                  min: 0,
                  max: 200,
                  interval: 40,
                  axisLabel: {
                      formatter: '{value}'
                  }
              }
            ],
            series: [
              {
                  name: 'Mspeed',
                  type: 'line',
                  itemStyle: {
                      normal: {
                          lineStyle: {
                              type: 'solid',
                              width: 2
                          }
                      }
                  },
                  data: EchartMespeed
              },
              {
                  name: 'Meter',
                  type: 'line',
                  itemStyle: {
                      normal: {
                          lineStyle: {
                              type: 'solid',
                              width: 2
                          }
                      }
                  },
                  data: EchartMeter
              },
              {
                  name: 'Rspeed',
                  type: 'bar',
                  yAxisIndex: 1,
                  barWidth: 14,
                  data: EchartRespeed,
                  itemStyle: {
                      normal: {
                          color: '#429EFF',
                          label: {
                              show: true,
                              position: 'top',
                              textStyle: {
                                  color: '#429EFF',
                                  fontSize: 12
                              }
                          }
                      }
                  }
              }
            ]
        }
        myChart.setOption(option);
    }

}

 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Vue中,可以使用createElement函数动态创建DOM元素。createElement函数接受三个参数,分别是标签名、属性对象和子元素。通过调用createElement函数,可以创建一个虚拟节点(vnode),然后将其插入到父元素中。 例如,如果要创建一个div标签,并给其添加子元素,可以使用以下代码: ```javascript render(createElement) { return createElement('div', {}, \[ createElement('p', {}, '这是一个段落'), createElement('span', {}, '这是一个span元素') \]) } ``` 在上述代码中,createElement('div', {}, \[...\])创建了一个div标签,并使用第三个参数添加了两个子元素p和span。 另外,如果想要创建组件节点,可以使用createComponent函数。在Vue的组件系统中,子组件的初始化创建是在createElm函数中进行的。 总结起来,Vue动态创建DOM元素可以通过createElement函数来实现,同时也可以使用createComponent函数来创建组件节点。 #### 引用[.reference_title] - *1* *3* [Vue.js源码解析-Vue初始化流程之动态创建DOM](https://blog.csdn.net/weixin_57699483/article/details/118994933)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Vue2笔记_01创建vdom并挂载到dom元素上](https://blog.csdn.net/qq_43260366/article/details/126908076)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Bibabu135766

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值