$(this).parent("tr").find("td").eq(0).text()

本文介绍了一种使用jQuery快速定位并获取HTML表格中特定元素的方法。通过一个简单的示例展示了如何选取表格行内的第一个单元格文本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 $(this).parent("tr").find("td").eq(0).text()
// 全局变量 let currentSort = { column: null, direction: 'asc' }; let currentPage = 1; const pageSize = 10; let filteredResults = []; //监听来自父窗口的消息 window.addEventListener('message', function(event) { if (event.source === window.parent && event.data === 'DataManagerReady') { initializeDataManager(); } }); // 初始化数据管理器 function initializeDataManager() { const dataManager = window.parent.dataManager; if (dataManager) { // 注册数据刷新回调 dataManager.registerCallback('all', function(operation, entity, data) { updatePageData(dataManager); }); // 初始页面数据更新 updatePageData(dataManager); // 设置搜索功能 setupSearch(dataManager); // 设置排序功能 setupSorting(); // 设置分页事件 setupPagination(); } else { console.error('DataManager not available'); } } // 更新页面数据 function updatePageData(dataManager) { updateStats(dataManager); updateTable(dataManager); $('#lastUpdate').text(new Date().toLocaleTimeString()); } // 更新统计卡片数据 function updateStats(dataManager) { const data = dataManager.data; $('#orderCount').text(data.dingdans?.length || 0); $('#productCount').text(data.chanpins?.length || 0); $('#materialCount').text(data.bancais?.length || 0); const totalStock = data.kucuns?.reduce((sum, kucun) => sum + kucun.shuliang, 0) || 0; $('#totalStock').text(totalStock); } // 更新结果表格 function updateTable(dataManager) { const data = dataManager.data; filteredResults = []; // 处理订单产品数据 if (data.dingdan_chanpins) { data.dingdan_chanpins.forEach(dc => { if (!dc.dingdan || !dc.chanpin) return; if (dc.chanpin.chanpin_zujians) { dc.chanpin.chanpin_zujians.forEach(cz => { if (!cz.zujian || !cz.bancai) return; const bancai = cz.bancai; const materialInfo = getMaterialInfo(bancai); // 查找该板材的库存 const kucun = data.kucuns?.find(k => k.bancai?.id === bancai.id); const stockQuantity = kucun ? kucun.shuliang : 0; filteredResults.push({ orderNumber: dc.dingdan.number, productInfo: dc.chanpin.bianhao, productQuantity: dc.shuliang, component: cz.zujian.name, material: materialInfo, materialPerComponent: cz.one_howmany, materialOrderQuantity: dc.shuliang / cz.one_howmany, stockQuantity: stockQuantity, raw: { orderNumber: dc.dingdan.number, productQuantity: dc.shuliang, materialPerComponent: cz.one_howmany, materialOrderQuantity: dc.shuliang / cz.one_howmany, stockQuantity: stockQuantity, thickness: bancai.houdu || 0 }, bancaiId: bancai.id }); }); } }); } // 处理订单板材数据 (Dingdan_bancai) if (data.dingdan_bancais) { data.dingdan_bancais.forEach(db => { if (!db.dingdan || !db.bancai) return; const bancai = db.bancai; const materialInfo = getMaterialInfo(bancai); // 查找该板材的库存 const kucun = data.kucuns?.find(k => k.bancai?.id === bancai.id); const stockQuantity = kucun ? kucun.shuliang : 0; // 确定产品信息 let productInfo = '独立订购'; if (db.chanpin) { productInfo = db.chanpin.bianhao; } // 确定组件信息 let component = '独立板材'; if (db.zujian) { component = db.zujian.name; } else if (db.chanpin) { component = '产品板材'; } filteredResults.push({ orderNumber: db.dingdan.number, productInfo: productInfo, productQuantity: db.shuliang, // 直接订购的板材数量 component: component, material: materialInfo, materialPerComponent: 1, // 直接订购时,每件用量为1 materialOrderQuantity: db.shuliang, stockQuantity: stockQuantity, raw: { orderNumber: db.dingdan.number, productQuantity: db.shuliang, materialPerComponent: 1, materialOrderQuantity: db.shuliang, stockQuantity: stockQuantity, thickness: bancai.houdu || 0 }, bancaiId: bancai.id }); }); } // 应用排序 if (currentSort.column !== null) { filteredResults = sortResults(filteredResults, currentSort.column, currentSort.direction); } // 渲染表格和分页 renderTable(); renderPagination(); } // 渲染表格数据 function renderTable() { const $tableBody = $('#resultBody'); $tableBody.empty(); const startIndex = (currentPage - 1) * pageSize; const pageData = filteredResults.slice(startIndex, startIndex + pageSize); if (pageData.length === 0) { $('#noResults').show(); $('#paginationContainer').hide(); } else { $('#noResults').hide(); $('#paginationContainer').show(); pageData.forEach(row => { const $tr = $('<tr>'); $tr.append(`<td>${row.orderNumber}</td>`); $tr.append(`<td>${row.productInfo}</td>`); $tr.append(`<td>${row.productQuantity}</td>`); $tr.append(`<td>${row.component}</td>`); $tr.append(`<td>${row.material}</td>`); $tr.append(`<td>${row.materialPerComponent}</td>`); $tr.append(`<td>${row.materialOrderQuantity}</td>`); $tr.append(`<td>${row.stockQuantity}</td>`); $tr.append(`<td><button class="btn btn-sm btn-outline-primary" onclick="showMaterialDetail(${row.bancaiId})">详情</button></td>`); $tableBody.append($tr); }); } $('#resultCount').text(filteredResults.length); } //设置排序功能 function setupSorting() { // 为每个可排序表头添加点击事件 $('#resultsTable th[data-sortable]').each((index, header) => { $(header).on('click', () => { // 更新排序状态 if (currentSort.column === index) { currentSort.direction = currentSort.direction === 'asc' ? 'desc' : 'asc'; } else { currentSort.column = index; currentSort.direction = 'asc'; } // 更新UI指示器 updateSortIndicators(); // 重新排序和渲染表格 filteredResults = sortResults(filteredResults, currentSort.column, currentSort.direction); renderTable(); renderPagination(); }); }); } //排序函数 function sortResults(results, columnIndex, direction) { return results.sort((a, b) => { // 根据列索引确定排序字段 let field; switch(columnIndex) { case 0: field = 'orderNumber'; break; case 1: field = 'productInfo'; break; case 2: field = 'productQuantity'; break; case 3: field = 'component'; break; case 4: return sortByThickness(a, b, direction); // 特殊处理:按厚度排序 case 5: field = 'materialPerComponent'; break; case 6: field = 'materialOrderQuantity'; break; case 7: field = 'stockQuantity'; break; default: return 0; } // 数值排序 if (['productQuantity', 'materialPerComponent', 'materialOrderQuantity', 'stockQuantity'].includes(field)) { return sortNumeric(a.raw[field], b.raw[field], direction); } // 字符串排序 return sortString(a[field], b[field], direction); }); } //按厚度排序(特殊处理) function sortByThickness(a, b, direction) { return sortNumeric(a.raw.thickness, b.raw.thickness, direction); } //数值排序辅助函数 function sortNumeric(aVal, bVal, direction) { const aNum = parseFloat(aVal) || 0; const bNum = parseFloat(bVal) || 0; return direction === 'asc' ? aNum - bNum : bNum - aNum; } //字符串排序辅助函数 function sortString(aVal, bVal, direction) { const aStr = String(aVal).toLowerCase(); const bStr = String(bVal).toLowerCase(); if (aStr < bStr) return direction === 'asc' ? -1 : 1; if (aStr > bStr) return direction === 'asc' ? 1 : -1; return 0; } //更新排序指示器UI function updateSortIndicators() { // 清除所有指示器 $('#resultsTable th[data-sortable] .sort-indicator').text(''); // 为当前排序列添加指示器 if (currentSort.column !== null) { const $currentHeader = $(`#resultsTable th[data-sortable]:eq(${currentSort.column})`); $currentHeader.find('.sort-indicator').text(currentSort.direction === 'asc' ? '↑' : '↓'); } } // 获取板材详细信息函数 function getMaterialInfo(bancai) { if (!bancai) return '未知板材'; // 获取材质名称 const caizhiName = bancai.caizhi?.name || '未知材质'; // 获取木皮信息 const formatMupi = (mupi) => { if (!mupi) return null; return `${mupi.name}${mupi.you ? '()' : ''}`; }; const mupi1Str = formatMupi(bancai.mupi1) || '无'; const mupi2Str = formatMupi(bancai.mupi2) || '无'; const mupiInfo = mupi1Str + (mupi2Str !== '无' ? `/${mupi2Str}` : ''); // 厚度转换为字符串 const thickness = bancai.houdu ? `${bancai.houdu.toFixed(1)}mm` : '未知厚度'; return `${caizhiName}-${mupiInfo} (${thickness})`; } // 设置搜索功能 function setupSearch(dataManager) { // 订单搜索 $('#orderSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 0); }); // 产品搜索 $('#productSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 1); }); // 板材材质搜索 $('#materialSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 4); }); // 木皮搜索 $('#woodSearch').on('input', function() { const searchTerm = $(this).val().toLowerCase(); // 支持中文和数字搜索 const searchKeywords = { '有油': '有油', '无油': '无油', 'you': '有油', 'wu': '无油', '1': '有油', '0': '无油', '()': '()' }; const actualTerm = searchKeywords[searchTerm] || searchTerm; filterTable(actualTerm, 4); }); // 厚度搜索 $('#thicknessSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 4); }); // 库存状态搜索 $('#stockStatusBtn').on('click', function() { const minStock = parseInt($('#minStock').val()) || 0; const maxStock = parseInt($('#maxStock').val()) || Number.MAX_SAFE_INTEGER; filterByStock(minStock, maxStock); }); // 重置搜索 $('#resetSearch').on('click', function() { $('.search-input').val(''); currentPage = 1; updateTable(window.parent.dataManager); }); } // 设置分页功能 function setupPagination() { // 分页按钮事件委托 $('#paginationContainer').on('click', '.page-link', function(e) { e.preventDefault(); const action = $(this).data('action'); if (action === 'prev' && currentPage > 1) { currentPage--; } else if (action === 'next' && currentPage < Math.ceil(filteredResults.length / pageSize)) { currentPage++; } else if (action === 'page') { currentPage = parseInt($(this).data('page')); } renderTable(); renderPagination(); }); } // 渲染分页控件 function renderPagination() { const $pagination = $('#pagination'); $pagination.empty(); const totalPages = Math.ceil(filteredResults.length / pageSize); if (totalPages <= 1) return; // 添加上一页按钮 $pagination.append(` <li class="page-item ${currentPage === 1 ? 'disabled' : ''}"> <a class="page-link" href="#" data-action="prev">上一页</a> </li> `); // 添加页码按钮 const startPage = Math.max(1, currentPage - 2); const endPage = Math.min(totalPages, startPage + 4); for (let i = startPage; i <= endPage; i++) { $pagination.append(` <li class="page-item ${i === currentPage ? 'active' : ''}"> <a class="page-link" href="#" data-action="page" data-page="${i}">${i}</a> </li> `); } // 添加下一页按钮 $pagination.append(` <li class="page-item ${currentPage === totalPages ? 'disabled' : ''}"> <a class="page-link" href="#" data-action="next">下一页</a> </li> `); // 显示页码信息 $('#pageInfo').text(`第 ${currentPage} 页,共 ${totalPages} 页`); } // 更新排序指示器 function updateSortIndicators() { // 清除所有指示器 $('#resultsTable th[data-sortable] .sort-indicator').text(''); // 为当前排序列添加指示器 if (currentSort.column !== null) { const $currentHeader = $(`#resultsTable th[data-sortable]:eq(${currentSort.column})`); $currentHeader.find('.sort-indicator').text(currentSort.direction === 'asc' ? '↑' : '↓'); } } // 表格过滤函数 function filterTable(searchTerm, columnIndex) { currentPage = 1; // 重置到第一页 if (!searchTerm) { updateTable(window.parent.dataManager); return; } const $rows = $('#resultBody tr'); let visibleCount = 0; $rows.each(function() { const $cell = $(this).find(`td:eq(${columnIndex})`); const cellText = $cell.text().toLowerCase(); let isMatch = false; // 特殊处理油状态搜索 if (searchTerm === '有油' || searchTerm === '无油' || searchTerm === '()') { isMatch = cellText.includes(searchTerm); } // 处理厚度字符串匹配 else if (columnIndex === 4 && !isNaN(parseFloat(searchTerm))) { // 提取厚度数字部分进行匹配 const thicknessMatch = cellText.match(/(\d+\.?\d*)/); if (thicknessMatch) { const thicknessValue = parseFloat(thicknessMatch[1]); const searchValue = parseFloat(searchTerm); // 允许小数点误差 isMatch = Math.abs(thicknessValue - searchValue) < 0.5; } } // 常规文本匹配 else { isMatch = cellText.includes(searchTerm); } if (isMatch) { $(this).show(); visibleCount++; } else { $(this).hide(); } }); $('#resultCount').text(visibleCount); $('#noResults').toggle(visibleCount === 0); $('#paginationContainer').toggle(visibleCount > 0); } // 按库存量过滤 function filterByStock(minStock, maxStock) { currentPage = 1; // 重置到第一页 const $rows = $('#resultBody tr'); let visibleCount = 0; $rows.each(function() { const $stockCell = $(this).find('td:eq(7)'); const stockText = $stockCell.text(); const stockValue = parseInt(stockText) || 0; const isMatch = stockValue >= minStock && stockValue <= maxStock; if (isMatch) { $(this).show(); visibleCount++; } else { $(this).hide(); } }); $('#resultCount').text(visibleCount); $('#noResults').toggle(visibleCount === 0); $('#paginationContainer').toggle(visibleCount > 0); } // 显示板材详情模态框 function showMaterialDetail(bancaiId) { const dataManager = window.parent.dataManager; if (!dataManager) return; const bancais = dataManager.data.bancais || []; const bancai = bancais.find(b => b.id === bancaiId); const kucun = dataManager.data.kucuns?.find(k => k.bancai?.id === bancaiId); if (!bancai) { alert('未找到板材信息'); return; } // 格式化木皮信息 const formatMupiDetail = (mupi) => { if (!mupi) return '无'; return `${mupi.name}${mupi.you ? '()' : ''}`; }; // 获取相关订单 const relatedOrders = getRelatedOrders(bancai); // 构建详情HTML const detailHtml = ` <div class="row mb-3"> <div class="col-md-6"> <h5>基本信息</h5> <ul class="list-group"> <li class="list-group-item"><strong>ID:</strong> ${bancai.id}</li> <li class="list-group-item"><strong>材质:</strong> ${bancai.caizhi?.name || '未知'}</li> <li class="list-group-item"><strong>厚度:</strong> ${bancai.houdu ? bancai.houdu.toFixed(1) + 'mm' : '未知'}</li> <li class="list-group-item"><strong>库存数量:</strong> ${kucun ? kucun.shuliang : 0}</li> </ul> </div> <div class="col-md-6"> <h5>表面处理</h5> <ul class="list-group"> <li class="list-group-item"><strong>木皮1:</strong> ${formatMupiDetail(bancai.mupi1)}</li> <li class="list-group-item"><strong>木皮2:</strong> ${formatMupiDetail(bancai.mupi2)}</li> </ul> </div> </div> <div class="mt-3"> <h5>相关订单 (${relatedOrders.length})</h5> <div class="table-responsive"> <table class="table table-sm table-hover"> <thead> <tr> <th>订单号</th> <th>下单日期</th> <th>交货日期</th> </tr> </thead> <tbody> ${relatedOrders.map(order => ` <tr> <td>${order.number}</td> <td>${order.xiadan ? new Date(order.xiadan).toLocaleDateString() : '-'}</td> <td>${order.jiaohuo ? new Date(order.jiaohuo).toLocaleDateString() : '-'}</td> </tr> `).join('')} </tbody> </table> </div> </div> `; // 设置模态框内容 $('#materialDetailContent').html(detailHtml); // 显示模态框 const materialModal = new bootstrap.Modal('#materialDetailModal'); materialModal.show(); } // 获取板材相关订单 function getRelatedOrders(bancai) { const dataManager = window.parent.dataManager; if (!dataManager) return []; const orders = []; const dingdan_bancais = dataManager.data.dingdan_bancais || []; // 查找直接订单组件关联 dingdan_bancais.forEach(db => { if (db.bancai?.id === bancai.id && db.dingdan && !orders.some(o => o.id === db.dingdan.id)) { orders.push(db.dingdan); } }); // 查找产品组件关联 const chanpin_zujians = dataManager.data.chanpin_zujians || []; chanpin_zujians.forEach(cz => { if (cz.bancai?.id === bancai.id) { const dingdan_chanpins = dataManager.data.dingdan_chanpins || []; dingdan_chanpins.forEach(dc => { if (dc.chanpin?.id === cz.chanpin?.id && dc.dingdan && !orders.some(o => o.id === dc.dingdan.id)) { orders.push(dc.dingdan); } }); } }); return orders; } // 页面加载时尝试初始化 if (window.parent) { window.parent.postMessage('RequestDataManager', '*'); } // 添加全局函数供按钮调用 window.showMaterialDetail = showMaterialDetail; 详情中关联订单添加排序并去重,在一个加一个上下滚动
最新发布
06-30
// 监听来自父窗口的消息 window.addEventListener('message', function(event) { if (event.source === window.parent && event.data === 'DataManagerReady') { initializeDataManager(); } }); // 初始化数据管理器 function initializeDataManager() { const dataManager = window.parent.dataManager; if (dataManager) { // 注册数据刷新回调 dataManager.registerCallback('all', function(operation, entity, data) { updatePageData(dataManager); }); // 初始页面数据更新 updatePageData(dataManager); // 设置搜索功能 setupSearch(dataManager); } else { console.error('DataManager not available'); } } // 更新页面数据 function updatePageData(dataManager) { updateStats(dataManager); updateTable(dataManager); document.getElementById('lastUpdate').textContent = new Date().toLocaleTimeString(); } // 更新统计卡片数据 function updateStats(dataManager) { const data = dataManager.data; document.getElementById('orderCount').textContent = data.dingdans?.length || 0; document.getElementById('productCount').textContent = data.chanpins?.length || 0; document.getElementById('materialCount').textContent = data.bancais?.length || 0; const totalStock = data.kucuns?.reduce((sum, kucun) => sum + kucun.shuliang, 0) || 0; document.getElementById('totalStock').textContent = totalStock; } // 更新结果表格 function updateTable(dataManager) { const tableBody = document.getElementById('resultBody'); tableBody.innerHTML = ''; const data = dataManager.data; const results = []; let resultCount = 0; // 处理订单产品数据 if (data.dingdan_chanpins) { data.dingdan_chanpins.forEach(dc => { if (!dc.dingdan || !dc.chanpin) return; if (dc.chanpin.chanpin_zujians) { dc.chanpin.chanpin_zujians.forEach(cz => { if (!cz.zujian || !cz.bancai) return; const bancai = cz.bancai; const materialInfo = getMaterialInfo(bancai); const stockQuantity = bancai.kucun?.shuliang || 0; results.push({ orderNumber: dc.dingdan.number, productInfo: dc.chanpin.bianhao, productQuantity: dc.shuliang, component: cz.zujian.name, material: materialInfo, materialPerComponent: cz.one_howmany, materialOrderQuantity: dc.shuliang * cz.one_howmany, stockQuantity: stockQuantity, operation: `<button class="btn btn-sm btn-outline-primary" onclick="showMaterialDetail(${bancai.id})">详情</button>` }); resultCount++; }); } }); } // 处理直接订单组件数据 if (data.dingdan_chanpin_zujians) { data.dingdan_chanpin_zujians.forEach(dcz => { if (!dcz.dingdan || !dcz.chanpin_zujian || !dcz.chanpin_zujian.zujian || !dcz.bancai) return; const bancai = dcz.bancai; const materialInfo = getMaterialInfo(bancai); const stockQuantity = bancai.kucun?.shuliang || 0; results.push({ orderNumber: dcz.dingdan.number, productInfo: dcz.chanpin_zujian.chanpin?.bianhao || '独立组件', productQuantity: dcz.shuliang, component: dcz.chanpin_zujian.zujian.name, material: materialInfo, materialPerComponent: dcz.chanpin_zujian.one_howmany, materialOrderQuantity: dcz.shuliang * dcz.chanpin_zujian.one_howmany, stockQuantity: stockQuantity, operation: `<button class="btn btn-sm btn-outline-primary" onclick="showMaterialDetail(${bancai.id})">详情</button>` }); resultCount++; }); } // 填充表格 if (resultCount > 0) { document.getElementById('noResults').style.display = 'none'; results.forEach(row => { const tr = document.createElement('tr'); tr.innerHTML = ` <td>${row.orderNumber}</td> <td>${row.productInfo}</td> <td>${row.productQuantity}</td> <td>${row.component}</td> <td>${row.material}</td> <td>${row.materialPerComponent}</td> <td>${row.materialOrderQuantity}</td> <td>${row.stockQuantity}</td> <td>${row.operation}</td> `; tableBody.appendChild(tr); }); } else { document.getElementById('noResults').style.display = 'flex'; } document.getElementById('resultCount').textContent = resultCount; } // 获取板材详细信息函数(添加油状态) function getMaterialInfo(bancai) { if (!bancai) return '未知板材'; // 获取材质名称 const caizhiName = bancai.caizhi?.name || '未知材质'; // 获取木皮信息(添加油状态) const formatMupi = (mupi) => { if (!mupi) return null; return `${mupi.name}${mupi.you ? '()' : ''}`; }; const mupi1Str = formatMupi(bancai.mupi1) || '无'; const mupi2Str = formatMupi(bancai.mupi2) || '无'; const mupiInfo = mupi1Str + (mupi2Str !== '无' ? `/${mupi2Str}` : ''); // 厚度转换为字符串 const thickness = bancai.houdu ? `${bancai.houdu.toFixed(1)}mm` : '未知厚度'; return `${caizhiName} - ${mupiInfo} (${thickness})`; } // 设置搜索功能(添加油状态搜索) function setupSearch(dataManager) { // 订单搜索 $('#orderSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 0); }); // 产品搜索 $('#productSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 1); }); // 板材材质搜索 $('#materialSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 4); }); // 木皮搜索(添加油状态搜索) $('#woodSearch').on('input', function() { const searchTerm = $(this).val().toLowerCase(); // 支持中文和数字搜索 const searchKeywords = { '有油': '有油', '无油': '无油', 'you': '有油', 'wu': '无油', '1': '有油', '0': '无油' }; const actualTerm = searchKeywords[searchTerm] || searchTerm; filterTable(actualTerm, 4); }); // 厚度搜索(字符串匹配) $('#thicknessSearch').on('input', function() { filterTable($(this).val().toLowerCase(), 4); }); // 库存状态搜索 $('#stockStatusBtn').click(function() { const minStock = parseInt($('#minStock').val()) || 0; const maxStock = parseInt($('#maxStock').val()) || Number.MAX_SAFE_INTEGER; filterByStock(minStock, maxStock); }); } // 表格过滤函数(支持油状态搜索) function filterTable(searchTerm, columnIndex) { const rows = $('#resultBody tr'); let visibleCount = 0; rows.each(function() { const cellText = $(this).find(`td:eq(${columnIndex})`).text().toLowerCase(); let isMatch = false; // 特殊处理油状态搜索 if (searchTerm === '有油' || searchTerm === '无油') { isMatch = cellText.includes(searchTerm); } // 处理厚度字符串匹配 else if (columnIndex === 4 && !isNaN(parseFloat(searchTerm))) { // 提取厚度数字部分进行匹配 const thicknessMatch = cellText.match(/$(\d+\.?\d*)mm$/); if (thicknessMatch) { const thicknessValue = parseFloat(thicknessMatch[1]); const searchValue = parseFloat(searchTerm); // 允许小数点误差 isMatch = Math.abs(thicknessValue - searchValue) < 0.1; } } // 常规文本匹配 else { isMatch = cellText.includes(searchTerm); } $(this).toggle(isMatch); if (isMatch && searchTerm) { $(this).addClass('highlight'); } else { $(this).removeClass('highlight'); } if (isMatch) visibleCount++; }); document.getElementById('resultCount').textContent = visibleCount; document.getElementById('noResults').style.display = visibleCount > 0 ? 'none' : 'flex'; } // 按库存量过滤 function filterByStock(minStock, maxStock) { const rows = $('#resultBody tr'); let visibleCount = 0; rows.each(function() { const stockCell = $(this).find('td:eq(7)').text(); const stockValue = parseInt(stockCell) || 0; const isMatch = stockValue >= minStock && stockValue <= maxStock; $(this).toggle(isMatch); if (isMatch) visibleCount++; }); document.getElementById('resultCount').textContent = visibleCount; document.getElementById('noResults').style.display = visibleCount > 0 ? 'none' : 'flex'; } // 显示板材详情(添加油状态显示) function showMaterialDetail(bancaiId) { const dataManager = window.parent.dataManager; if (!dataManager) return; const bancais = dataManager.data.bancais || []; const bancai = bancais.find(b => b.id === bancaiId); if (!bancai) { alert('未找到板材信息'); return; } // 格式化木皮信息(添加油状态) const formatMupiDetail = (mupi) => { if (!mupi) return '无'; return `${mupi.name} (${mupi.you ? '有油' : '无油'})`; }; // 构建详情信息 const detailHtml = ` <div class="material-detail"> <h4>板材详情 (ID: ${bancai.id})</h4> <p><strong>材质:</strong> ${bancai.caizhi?.name || '未知'}</p> <p><strong>厚度:</strong> ${bancai.houdu ? bancai.houdu.toFixed(1) + 'mm' : '未知'}</p> <p><strong>木皮1:</strong> ${formatMupiDetail(bancai.mupi1)}</p> <p><strong>木皮2:</strong> ${formatMupiDetail(bancai.mupi2)}</p> <p><strong>库存数量:</strong> ${bancai.kucun?.shuliang || 0}</p> <div class="related-orders"> <h5>相关订单:</h5> <ul> ${getRelatedOrders(bancai).map(order => `<li>订单 ${order.number} (ID: ${order.id})</li>` ).join('') || '<li>无相关订单</li>'} </ul> </div> </div> `; // 显示详情(实际项目中可用模态框) const detailWindow = window.open('', '_blank', 'width=600,height=400'); detailWindow.document.write(` <!DOCTYPE html> <html> <head> <title>板材详情</title> <style> body { font-family: Arial, sans-serif; padding: 20px; } .material-detail { max-width: 500px; } h4 { color: #2c3e50; border-bottom: 2px solid #3498db; padding-bottom: 10px; } p { margin: 10px 0; } .related-orders { margin-top: 20px; } ul { list-style-type: none; padding: 0; } li { padding: 5px 0; border-bottom: 1px solid #eee; } </style> </head> <body> ${detailHtml} </body> </html> `); detailWindow.document.close(); } // 获取板材相关订单 function getRelatedOrders(bancai) { const dataManager = window.parent.dataManager; if (!dataManager) return []; const orders = []; const dingdan_chanpin_zujians = dataManager.data.dingdan_chanpin_zujians || []; // 查找直接订单组件关联 dingdan_chanpin_zujians.forEach(dcz => { if (dcz.bancai?.id === bancai.id && dcz.dingdan && !orders.some(o => o.id === dcz.dingdan.id)) { orders.push(dcz.dingdan); } }); // 查找产品组件关联 const chanpin_zujians = dataManager.data.chanpin_zujians || []; chanpin_zujians.forEach(cz => { if (cz.bancai?.id === bancai.id) { const dingdan_chanpins = dataManager.data.dingdan_chanpins || []; dingdan_chanpins.forEach(dc => { if (dc.chanpin?.id === cz.chanpin?.id && dc.dingdan && !orders.some(o => o.id === dc.dingdan.id)) { orders.push(dc.dingdan); } }); } }); return orders; } // 页面加载时尝试初始化 if (window.parent) { window.parent.postMessage('RequestDataManager', '*'); } // 添加全局函数供按钮调用 window.showMaterialDetail = showMaterialDetail; 厚度搜索没有用,加入每列排序
06-20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值