jsp页面中<%=var%>获取的变量var的值乱码

jsp页面中有如下代码:
<%String title= URLDecoder.decode(request.getParameter(“title”), “UTF-8”);%>

接收到的title是utf8编码后的字符,用System.out.println打印出来title内容显示是正常的中文,但是到var title = '<%=title%>'该行js代码报错,导致后续代码未执行,页面显示空白。很费解。

后来仔细比对title字段utf8编码后的字符,发现4个中文占了13个子节,最后多了个%0A,其实是个换行符\n,导致报错的。。。

<%@page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@page import="weaver.general.Util"%> <%@page import="weaver.conn.RecordSet"%> <%@page import="com.alibaba.fastjson.JSONObject"%> <%@page import="com.alibaba.fastjson.JSONArray"%> <%@page import="java.net.URLEncoder"%> <% request.setCharacterEncoding("UTF-8"); // 基础参数 String pddhRaw = Util.null2String(request.getParameter("PDDH")); String pddh = "0"; try { pddh = String.valueOf(Integer.parseInt(pddhRaw)); } catch(Exception e){ pddh = "0"; } // 查询参数(做简单清洗,避免注入/通配符滥用) String q_zcbm = Util.null2String(request.getParameter("q_zcbm")).replaceAll("[%'_]", ""); String q_syr = Util.null2String(request.getParameter("q_syr")).replaceAll("[%'_]", ""); String q_sybm = Util.null2String(request.getParameter("q_sybm")).replaceAll("[%'_]", ""); // 组装 SQL StringBuilder sql = new StringBuilder(); sql.append("select zcmc,zcbm,zcqc,zcgz,zclz,zcfl,ppxh,syr,sybm,rkrq,pdbz,zczt,pdsj,zcgs ") .append("from uf_CKBGQD where pddh=").append(pddh); if(q_zcbm.length()>0){ sql.append(" and zcbm like '%").append(q_zcbm).append("%'"); } if(q_syr.length()>0 ){ sql.append(" and syr like '%").append(q_syr ).append("%'"); } if(q_sybm.length()>0){ sql.append(" and sybm like '%").append(q_sybm).append("%'"); } // 查询 JSONArray jsonArray = new JSONArray(); RecordSet rs = new RecordSet(); rs.execute(sql.toString()); while(rs.next()){ JSONObject row = new JSONObject(); row.put("zcmc", rs.getString("zcmc")); row.put("zcbm", rs.getString("zcbm")); row.put("zcqc", rs.getString("zcqc")); row.put("zcgz", rs.getString("zcgz")); row.put("zclz", rs.getString("zclz")); row.put("zcfl", rs.getString("zcfl")); row.put("ppxh", rs.getString("ppxh")); row.put("syr", rs.getString("syr")); row.put("sybm", rs.getString("sybm")); // 使用部门 row.put("rkrq", rs.getString("rkrq")); row.put("pdbz", rs.getString("pdbz")); row.put("zczt", rs.getString("zczt")); row.put("pdsj", rs.getString("pdsj")); row.put("zcgs", rs.getString("zcgs")); // 资产归属 jsonArray.add(row); } // 把数据输出给前端 JS 使用(便于导出/前端处理) String dataJson = jsonArray.toJSONString(); %> <!DOCTYPE html> <html> <head> <title>查看报告</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no"> <link rel="stylesheet" href="/cloudstore/resource/pc/com/v1/index.min.css?v=1715806801819"> <link rel="stylesheet" href="/cloudstore/resource/pc/com/v1/ecCom.min.css?v=1715806801819"> <script type="text/javascript" src="/js/My97DatePicker/WdatePicker.js" charset="gb2312"></script> <script type="text/javascript" src="/js/jquery/jquery-3.7.1.min.js"></script> <style> .toolbar { display:flex; gap:8px; align-items:center; padding:10px 0; flex-wrap:wrap; } .toolbar input { height:32px; padding:0 8px; } .toolbar .btn { height:32px; padding:0 12px; border:1px solid #d9d9d9; border-radius:4px; background:#fff; cursor:pointer; } .toolbar .btn.primary { background:#1677ff; color:#fff; border-color:#1677ff; } .action-link { color:#1677ff; cursor:pointer; } </style> </head> <body style="width:100%; height:100%;"> <div id="container"> <div class="coms-mode-docker coms-mode-search"> <div id="cube_search_9"> <div class="ant-spin-nested-loading"> <div class="ant-spin-container"> <div style="height: 100%;"> <div class="wea-new-top-content" style="height: 691.175px; overflow-y: hidden;"> <div class="cube-list-wrapper"> <!-- 查询工具条 & 导出 --> <form id="queryForm" method="get" class="toolbar"> <input type="hidden" name="PDDH" value="<%=pddh%>" /> <label>物料编码:</label> <input type="text" name="q_zcbm" value="<%=q_zcbm%>" placeholder="支持模糊查询"> <label>使用人:</label> <input type="text" name="q_syr" value="<%=q_syr%>" placeholder="支持模糊查询"> <label>使用部门:</label> <input type="text" name="q_sybm" value="<%=q_sybm%>" placeholder="支持模糊查询"> <button type="submit" class="btn primary">查询</button> <button type="button" class="btn" id="btnReset">重置</button> <button type="button" class="btn" id="btnExport">导出当前结果</button> </form> <div class="wea-new-table cube-list-table pageAutoWrap"> <div style="width: 100%; height: 100%;"> <div class="cube-list-table clearfix"> <div class="ant-spin-nested-loading"> <div class="ant-spin-container"> <div class="ant-table ant-table-large ant-table-fixed-header ant-table-scroll-position-left"> <div class="ant-table-content" style="padding-left: 0px; padding-right: 0px;"> <div class="ant-table-scroll"> <span> <div class="ant-table-header" style="overflow-x: scroll; margin-bottom: 0px !important; padding-bottom: 0px !important;"> <table class="ant-table-fixed" style="width: 100%;"> <colgroup> <col style="width: 14%"> <col style="width: 10%"> <col style="width: 14%"> <col style="width: 8%"> <col style="width: 8%"> <col style="width: 8%"> <col style="width: 10%"> <col style="width: 8%"> <col style="width: 10%"> <col style="width: 8%"> <col style="width: 8%"> <col style="width: 10%"> </colgroup> <thead class="ant-table-thead"> <tr style="height: 41.6px;"> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">物料编码</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">资产名称</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">资产全称</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">资产类属</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">资产归属</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">资产分类</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">品牌/型号</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">使用人</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">使用部门</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">入库日期</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">资产状态</span></th> <th class="react-resizable"><span class="ant-table-column-sorterN text-elli">操作</span></th> </tr> </thead> </table> </div> <div class="ant-table-body" style="overflow: auto scroll; max-height: 600px; min-height: auto;"> <table class="ant-table-fixed" style="width: 100%;" id="dataTable"> <colgroup> <col style="width: 14%"> <col style="width: 10%"> <col style="width: 14%"> <col style="width: 8%"> <col style="width: 8%"> <col style="width: 8%"> <col style="width: 10%"> <col style="width: 8%"> <col style="width: 10%"> <col style="width: 8%"> <col style="width: 8%"> <col style="width: 10%"> </colgroup> <tbody class="ant-table-tbody"> <% if(jsonArray.size()>0){ for(int i=0;i<jsonArray.size();i++){ %> <tr class="ant-table-row ant-table-row-level-0"> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("zcbm")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("zcmc")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("zcqc")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("zclz")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("zcgs")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("zcfl")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("ppxh")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("syr")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("sybm")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("rkrq")%></span></td> <td class="react-resizable"><span class="wea-url"><%=jsonArray.getJSONObject(i).getString("zczt")%></span></td> <td class="react-resizable"> <span class="action-link" onclick="onDelete(this)">删除</span> </td> </tr> <% } } %> </tbody> </table> </div> </span> </div> </div> </div> </div> </div> <!-- ant-spin-container --> </div> </div> </div> <!-- table wrap --> </div> </div> </div> </div> </div> <!-- spin --> </div> </div> </div> <script> // 前端可用数据(用于导出) const tableData = <%=dataJson%>; // 重置查询 $("#btnReset").on("click", function(){ const base = location.pathname + "?PDDH=<%=pddh%>"; location.href = base; }); // 一键导出(把当前结果导成 CSV) $("#btnExport").on("click", function(){ if(!tableData || tableData.length === 0){ alert("没有可导出的数据"); return; } const headers = ["物料编码","资产名称","资产全称","资产类属","资产归属","资产分类","品牌/型号","使用人","使用部门","入库日期","资产状态","盘点备注","盘点时间"]; const keys = ["zcbm","zcmc","zcqc","zclz","zcgs","zcfl","ppxh","syr","sybm","rkrq","zczt","pdbz","pdsj"]; // CSV 内容,含 BOM 以防中文乱码(Excel 友好) let csv = "\uFEFF" + headers.join(",") + "\n"; tableData.forEach(r=>{ const row = keys.map(k=>{ let val = (r[k] ?? "").toString().replace(/"/g,'""'); // 若包含逗号/引号/换行,按 CSV 规范用引号包裹 if(/[",\n]/.test(val)){ val = `"${val}"`; } return val; }).join(","); csv += row + "\n"; }); const blob = new Blob([csv], {type: "text/csv;charset=utf-8;"}); const url = URL.createObjectURL(blob); const a = document.createElement("a"); const ts = new Date(); const pad = n=> String(n).padStart(2,"0"); const name = `盘点清单_${ts.getFullYear()}${pad(ts.getMonth()+1)}${pad(ts.getDate())}_${pad(ts.getHours())}${pad(ts.getMinutes())}${pad(ts.getSeconds())}.csv`; a.href = url; a.download = name; document.body.appendChild(a); a.click(); document.body.removeChild(a); URL.revokeObjectURL(url); }); // 删除:把该行的“物料编码”传给后端 function onDelete(el){ const $tr = $(el).closest("tr"); const zcbm = $tr.find("td").eq(0).text().trim(); // 第1列就是物料编码 if(!zcbm){ alert("未找到物料编码"); return; } if(!confirm("确认删除物料编码为【"+zcbm+"】的记录吗?")) return; // // TODO: 把 URL 换成你后端实际的删除接口 // $.ajax({ // url: "/api/ckbgqd/delete", // 例如:新建一个 Servlet/JSP 接口去处理删除 // type: "POST", // data: { zcbm: zcbm, pddh: "<%=pddh%>" }, // success: function(res){ // // 这里按你的后端返回格式调整 // // 假设返回 {success:true,msg:"ok"} // try{ // const r = typeof res === "string" ? JSON.parse(res) : res; // if(r.success){ // $tr.remove(); // }else{ // alert(r.msg || "删除失败"); // } // }catch(e){ // // 如果不是 JSON,就当成功处理 // $tr.remove(); // } // }, // error: function(){ // alert("请求失败,请稍后重试"); // } // }); var pddh = "<%=pddh%>"; <% String sql = "delete from uf_CKBGQD where pddh ='"<%=pddh%>"' and zcbm ="+"'"+zcbm+"'"; RecordSet rs1 = new RecordSet(); rs1.execute(rs1); %> } </script> </body> </html> 这个有错误,帮修复一下
最新发布
10-24
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" %> <!DOCTYPE html> <html lang="en"> <%@ taglib prefix="spring" uri="http://www.springframework.org/tags" %> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=no,minimum-scale=1.0"> <title><spring:message code="location_adjustment"/></title> <!-- compiled css output --> <%@ include file="../common/header.jsp" %> </head> <style> .float-bottom { position: fixed; bottom: 0; left: 0; width: 100%; background: #fff; } </style> <%--<spring:message code="login_name"></spring:message>--%> <body> <div id="container" class="scroller" style="height: 100%;"> <div class="loading"> Loading </div> <div class="bar-positive bar bar-header disable-user-behavior" style="position:relative;"> <div side="right" class="pull-right"> <button class="button button-icon button-clear ion-ios-undo-outline" onclick="end()"> </button> </div> <h1 class="h1 title"><spring:message code="location_adjustment"/></h1> <%@include file="../common/left.jsp"%> </div> <div class="content text-center padding" id="scanStep3"> <div id="scanStep0"> <h1> <div class="positive subheader-height-arrange-unit-scan-main-content"><spring:message code="out"/></div> </h1> <div class="positive has-subheader-content-arrange-unit-scan-sub-content"><spring:message code="please_scan_outof-location"/></div> </div> <div id="scanStep1" style="display: none;"> <h1> <div class="positive subheader-height-arrange-unit-scan-main-content"><spring:message code="in"/></div> </h1> <div class="positive has-subheader-content-arrange-unit-scan-sub-content"><spring:message code="please_scan_into-location"/></div> <div style="text-align:center;color:#AAAAAA;margin-top:10px;" id="outUnitName"></div> </div> <div class="content item-input-inset" style="margin-top:20px;"> <label class="item-input-wrapper"> <input type="text" placeholder="<spring:message code="scan_NFC/bar_code/input_mobile_location_manually" />" id="storageunit">   </label> <a href="javascript:WE.scanQRCode();"><i class="icon ion-ios-camera"></i></a> </div> <button class="button button-block button-positive" style="margin-top:20px;" type="submit" onclick="submitUnitName()"><spring:message code="submit_location"/></button> </div> <div id="scanStep2" style="display: none;"> <div class="bar bar-subheader-content subheader-height-arrange-unit-scan-finish padding" on-hold="arrangeAllOutUnitMac()"> <table class="xsa-table-content" width="100%"> <tr ng-show="true"> <td width="45%"><h3><span class="positive arrange-unit-scan-finish-unit-info-base" id="outUnit"></span></h3></td> <td width="10%" style="text-align:center"><h3><i class="icon ion-arrow-right-a positive"></i> </h3></td> <td width="45%"><h3><span class="positive arrange-unit-scan-finish-unit-info-base" id="inUnit"></span></h3></td> </tr> </table> <table class="arrange-unit-scan-finish-attached-info-table" width="100%"> <tr> <td width="45%"><span class="arrange-unit-scan-finish-unit-info-base arrange-unit-scan-finish-unit-attached-info-base" id="outstorageName">{{outUnitObj.storageName}}[{{outUnitObj.unitUseTypeDesc}}]</span> </td> <td width="10%"></td> <td width="45%"><span class="arrange-unit-scan-finish-unit-info-base arrange-unit-scan-finish-unit-attached-info-base" id="instorageName">{{inUnitObj.storageName}}[{{inUnitObj.unitUseTypeDesc}}]</span></td> </tr> <tr> <td width="45%"><span class="arrange-unit-scan-finish-unit-info-base arrange-unit-scan-finish-unit-attached-info-base" id="outquantity"><spring:message code="quantity"/> : {{outUnitObj.macnoQuantity}}</span> </td> <td width="10%"></td> <td width="45%"><span class="arrange-unit-scan-finish-unit-info-base arrange-unit-scan-finish-unit-attached-info-base" id="inquantity"><spring:message code="category"/> : {{inUnitObj.macnoQuantity}}</span> </td> </tr> <tr> <td width="45%"><span class="arrange-unit-scan-finish-unit-info-base arrange-unit-scan-finish-unit-attached-info-base" id="outtotalQuantity"><spring:message code="quantity"/> : {{outUnitObj.totalQuantity}}</span></td> <td width="10%"></td> <td width="45%"><span class="arrange-unit-scan-finish-unit-info-base arrange-unit-scan-finish-unit-attached-info-base" id="intotalQuantity"><spring:message code="category"/> : {{inUnitObj.totalQuantity}}</span></td> </tr> </table> </div> <div class="has-header has-subheader-content-arrange-unit-scan-finish has-bar-for-footer-button"> <div> <div class="macInfoList" class="xsa-pickup-finish item-button-right" style="padding-right:0px; overflow: hidden;"> <!--<ion-item quick-ng-repeat="item in macInfoList" quick-repeat-list="macInfoList" class="xsa-pickup-finish item-button-right" style="padding-right:0px">--> <table width="100%" class="table" style="margin-bottom: 80px"> </table> </div> </div> </div> </div> </div> <div class="content text-center padding float-bottom" style="display: none;"> <button class="button button-block button-positive" onclick="end()"><spring:message code="finish_adjustment"/></button> </div> <%@ include file="../common/footer.jsp" %> <script> function scanQRCodeResult(code) { $('#storageunit').val(code); submitUnitName(); } function readNFCDataResult(nfcData) { $('#storageunit').val(nfcData); submitUnitName(); } var scanStep = 0; var storage_unit_out = ''; var storage_unit_in = ''; $(function () { storage_unit_in = getCookie('storage_unit_in') ? $.parseJSON(getCookie('storage_unit_in')) : null; storage_unit_out = getCookie('storage_unit_out') ? $.parseJSON(getCookie('storage_unit_out')) : null; if (storage_unit_out != null) { scanStep = 1; } if (storage_unit_out != null && storage_unit_in != null) { scanStep = 2; } setStep(); $('body').on('click', '.macInfoList tr', function () { setCookie("current_mac_info", $(this).attr('data-value')); $('#spinner').show(); window.location.href = "<%=request.getContextPath()%>/mobile/arrangeunit/detail?v="+Date.parse(new Date()); }); }); function setStep() { if (scanStep == 0) { $('#scanStep0').show(); $('#scanStep1').hide(); $('#scanStep2').hide(); $('.float-bottom').hide(); $('.pull-right').hide(); } else if (scanStep == 1) { $('#outUnitName').html('<spring:message code="location" />:' + storage_unit_out.name + '(' + storage_unit_out.storageName + '[' + storage_unit_out.unitUseTypeDesc + '])'); $('#scanStep0').hide(); $('#scanStep1').show(); $('#scanStep2').hide(); $('.float-bottom').hide(); $('.pull-right').show(); } else if (scanStep == 2) { $('#scanStep0').hide(); $('#scanStep1').hide(); $('#scanStep2').show(); $('.float-bottom').show(); $('#scanStep3').hide(); $('.pull-right').hide(); $('#outUnit').html(storage_unit_out.name); $('#inUnit').html(storage_unit_in.name); $('#outstorageName').html(storage_unit_out.storageName + '[' + storage_unit_out.unitUseTypeDesc + '])'); $('#instorageName').html(storage_unit_in.storageName + '[' + storage_unit_in.unitUseTypeDesc + '])'); $('#outquantity').html('<spring:message code="category" /> :' + storage_unit_out.macnoQuantity); $('#inquantity').html('<spring:message code="category" /> :' + storage_unit_in.macnoQuantity); $('#outtotalQuantity').html('<spring:message code="quantity" /> :' + storage_unit_out.totalQuantity); $('#intotalQuantity').html('<spring:message code="quantity" /> :' + storage_unit_in.totalQuantity); macList(); } } function macList() { data = {outUnitName: (storage_unit_out.name)}; $.ajax({ type: "get", url: malApiUrl + "?data="+getPostdata(data,"xsa.arrangeUnitGetMacInfoList2") + "&callback=jsoncallback", async: false, dataType: "jsonp", jsonp:'callback',//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(默认为:callback) jsonpCallback:"success_jsonpCallback",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名 success_jsonpCallback: function(data){ }, success: function (data) { data = setData(data); data.result = JSON.parse(data.result); if (data.code == 0) { if (data.result.length == 0) { BootstrapDialog.show({ title: '<spring:message code="message"/>', message: '<spring:message code="moving_location_finsh"/>'.format(storage_unit_out.name), buttons: [{ label: '<spring:message code="confirm"/>', action: function (dialog) { delCookie("storage_unit_in"); delCookie("storage_unit_out"); delCookie("current_mac_info"); $('#spinner').show(); window.location.href = "<%=request.getContextPath()%>/mobile/arrangeunit/unit?v="+Date.parse(new Date()); } }] }); } for (var i = 0; i < data.result.length; i++) { var item = data.result[i]; var item_str = escape(JSON.stringify(item)); $('.macInfoList table').append('<tr data-value="' + item_str + '"><td><div><h4>' + item.macname + '</h4></div><div>' + item.macno + '<span class="positive">* ' + item.quantity + '</span></div></td></tr>'); } } }, error: function (data) { message("提交数据失败!"); } }); } function submitUnitName() { setStep(); var url = ''; var data = ''; if (scanStep == 0) { data = {outUnitName: $('#storageunit').val()}; url = malApiUrl + "?data="+getPostdata(data,"xsa.arrangeUnitScanOutUnit2") + "&callback=jsoncallback"; } else if (scanStep == 1) { data = {outUnitName: storage_unit_out.name, inUnitName: $('#storageunit').val()}; url = malApiUrl + "?data="+getPostdata(data,"xsa.arrangeUnitScanInUnit2") + "&callback=jsoncallback"; } $.ajax({ type: "get", url: url, async: false, dataType: "jsonp", jsonp:'callback',//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(默认为:callback) jsonpCallback:"success_jsonpCallback",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名 success_jsonpCallback: function(data){ }, success: function (data) { data = setData(data); if (data.code == 0) { data.result = JSON.parse(data.result); if (scanStep == 0) { storage_unit_out = data.result; setCookie('storage_unit_out', JSON.stringify(data.result)); playMp3('<%=request.getContextPath() %>/mobile/raw/sound_pickup_one_success.mp3'); message(data.msg); } else { storage_unit_in = data.result; if (storage_unit_out.name == storage_unit_in.name) { playMp3('<%=request.getContextPath() %>/mobile/raw/sound_pickup_fail.mp3'); message('<spring:message code="sample_location_out_in"/>'.format(storage_unit_out.name,storage_unit_in.name)); return; } setCookie('storage_unit_in', JSON.stringify(data.result)); playMp3('<%=request.getContextPath() %>/mobile/raw/sound_pickup_one_success.mp3'); message(data.msg); } scanStep = scanStep + 1; $('#storageunit').val(''); setStep(); } else { playMp3('<%=request.getContextPath() %>/mobile/raw/sound_pickup_fail.mp3'); message(data.msg); } }, error: function (data) { message("提交数据失败!"); } }); } function end() { BootstrapDialog.show({ title: '<spring:message code="message"/>', message: '<spring:message code="adjustment_finsh"/> ', buttons: [{ label: '<spring:message code="cancel"/>', class: 'cancle', action: function (dialog) { dialog.close(); } }, { label: '<spring:message code="confirm"/>', class: 'confirm', action: function (dialog) { delCookie("storage_unit_in"); delCookie("storage_unit_out"); delCookie("current_mac_info"); $('#spinner').show(); window.location.href = "<%=request.getContextPath()%>/mobile/arrangeunit/unit?v="+Date.parse(new Date()); } }] }); } </script> </body> </html> 这个里面的scanStep == 3时这个的页面的长按箭头按着应该弹出弹框的现在是为什么弹不出来呢
07-05
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值