我想爲我的xulrunner(Firefox)應用程序使用內置的首選項系統。但我不知道如何根據偏好輕鬆地驅動用戶界面。根據偏好繪製用戶界面
用戶可以指定主頁列表,每個主頁將顯示在不同的選項卡中。由於選項卡位於表示層,因此我想使用xul代碼中的模板創建它們。這可能嗎?
我還沒有看到用xul模板做這件事的方法。有沒有其他的模板系統可以讓我根據用戶的喜好來改變用戶界面?
我想爲我的xulrunner(Firefox)應用程序使用內置的首選項系統。但我不知道如何根據偏好輕鬆地驅動用戶界面。根據偏好繪製用戶界面
用戶可以指定主頁列表,每個主頁將顯示在不同的選項卡中。由於選項卡位於表示層,因此我想使用xul代碼中的模板創建它們。這可能嗎?
我還沒有看到用xul模板做這件事的方法。有沒有其他的模板系統可以讓我根據用戶的喜好來改變用戶界面?
不,XUL中的模板功能不夠強大,所以您一定要編寫JavaScript代碼來讀取首選項並打開所需的選項卡。
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 [email protected]*::*) {
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());