js:循环查询数组对象中的某一项的值是否为空

循环检查 selinfo 数组中的每一个对象,判断其中的 po_qtyprice 是否为空(nullundefined 或空字符串 ""),可以使用以下几种方法:


方法1:使用 forEach 循环检查每一项

javascript 复制代码
const selinfo = this.data.selinfo;

selinfo.forEach((item, index) => {
  if (!item.po_qty || !item.price) {
    console.log(`第 ${index + 1} 项数据不完整:`, item);
    // 可以在这里处理不符合条件的数据
  }
});

判断逻辑

  • !item.po_qty → 检查 po_qty 是否为 nullundefined0""

  • !item.price → 检查 price 是否为 nullundefined0""

如果你希望 严格判断空值(仅 nullundefined,可以改成:

javascript 复制代码
if (item.po_qty == null || item.price == null) {
  console.log(`第 ${index + 1} 项数据为空:`, item);
}

方法2:使用 some() 检查是否有任意一项为空

javascript 复制代码
const hasEmptyData = selinfo.some(item => !item.po_qty || !item.price);

if (hasEmptyData) {
  console.log("存在数据不完整的项");
} else {
  console.log("所有数据完整");
}

方法3:使用 filter() 获取所有不完整的数据

javascript 复制代码
const incompleteItems = selinfo.filter(item => !item.po_qty || !item.price);

if (incompleteItems.length > 0) {
  console.log("以下数据不完整:", incompleteItems);
} else {
  console.log("所有数据完整");
}

方法4:使用 map() 返回检查结果

javascript 复制代码
const checkResults = selinfo.map(item => ({
  ...item,
  isValid: item.po_qty != null && item.price != null,
}));

console.log("检查结果:", checkResults);

输出示例:

javascript 复制代码
[
  { id: 1, po_qty: 10, price: 100, isValid: true },
  { id: 2, po_qty: null, price: 50, isValid: false },
  { id: 3, po_qty: 5, price: null, isValid: false }
]

严格判断空值(排除 0""

如果 po_qtyprice 可能是 0 或空字符串 "",但你仍然希望它们是有效值,可以这样判断:

javascript 复制代码
const isInvalid = (value) => value === null || value === undefined;

selinfo.forEach(item => {
  if (isInvalid(item.po_qty) || isInvalid(item.price)) {
    console.log("该项数据不合法:", item);
  }
});

扩展

判断数据项中某两项的数据和另一项的数据比

判断selinfo数组中,子项now_qty与reject_qty的和是否小于inv_qty

javascript 复制代码
const isRowValid = selinfo.every(row =>
  (row.now_qty || 0) + (row.reject_qty || 0) <= (row.inv_qty || 0)
);
if (!isRowValid) {
  wx.showToast({
    title: '输入数量请小于库存量!',
    icon: 'none'
  });
  return;
}

总结

方法 适用场景 返回值 推荐度
forEach 遍历并检查每一项 无返回值,可执行操作 推荐
some 只想知道是否有空数据 true / false
filter 获取所有不完整的数据 数组 ⚠️ 适用于需要具体数据时
map 返回检查结果 新数组 ⚠️ 适用于需要标记数据时

推荐方案

  • 如果只是检查是否有空数据some()

  • 如果需要获取哪些数据为空filter()

  • 如果需要遍历并处理空数据forEach

相关推荐
mCell15 小时前
GSAP ScrollTrigger 详解
前端·javascript·动效
gnip15 小时前
Node.js 子进程:child_process
前端·javascript
excel18 小时前
为什么在 Three.js 中平面能产生“起伏效果”?
前端
excel19 小时前
Node.js 断言与测试框架示例对比
前端
天蓝色的鱼鱼21 小时前
前端开发者的组件设计之痛:为什么我的组件总是难以维护?
前端·react.js
codingandsleeping21 小时前
使用orval自动拉取swagger文档并生成ts接口
前端·javascript
石金龙1 天前
[译] Composition in CSS
前端·css
白水清风1 天前
微前端学习记录(qiankun、wujie、micro-app)
前端·javascript·前端工程化
Ticnix1 天前
函数封装实现Echarts多表渲染/叠加渲染
前端·echarts
用户22152044278001 天前
new、原型和原型链浅析
前端·javascript