const value=this.personneInfo.pricingDetailBo.every(ele=>{ if (ele.isExceeded) { return ele.selected && ele.selectedItem && ele.selectedItem.length<0 } }) 如何判断有isExceeded才进行判断 它的selectedItem 数组不为空
时间: 2024-04-13 10:30:59 浏览: 167
你可以使用条件语句来判断是否满足条件。首先,你需要检查`isExceeded`的值是否为true,然后再判断`selectedItem`数组是否不为空。可以使用以下代码实现:
```javascript
const value = this.personneInfo.pricingDetailBo.every(ele => {
if (ele.isExceeded) {
return ele.selected && ele.selectedItem && ele.selectedItem.length > 0;
}
return true;
});
```
这样,只有当`isExceeded`为true时,才会判断`selectedItem`数组是否不为空。如果满足条件,返回true,否则返回false。
相关问题
findOverrideMapId = async (overrides: CaseOverrideInfo[]) => { let page = 1; const pageSize = 40; let mapIdTowardIndex = -1; let foundAllOverrides = overrides.length; while (page && foundAllOverrides) { const batchMaps = await this.getMaps(page, pageSize); for (const item of overrides) { if (item.missingMap && !item.overrideMapId) { const mapIdTowardId = batchMaps.items.find((ele) => ele?.name === item.mapId)?.id; mapIdTowardIndex = batchMaps.items.findIndex((ele) => ele?.name === item.mapId) + (page - 1) * pageSize; item.overrideMapId = mapIdTowardId || ""; item.initialPage = Math.ceil(mapIdTowardIndex / (pageSize + 2)); if (item.overrideMapId) --foundAllOverrides; } } page++; if (!batchMaps || batchMaps.items.length < pageSize) { break; } } return overrides; }; 有点问题,我希望overrides对象找一遍后尽量减少时间复杂度。
要尽量减少时间复杂度,可以考虑使用一个哈希表来存储已经处理过的 `mapId`,避免重复查找。以下是修改后的代码示例:
```javascript
findOverrideMapId = async (overrides: CaseOverrideInfo[]) => {
let page = 1;
const pageSize = 40;
let mapIdTowardIndex = -1;
const processedMapIds = new Set();
let foundAllOverrides = overrides.length;
while (page && foundAllOverrides) {
const batchMaps = await this.getMaps(page, pageSize);
for (const item of overrides) {
if (item.missingMap && !item.overrideMapId && !processedMapIds.has(item.mapId)) {
const mapIdTowardId = batchMaps.items.find((ele) => ele?.name === item.mapId)?.id;
mapIdTowardIndex =
batchMaps.items.findIndex((ele) => ele?.name === item.mapId) + (page - 1) * pageSize;
item.overrideMapId = mapIdTowardId || "";
item.initialPage = Math.ceil(mapIdTowardIndex / (pageSize + 2));
if (item.overrideMapId) {
--foundAllOverrides;
processedMapIds.add(item.mapId);
}
}
}
page++;
if (!batchMaps || batchMaps.items.length < pageSize) {
break;
}
}
return overrides;
};
```
在这个示例中,我们使用 `processedMapIds` 哈希表来存储已经处理过的 `mapId`,通过 `has()` 方法来判断是否已经处理过。如果已经处理过,就跳过当前循环。这样可以避免重复查找和处理相同的 `mapId`,从而减少时间复杂度。
请注意,这只是一种优化的方式,具体的实现可能需要根据您的代码逻辑进行调整。
findOverrideMapId = async (overrides: CaseOverrideInfo[]) => { const allMapsList = []; let page = 1; const pageSize = 40; while (page) { const batchMaps = await this.getMaps(page, pageSize); allMapsList.push(...batchMaps.items); page++; if (!batchMaps || batchMaps.items.length < pageSize) { break; } } let mapIdTowardIndex = -1; for (const item of overrides) { if (item.missingMap) { const mapIdTowardId = allMapsList.find((ele) => ele?.name === item.mapId)?.id; mapIdTowardIndex = allMapsList.findIndex((ele) => ele?.name === item.mapId); item.overrideMapId = mapIdTowardId || ""; } } this.setState({ initialPage: Math.ceil(mapIdTowardIndex / (pageSize + 2)) }); return overrides; }; 我想改一下逻辑,不用获取所有列表allMapsList。接口一找到就返回并且停止,并且还有序号需要正确
您想改变逻辑,不再获取所有的列表allMapsList,并且在找到匹配项后立即返回,并且确保序号正确。以下是您修改后的代码:
```javascript
findOverrideMapId = async (overrides: CaseOverrideInfo[]) => {
let mapIdTowardIndex = -1;
for (const [index, item] of overrides.entries()) {
if (item.missingMap) {
const batchMaps = await this.getMaps(1, index + 1); // 获取对应位置的地图项
const mapIdTowardId = batchMaps.items.find((ele) => ele?.name === item.mapId)?.id;
mapIdTowardIndex = batchMaps.items.findIndex((ele) => ele?.name === item.mapId);
item.overrideMapId = mapIdTowardId || "";
break; // 找到匹配项后立即停止循环
}
}
this.setState({ initialPage: Math.ceil(mapIdTowardIndex / (pageSize + 2)) });
return overrides;
};
```
这样修改后的代码会在找到第一个匹配项后立即停止循环,并且使用正确的序号进行处理。注意,我假设您的`getMaps`方法会根据提供的页码和页面大小返回对应位置的地图项。
阅读全文