我应该在哪里用javascript存储我的窗口维度

Where should I store my window dimensions in javascript?

本文关键字:窗口 我的 存储 在哪里 javascript 我应该      更新时间:2023-09-26

我会根据所选项目的类型弹出不同大小的Telerik RadWindows。每种类型的项目都有自己的编辑表单,点击时会弹出,所以我需要在Javascript中设置不同的窗口高度和宽度。现在我正在使用这个函数,它有每种类型的硬编码尺寸:

 function GetEditWindowDimensions(type) {
        var dimensions = null;           
        switch (type) {
            case 'Type1':
                dimensions = { length: 330, width: 400 };
                break
            case 'Type2':     
                dimensions = { length: 550, width: 450 };
                break;
            case 'Type2':
                dimensions = { length: 260, width: 400 };
                break;    
            case 'Type3':    
                dimensions = { length: 260, width: 400 };
                break;
            case 'Type4':
                dimensions = { length: 260, width: 400 };
                break;
            case 'Type5':
                dimensions = { length: 330, width: 400 };
                break;
            default:
                dimensions = { length: 500, width: 500 };
        }
        return dimensions
    }

这是我加载RadWindow的函数:

   function OpenEditWindow(type) {
        var oDimensions = GetEditWindowDimensions(type)
        var oWindow = openWindow('myurl.aspx', oDimensions.length, oDimensions.width, true);
        oWindow.MoveTo(200, 25);
    }

必须有更好的方法来做到这一点。你对我如何在Javascript中以可配置的方式存储/检索这些维度有什么想法吗?类型本身由项目中.vb文件中的枚举定义。我将枚举值名称传递给GetEditWindowDimensions()。

提前感谢!

您可以将其存储在一个对象中,例如:

    var dimensions = {
        'Type1': { length: 330, width: 400 },
        'Type2': { length: 550, width: 450 },
        'Type3': { length: 260, width: 400 }
    }

然后像一样访问它们

dimensions.type1.length; // <-- 330
dimensions.type1.width; // <-- 400

为什么不创建一个哈希?

var dWindowDimensions = }
    Type1: { length: 330, width: 400 },
    Type2: { length: 550, width: 450 },
    ...
}

然后,当您需要读取值时:

var oDimensions = dWindowDimensions[type]

只需像这样存储它们:

dimensions = {
    Type1: {
        length: 330,
        width: 400
    },
    ...
    ...
    Type5:  {
        length: 330,
        width: 400
    }
};

然后,如果您正在动态查找它们,则可以通过执行dimensions.Type1dimensions[type]来访问它们。对于默认情况,只需检查您尝试访问的维度是否为undefined。如果是,请使用默认的长度和宽度。例如:

var dimension = dimensions[type];
if(typeof dimension === "undefined") {
    dimension = {
        length: 500,
        width: 500 
    };
}

或者更简洁:

var dimension = dimensions[type] || {length: 500, width: 500};

如果第一个值不是"truthy",则将使用第二个值(||之后的值)。