简单的if语句在NodeJS中不起作用

时间:2013-02-07 23:00:38

标签: javascript node.js

我写了一个NodeJS应用程序,它使用eBay API从eBay获取列表。我有一个问题,即某些项目正在通过,即使它们应该用简单的if语句过滤掉。

应用程序从前端接收后期数据作为JSON,执行每次搜索,然后根据某些参数过滤掉项目。这是违规代码:

if ( items[i].listingInfo.listingType != 'Auction' ) {
    //console.log( items[i].listingInfo.listingType );

    if ( items[i].primaryCategory.categoryId == '9355' ) {
        //console.log( items[i].primaryCategory.categoryId );

        if ( price < maxPrice && price > 40 ) {
            //console.log( price, maxPrice );
            file =  path + 
                    items[i].itemId + '-' + 
                    price + '-' + maxPrice + '-' + 
                    items[i].primaryCategory.categoryId + '-' + 
                    items[i].listingInfo.listingType;

            if ( !fs.existsSync( file ) ) {
                console.log(
                    'File ' + file + ' does not exist.', 
                    !fs.existsSync( file ), 
                    items[i].listingInfo.listingType, 
                    price < maxPrice,
                    items[i].itemId
                );

                fs.writeFile( file, ' ', function(err) {
                    if (err) {
                        if (debug)
                            console.log('Writing ' + file + ' failed.');
                    }
                    else {
                        if (debug)
                            console.log('Writing ' + file + ' worked.');      
                        returnData.success = true;
                        returnData.results[ result.itemId ] = result;
                        console.log( price, maxPrice, !fs.existsSync( file ) );
                        console.log('success');
                    }
                })
            }
            else {
                returnData.discard.file[ result.itemId ] = result;
                delete returnData.results[ result.itemId ];
            }

        }
        else {
            returnData.discard.price[ result.itemId ] = result;
            if (debug)
                console.log('FAILED (price): ' + items[i].itemId + ' is ' + ( price - maxPrice ) + ' greater than maxPrice.');
        }
    }
    else {
        returnData.discard.cat[ result.itemId ] = result;
        if (debug)
            console.log('FAILED (categoryId): ' + items[i].itemId + ' is ' + items[i].primaryCategory.categoryId);
    }                    
}
else {
    returnData.discard.type[ result.itemId ] = result;
    if (debug)
        console.log('FAILED (listingType): ' + items[i].itemId + ' is a ' + items[i].listingInfo.listingType);                
}

您可以看到此行if ( price < maxPrice && price > 40 )应过滤掉任何大于maxPrice且低于40的项。但是,它不会执行此操作。我不知道为什么会发生这种情况以及这里发生了什么。看起来非常简单明了,但事实并非如此。这是返回的对象,您可以看到它无法正常工作。

111004318957:
    listingType: "FixedPrice"
    maxPrice: 170
    price: 349

我也在使用节点集群,所以我的server.js文件包含:

    function start(route, handle) {
        if ( cluster.isMaster ) {

            for ( var i = 0; i < numCPUs; i++ ) {
                cluster.fork();
            }

            cluster.on('exit', function( worker, code, signal) {
                console.log( 'worker ' + worker.process.pid + ' died' );
            })
        }
        else {
            function onRequest(request, response) {
                var postData = "";
                var pathname = url.parse(request.url).pathname;

                request.setEncoding("utf8");
                request.addListener("data", function(postDataChunk) {
                    postData += postDataChunk;
                });
                request.addListener("end", function() {
                    //console.log('Request ended.');
                    if ( postData != '' ) {
                        postData = JSON.parse(postData);
                    }
                    //console.log(postData.search.searches[0]);
                    route(handle, pathname, response, postData);
                });
            }
            http.createServer(onRequest).listen(8888);
            console.log("Server has started.");
        }
    }

感谢所有的帮助,谢谢。

编辑:我应该解释说111004318957是eBay返回的itemId。结果对象如下所示:

results: {
    itemId1: {
        listingType: '',
        maxPrice: '',
        price: ''
    },
    itemId2: {
        listingType: '',
        maxPrice: '',
        price: ''
    }
}

编辑2: price在此代码段之前设置。它在eBay的响应中返回,它的位置依赖于items [i] .listingInfo.listingType,所以有一个简单的if / else来设置它。

if ( items[i].listingInfo.listingType == 'AuctionWithBIN' ) {
    price = parseInt( items[i].listingInfo.buyItNowPrice.USD );
}
else {
    price = parseInt( items[i].sellingStatus.currentPrice.USD );
}

2 个答案:

答案 0 :(得分:0)

JSON返回listingType,maxPrice,price。

尝试if (items[i].price < maxPrice && items[i].price > 40)

答案 1 :(得分:0)

作者几乎肯定不能对这个问题做出任何贡献,以澄清我的说法是否正确,就像六年前的要求一样。

但是,可以肯定的是,问题与代码的以下部分有关:

$1

fs.writeFile( file, ' ', function(err) { if (err) { if (debug) console.log('Writing ' + file + ' failed.'); } else { if (debug) console.log('Writing ' + file + ' worked.'); returnData.success = true; returnData.results[ result.itemId ] = result; console.log( price, maxPrice, !fs.existsSync( file ) ); console.log('success'); } }) 是异步的,并且如果OP循环遍历结果列表,则fs.writeFile中的result将始终引用循环的最后一个元素,无论是否元素是否符合条件returnData.results[ result.itemId ] = result