for (let i = 0, l = LHI.cqt.length; i < l; i++) { let d = LHI.cqt[i]; d.CQTToolTip = 'All SUBLOOP Are OPEN' if (d.SUBLOOP_JSON) { try { d.SUBLOOP_JSON = $.parseJSON(d.SUBLOOP_JSON); d.CQTToolTip = 'STG_OPER || ON_OFF || SUBLOOP || TOOLKEY || BUDGET || CAP || INV || REASON ' d.SUBLOOP_JSON.forEach(function (e) { d.CQTToolTip += "<br/>" + e.STG_OPER + "||" + e.ON_OFF + "||" + e.SUBLOOP + "||" + e.TOOLKEY + "||" + e.Budget + '||' + e.CAP + '||' + e.INV + '||' + e.REASON }) } catch (err) { console.log('unable to parse CQT JSON row:' + i); } } }
时间: 2024-02-10 21:28:51 浏览: 148
这段代码是一个循环,它遍历了一个名为LHI.cqt的数组。在循环的每一次迭代中,它将数组中的元素赋值给变量d。然后,它给d添加一个名为CQTToolTip的属性,值为'All SUBLOOP Are OPEN'。
接下来,它检查d对象是否有一个名为SUBLOOP_JSON的属性。如果有,它尝试将SUBLOOP_JSON的值解析为JSON格式,并给d添加一个新的属性CQTToolTip。这个新的CQTToolTip属性的值是一个字符串,包含了一系列用于显示工具提示的信息。
最后,它使用forEach方法遍历SUBLOOP_JSON数组中的每个元素,并将每个元素的属性值拼接到CQTToolTip字符串中,以创建一个更详细的工具提示信息。
如果解析JSON时出现错误,它会输出一条错误信息到控制台。
请注意,代码中引用了$和$.parseJSON,这可能是引入了jQuery库或其他JavaScript库的情况。
相关问题
function sortFunctionPotDays(rowA, rowB) { var a = rowA.pot_days var b = rowB.pot_days return a - b; } function loadLineProfileData() { $("#lapLineProfileLoading").show(); $.ajax({ type: "GET", url: "getLineProfileDMTMDev", dataType: "json", cache: false, success: function (data, textStatus, jqXHR) { LHI.line_profile = data.line_profile; LHI.pull_station = data.pull_station; LHI.cqt = data.cqt; var data = data.line_profile; for (var i = 0, l = data.length; i < l; i++) { var d = data[i]; d.pot_days = Math.round(parseFloat(d.pot_days) * 100) / 100; d.width = Math.round(parseFloat(d.width) * 100) / 100; d.block = +d.block; d.block_moves = +d.block_moves; d.block_req_moves = +d.block_req_moves; d.block_wip = +d.block_wip; d.required_moves = +d.required_moves; d.running_wip = +d.running_wip; d.wafer_delta = +d.wafer_delta; d.segment = +d.segment if ($("#wipCriteria option:checked").val() == 1) { d.wip = +d.wip; } else { d.wip = +d.prod_wip; } d.pot_ww = +d.pot_ww; }
这段代码包含两个函数:sortFunctionPotDays和loadLineProfileData。
sortFunctionPotDays函数用于比较两个对象的pot_days属性,并根据它们的大小进行排序。它首先将rowA和rowB的pot_days属性分别赋值给变量a和b,然后返回a - b的结果,实现升序排序。
loadLineProfileData函数用于加载线路配置数据。它首先显示一个具有id为"lapLineProfileLoading"的元素。
然后,它使用jQuery的ajax方法发送一个GET请求。请求的URL是"getLineProfileDMTMDev",期望的响应数据类型是JSON。通过设置cache为false,禁用对响应的缓存。
当请求成功时,它将返回的数据分别赋值给LHI对象的line_profile、pull_station和cqt属性。
接下来,它将返回的数据赋值给一个名为data的变量。然后,它遍历data数组中的每个元素。
在每次迭代中,它将元素赋值给变量d。然后,它对d对象的一些属性进行处理和转换。例如,将pot_days属性的值四舍五入到小数点后两位,将width属性的值四舍五入到小数点后两位。
接下来,它将一些属性(如block、block_moves等)转换为数字类型。
然后,根据选择框(id为"wipCriteria")选中的值,决定将哪个属性(wip或prod_wip)转换为数字类型。
最后,它将一些属性(如wip、pot_ww等)转换为数字类型。
请注意,代码中引用了$、Math.round和$.ajax,这可能是引入了jQuery库或其他JavaScript库的情况。
function buildLHINodeChartSeries(techNode, renderToId, height, filteredArray) { var drawFiltered = false; if (filteredArray) { rsArrayFilter = filteredArray; drawFiltered = true; } else { rsArrayFilter = LHI.nodeLineArray.filter(function (e) { return e.tech_node === techNode; }); } var cqtArray = LHI.cqt.filter(function (e) { return e.PROCESS === techNode }); var pullStationArray = LHI.pull_station.filter(function (e) { return e.part === techNode }); rsArrayChart = []; rsArrayFilter.sort(sortFunctionPotDays); if (rsArrayFilter.length > 0) { var fillColorObj = { linearGradient: { x1: 0, y1: 0, x2: 0, y2: 1 }, stops: [ [0, Highcharts.getOptions().colors[0]], [1, Highcharts.Color(Highcharts.getOptions().colors[0]).setOpacity( 0).get('rgba')] ] };
这段代码定义了一个名为buildLHINodeChartSeries的函数,它接受四个参数:techNode,renderToId,height和filteredArray。
首先,它设置了一个变量drawFiltered为false。然后检查filteredArray是否存在。如果存在,它将filteredArray赋值给全局变量rsArrayFilter,并将drawFiltered设置为true。否则,它使用filter方法筛选出LHI.nodeLineArray中tech_node属性等于techNode的元素,并将结果赋值给rsArrayFilter。
接下来,它使用filter方法从LHI.cqt数组中筛选出PROCESS属性等于techNode的元素,并将结果赋值给cqtArray。
然后,它使用filter方法从LHI.pull_station数组中筛选出part属性等于techNode的元素,并将结果赋值给pullStationArray。
接下来,它初始化了一个空数组rsArrayChart。
然后,它对rsArrayFilter数组进行排序,排序函数是sortFunctionPotDays。
然后,它检查rsArrayFilter数组的长度是否大于0。如果大于0,则定义了一个fillColorObj对象,该对象定义了一个线性渐变的颜色,用于填充图表中的区域。
请注意,代码中引用了Highcharts库,因此在使用之前需要确保已经引入了Highcharts库。
阅读全文