我刚刚开始使用 JavaScript 中的 OOP。我想创建一个自定义“面板”。这是我到目前为止所拥有的:
function ShinyPanel(css, attributes)
{
this.container = $(document.createElement("div")).addClass("shinyPanel");
this.titleBar = $(document.createElement("div")).addClass("shinyPanelTitleBar").appendTo(this.container);
this.topShine = $(document.createElement("div")).addClass("shinyPanelTopShine").appendTo(this.container);
this.leftShine = $(document.createElement("div")).addClass("shinyPanelLeftShine").appendTo(this.container);
this.content = $(document.createElement("div")).addClass("shinyPanelContent").appendTo(this.container);
if (!css) css = {};
if (!attributes) attributes = {};
this.css = css;
$(this.container).css(this.css);
this.title = attributes["title"];
$(this.titleBar).html(this.title);
}
现在我可以实例化这个对象并通过这样的方式将它附加到正文中:
var panel = new ShinyPanel({position:"absolute", top:"25%", width:"300px", height:"200px"}, {title:"Test"});
$("body").append(panel.container);
我的问题是,有没有办法让对象本身成为一个 div,从而消除对“容器”div 的需要?然后我就可以打电话了$("body").append(panel);
。
将容器 div 放在那里对我来说并不是那么麻烦,它更适合我......想要学习正确的做事方式。
我试过this = document.createElement("div");
了,但我得到了一个错误:invalid assignment left-hand side
。