全部,
我正在尝试实现一个包含多个子面板的 StackPanel 来收集用户数据。每个子面板(我将它们命名为 SwapRecordPanels)代表 Google 电子表格中的一行,其中包含两个想要交换工作日期的人的数据。SwapRecordPanels 包含一个删除按钮。单击删除按钮时,我希望 SwapRecordPanel 将自身从 StackPanel 中删除。
但是,我发现当我尝试从 StackPanel 中删除元素时,更改不会在 GUI 中注册。为了证明我可以删除 StackPanel 中的元素的概念,我添加了一个名为“Click Me”的额外按钮。正如您在下面的代码中看到的,它的处理程序尝试从 StackPanel“LeftPanel”中删除一个元素。但是,当我单击按钮时,“LeftPanel”保持不变。我想知道是否需要调用某种刷新/重绘方法来更新 GUI。如果没有,有人可以提供任何建议吗?任何帮助将不胜感激。
function myViewer() {
var myapp = doGet();
SpreadsheetApp.getActive().show(myapp)
}
function doGet() {
var myapp = UiApp.createApplication();
var LeftPanel = myapp.createStackPanel().setId("LeftPanel");
var LeftScrollPanel = myapp.createScrollPanel(LeftPanel).setPixelSize(410,200)
myapp.add(LeftScrollPanel)
var SwapPane1 = SwapRecordPanel(LeftPanel);
var SwapPane2 = SwapRecordPanel(LeftPanel);
LeftPanel.add(SwapPane1,"Test 1 Header");
LeftPanel.add(SwapPane2, "Test 2 Header");
var myButton = myapp.createButton("Click Me").addClickHandler(myapp.createServerHandler("ButtonClicker"));
myapp.add(myButton);
return myapp;
}
function ButtonClicker()
{
Logger.log("I was clicked")
var myapp = UiApp.getActiveApplication();
var LeftPanel = myapp.getElementById("LeftPanel");
LeftPanel.remove(myapp.getElementById("panel1"));
}