js版计算比亚迪行驶里程连续12个月计算不超3万公里改进版带echar

本文主要是介绍js版计算比亚迪行驶里程连续12个月计算不超3万公里改进版带echar,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

<!DOCTYPE html>
<html lang="zh-CN" style="height: 100%">
<head>
    <meta charset="utf-8" />
    <title>连续12个月不超3万公里计算LIGUANGHUA</title>
    <style>
        .clocks {
            height: 500px;
            margin: 25px auto;
            position: relative;
            width: 500px;
        }
    </style>
</head>
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script src="http://echarts.baidu.com/build/dist/echarts-all.js"></script>
<script type="text/javascript">
    function myFunction(){
        var search1=document.getElementById("month");// 获取对象
        var search2=document.getElementById("amounts");// 获取对象
        // 文档刚刚载入时的默认样式
        search1.value="202211";
        search2.value="2831,1108,3625,2888,2165,3032,1913";
        search1.style.color="gray";
        search2.style.color="gray";
        search1.οnblur=function(){// 失去焦点时
            if(this.value){// 输入框有值,应为黑色字体。
                this.style.color="";
            }else{// 无值时,为文档载入时样式
                this.value="202211";
                this.style.color="gray";
            }
        };
        search2.οnblur=function(){// 失去焦点时
            if(this.value){// 输入框有值,应为黑色字体。
                this.style.color="";
            }else{// 无值时,为文档载入时样式
                this.value="2831,1108,3625,2888,2165,3032,1913";
                this.style.color="gray";
            }
        };
        search1.οnfοcus=function(){// 获得焦点时,清空输入框,恢复字体颜色
            this.value="";
            this.style.color="";
        };
        search2.οnfοcus=function(){// 获得焦点时,清空输入框,恢复字体颜色
            this.value="";
            this.style.color="";
        };
    };
    function counts() {
        var months, amounts,array,hev;
        var arr1 = new Array(0)

        var arr2 = new Array(0)
        months = document.getElementById('month').value;
        amounts = document.getElementById('amounts').value;
        array = amounts.split(",");
        var sum=0,length,max,min,maxYear,minYear,k;
        length=array.length;
        var s='';
        var jve=0;
        var counts=30000;
        for (var i = 0; i < length; i++) {
            arr1.push(handelYear(months,i));
            k=0;
            hev=parseInt(array[i]);
            max=hev;
            console.log(months);
            minYear=handelYear(months,i);
            maxYear=handelYear(months,i);
            console.log(minYear);
            console.log(maxYear);
            min=hev;
            sum += parseInt(array[i]);
            k++;
            for (var j = i+1; j < length; j++) {

                // months.add(array[j]);
                jve=parseInt(array[j]);
                if (jve>max){
                    max=jve;
                    maxYear=handelYear(months,j);
                }
                if (jve<min){
                    min=jve;
                    minYear=handelYear(months,j);
                }
                sum+= jve;
                k++;
                if (k==12){
                    console.log("从"+handelYear(months,i)+"至"+handelYear(handelYear(months,i),11)+"的连续12个月的总里程:"+sum+"公里,平均每月行驶:"+parseInt(sum/k)+"公里,其中"+maxYear+"是单月最大行驶:"+max+"公里,"+minYear+"是单月最小行驶公里数:"+min+"公里");
                    s=s+' <p> 从'+handelYear(months,i)+'至'+handelYear(handelYear(months,i),11)+'的连续12个月的总里程:<span style="color: red ;font-size:20px;font-weight: bold">'+sum+'</span>公里,平均每月行驶:<span style="color: red ;font-size:20px;font-weight: bold">'+parseInt(sum/k)+'</span>公里,其中'+maxYear+'是单月最大行驶:<span style="color: red ;font-size:20px;font-weight: bold">'+max+'</span>公里,'+minYear+'是单月最小行驶公里数:<span style="color: red ;font-size:20px;font-weight: bold">'+min+'</span>公里'+'</p> ';
                    sum=0;
                    k=0;
                    break;
                }else if  (i==0&&k<12&&j==length-1){
                    console.log("1从"+handelYear(months,i)+"至"+handelYear(months,length-1)+"的连续"+ k+"个月的总里程:"+sum+"公里,平均每月行驶:"+parseInt(sum/k)+"公里,其中"+maxYear+"是单月最大行驶:"+max+"公里,"+minYear+"是单月最小行驶公里数:"+min+"公里,剩余的"+(12-k)+"个月內请控制在"+(counts-sum)+"公里内,平均每月可以行驶:"+(counts-sum)/(12-k));
                    //System.out.println("从"+month+"至"+handelYear(month,11)+"里程详情"+months.stream().map(String::valueOf).collect(Collectors.joining(",")));
                    s=s+'<p> 从<span style="color: red ;font-size:20px;font-weight: bold">'+handelYear(months,i)+'</span>至<span style="color: red ;font-size:20px;font-weight: bold">'+handelYear(months,length-1)+'(含当月)</span>连续<span style="color: red ;font-size:20px;font-weight: bold">'+ k+'</span>个月的总里程:<span style="color: red ;font-size:20px;font-weight: bold">'+sum+'</span>公里,平均每月行驶:<span style="color: red ;font-size:20px;font-weight: bold">'+parseInt(sum/k)+'</span>公里,其中'+maxYear+'是单月最大行驶:<span style="color: red ;font-size:20px;font-weight: bold">'+max+'</span>公里,'+minYear+'是单月最小行驶公里数:<span style="color: red ;font-size:20px;font-weight: bold">'+min+'</span>公里'+
                        ',剩余的<span style="color: red ;font-size:20px;font-weight: bold">'+(12-k)+'</span>个月內请控制在<span style="color: red ;font-size:20px;font-weight: bold">'+(counts-sum)+'</span>公里内,平均每月还可以行驶:<span style="color: red ;font-size:20px;font-weight: bold">'+(counts-sum)/(12-k)+'</span>公里</p> ';
                    sum=0;
                    k=0;
                    break;
                }
            }
        }
        document.getElementById('jieguo').innerHTML=s;
        var myChart = echarts.init(document.getElementById('container'));
        var hour = arr1;
        var usercount = array;

        var option = {
            toolbox: {
                show : true,
                feature : {
                    mark : {show: true},
                    dataView : {show: true, readOnly: false},
                    magicType : {show: true, type: ['line','bar']},
                    restore : {show: true},
                    saveAsImage : {show: true}
                }
            },
            tooltip: {
                show: true
            },
            legend: {
                data:['每月公里数']
            },
            xAxis : [
                {
                    type : 'category',
                    data : hour
                }
            ],
            yAxis : [
                {
                    type : 'value'
                }
            ],
            series : [
                {
                    "name":"百分比每度电占比",
                    "type":"line",
                    "data":usercount,
                    itemStyle: {
                        normal: {
                            label : {
                                show: true,
                                position:"top"
                            }
                        }
                    }
                }
            ]
        };


        // 为echarts对象加载数据
        myChart.setOption(option);
    }
    function handelYear(month,length){
        var year=parseInt(month.substring(0,4));
        var mo=month.substring(4,6);
        var mon=0;
        if (mo.startsWith("0")){
            mon=parseInt(month.substring(5,6));
        }else{
            mon=parseInt(month.substring(4,6));
        }
        mon=mon+length;
        var j=parseInt(mon/12);
        if (mon>12){
            year=year+j;
            mon=mon-12*j;
        }
        var yearmon=null;
        if (mon>9){
            yearmon=year.toString()+mon.toString();
        }else{
            if (mon==0){
                mon=mon+1;
            }
            yearmon=year.toString()+"0"+mon.toString();
        }
        return yearmon;
    }


</script>
<!--  <h1><a href="http://10.0.2.52:8081/test/index1" target="_parent">测试手动调用接口</a>></h1>-->

<body style="height: 100%; margin: 0" οnlοad="myFunction()">
<p>请输入周期开始年月份(如:202201):<input type="text" name="month" id="month" οnmοuseοver="this.style.borderColor='#FF6600'" οnmοuseοut="this.style.borderColor=''" onFocus="if (value =='202211'){value =''}" onBlur="if (value ==''){value='202211'}"></p>
<p>请输入上面周期开始的每月公里数(车机系统获取),逗号隔开(如:2831,1108,3625):<input type="text" name="amounts" id="amounts" style="width:550px;" οnmοuseοver="this.style.borderColor='#FF6600'" οnmοuseοut="this.style.borderColor=''" onFocus="if (value =='2831,1108,3625,2888,2165,3032,1913'){value =''}" onBlur="if (value ==''){value='2831,1108,3625,2888,2165,3032,1913'}" ></p>
<p><input type="button" value="开始计算" οnclick="counts()" οnmοuseοver="this.style.borderColor='#FF6600'" οnmοuseοut="this.style.borderColor=''" ></p>
<div id="jieguo">
</div>
<div id="container" style="height: 80%"></div>
</body>
</html>

将以上内容复制到文本框,改名为1.html,用浏览器打开即可

还有项目款,这个需要数据支撑了,感兴趣的可以私我

 

这篇关于js版计算比亚迪行驶里程连续12个月计算不超3万公里改进版带echar的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/197213

相关文章

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

poj2406(连续重复子串)

题意:判断串s是不是str^n,求str的最大长度。 解题思路:kmp可解,后缀数组的倍增算法超时。next[i]表示在第i位匹配失败后,自动跳转到next[i],所以1到next[n]这个串 等于 n-next[n]+1到n这个串。 代码如下; #include<iostream>#include<algorithm>#include<stdio.h>#include<math.

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa