代码在Firefox中工作正常,但在chrome中不起作用。为什么?

时间:2016-03-27 10:56:05

标签: javascript jquery html rest

在我的网络应用程序中,我在函数中使用了以下代码。当我在Firefox中执行代码时它工作正常并给我输出。但是当我在chrome中执行相同的代码时,函数进入无限循环并返回(它不会抛出任何异常或错误)。

信息: elem是一个xml元素而不是html元素;并且xml是SVG图像

守则是这样的:

函数调用:

buildElemView(viewElement, container, 1, viewType);

然后是功能:

function buildElemView(elem, container, start, viewType){

        var vwType = viewType;

        var cat = $(elem).find('cat:first').text();
                //alert("cat is "+cat);
        var type = $(elem).find('type:first').text();
        var id = $(elem).find('eid:first').text();
        var mid = $(elem).find('mid:first').text();

        var parentMids = $(elem).parents().map(function () {
              return $(this).find('mid:first').text();
            })
        .get().reverse().join("");

        if (viewType==1 && Number(eleCat>60) && Number(cat)<40)    
            return;

        var parentElementId = parentMids;
        var elementGroupId = parentMids+mid;

        var grp = $(elem).find('gr:first').text();

        var cz = $(elem).find('cz:first').text();

        var zo = $(elem).find('zo:first').text();
        var yo = $(elem).find('yo:first').text();


        var rotate = ($(elem).find('rt:first').text().split(';'))[0];
        var scale = ($(elem).find('sc:first').text().split(';'))[0];
        var positionx = ($(elem).find('px:first').text().split(';'))[0];
        var positiony = ($(elem).find('py:first').text().split(';'))[0];
        var positionz = ($(elem).find('pz:first').text().split(';'))[0];
        var dimension = $(elem).find('dm:first').text();
        var parentdimension = $(elem).parent().find('dm:first').text();
        var parentheight=0;
        if (parentdimension !='')
            parentheight = (parentdimension.split(';'))[2];
        if (parentheight==undefined || parentheight=="null")
            parentheight =0;

        var height = 0;
        if (dimension !='')
            height = (dimension.split(';'))[2];
        if (height==undefined || height=="null")
            height =0;


        var transformStr = "";

        var num =0;
        if (start && start==1)
        {
            transformStr= "translate(0,0) rotate(0) scale(1,1)";
            if (viewType==1 && Number(eleCat)<100) {
                var px = 0;
                var py = 0;
                if (scaleX==-1) px = 15000;
                if (scaleY==-1) py = 15000;

                transformStr = "translate("+ px+","+py +") rotate(0) scale("+ scaleX+","+scaleY+ ")";
            }

            if (Number(type)==50 || Number(type)==80 || Number(type)==100)
                vwType=4;
        }
        else {
            if (viewType<3 || Number(cat)>40)
                {
                   if (viewType==2) {

                       var px = positionx;
                       var py = positiony;
                       var pz = positionz;

                        if (parentheight)
                            positiony = Number(parentheight)-Number(positionz)-Number(height);

}


//And there is a lot of Code here but its not even executing the entire code //strightly coming to alert box after clicking debug stepover.

}

功能太大我只能给你这么多......

但通过调试问题发生在这里......

var cat = $(elem).find('cat:first').text();
var type = $(elem).find('type:first').text();
var id = $(elem).find('eid:first').text();
var mid = $(elem).find('mid:first').text();

我在他们之间发出警告信息后得出结论。

var cat = $(elem).find('cat:first').text();
var type = $(elem).find('type:first').text();
alert("Alert");
var id = $(elem).find('eid:first').text();
var mid = $(elem).find('mid:first').text();

在firefox警报中显示一次,所有行都被执行并返回。但在Chrome中,警报仍在继续。它没有执行前两行,最后两行只执行警报而且执行起来太持续了。

信息:这在Chrome版本47中运行良好,但在更新后现在无法在版本49中使用。

请帮助解决为什么这种奇怪的Chrome行为。

1 个答案:

答案 0 :(得分:0)

我有一个monte前的相关问题,我解决了它在调用后编写函数的定义