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

相关推荐
手握风云-几秒前
JavaEE初阶第九期:解锁多线程,从 “单车道” 到 “高速公路” 的编程升级(七)
java·开发语言
杨荧7 分钟前
基于大数据的旅游推荐系统 Python+Django+Hive+Vue.js
大数据·前端·vue.js·hive·python·开源·旅游
大飞pkz10 分钟前
【设计模式&C#】工厂方法模式(相比简单工厂模式更加具有灵活性和扩展性的工厂模式)
开发语言·设计模式·c#·工厂方法模式
爱编程的喵16 分钟前
前端Mock数据指南:从零到一的全栈开发实战
javascript·全栈
long_mingyue19 分钟前
JavaScript 对象操作、继承与模块化实现
javascript·原型模式·xss
挖三填一19 分钟前
原型与原型链详解
前端·javascript
iaku22 分钟前
🔥React性能优化全攻略:剖析、工具与实战策略
前端·javascript·react.js
qiyue7722 分钟前
AI编程专栏(六)-前端必用MCP推荐
前端·ai编程·mcp
轻语呢喃23 分钟前
forwardRef :打破函数组件封装限制的技巧
javascript·react.js
x_SpiderMan23 分钟前
XSS原型与原型链
前端·原型模式·xss