根据首选项绘制用户界面

时间:2008-12-06 11:03:19

标签: javascript firefox xul preferences xulrunner

我想为xulrunner(Firefox)应用程序使用内置首选项系统。但我无法弄清楚如何根据偏好轻松驱动用户界面。

用户可以指定主页列表,每个主页将显示在不同的选项卡中。因为选项卡位于表示层中,所以我想在xul代码中使用模板创建它们。这可能吗?

我还没有看到使用xul模板执行此操作的方法。是否有替代模板系统允许我根据用户偏好更改UI?

2 个答案:

答案 0 :(得分:1)

不,XUL中的模板功能不够强大,因此您不得不编写读取首选项的JavaScript代码并打开所需的选项卡。

答案 1 :(得分:0)


XML.prototype.function::domNode = function domNode() {
    function addPrefix(prefix, name) {
        if (typeof(prefix) == "undefined" || prefix == null || prefix == "") {
            return name;
        } else {
            return prefix + ":" + name;
        }
    }

    function recurse(xml) {
        var domNode = document.createElementNS(xml.namespace().uri, addPrefix(xml.namespace().prefix, xml.localName()));

        for each (let attr in xml.@*::*) {
            let attrNode = document.createAttributeNS(attr.namespace().uri, addPrefix(attr.namespace().prefix, attr.localName()));
            attrNode.nodeValue = attr;
            domNode.setAttributeNode(attrNode);
        }
        if (xml.hasComplexContent()) {
            for each (let node in xml.*) {
                domNode.appendChild(recurse(node));
            }
        } else if (xml.hasSimpleContent()) {
            domNode.appendChild(document.createTextNode(xml));
        }
        return domNode;
    }

    return recurse(this);
};

var name = "example"
var xml = {name};

document.querySelector("#example-statusbar-panel").appendChild(xml.domNode());

可以作为一个魅力,但是有一些关于名称空间的小故障。

您总是可以使用

将dom转换回XML
var str = serializer.serializeToString( xml.domNode() );