qooxdoo 值未在 html 小部件中更新

发布于 2025-01-03 03:19:34 字数 2559 浏览 1 评论 0原文

我正在 qooxdoo 上编写一个应用程序。我有一个类,它应该返回包含数据和小部件的表,用户在行信息上单击(与电子邮件客户端中的界面类似)。

然而,html 嵌入小部件中的信息仅在加载时初始化一次,之后就不会改变。如何重写代码以显示用户在 html 小部件中单击的行? 这是我的代码:

qx.Class.define("bank.InvoiceListBuilder",
{
  extend : qx.core.Object,
  statics:
  {
    createList : function(folder) {

        var box = new qx.ui.layout.VBox();
        box.setSpacing(0);

        var container = new qx.ui.container.Composite(box);
        container.setPadding(0);

        // table construction
            var data = new qx.data.Array;
            var invoice = new qx.data.Array;
            var tableModel = new qx.ui.table.model.Simple();
            tableModel.setColumns([ "id", "status", "name", "surname", "date", "email", "amount", "payexp", "description" ]);
            var rpc = new qx.io.remote.Rpc(
                "http://192.1.1.102/rpc",
                "mylist"
            );
            var handler = function(result, exc) {
              if (exc == null) 
              { 
                data = qx.lang.Json.parse(result);
                tableModel.setData(data);
              } else {
                alert("Exception during async call: " + exc);
              }
            };
            rpc.callAsync(handler, "listings", folder);
            var table = new qx.ui.table.Table(tableModel);
            var rowcontent = function(e)
            {
                var row = table.getFocusedRow();
                invoice = tableModel.getRowData(row);
                console.log(invoice);
            };
            table.addListener('cellClick', rowcontent, this);           
            table.getTableColumnModel().setColumnVisible(1, false);                 
            table.setShowCellFocusIndicator(false);
            table.setHeight(300);
            container.add(table);

            // invoice content view
            var rich = new qx.util.StringBuilder();

            if (invoice[2] == null)
            {
                rich.add("<b>Text</b>");
            } else {
                rich.add("<b>",invoice[2],"</b>");
            }
            var richWidget = new qx.ui.embed.Html(rich.get());
            console.log(rich.get());
            console.log(invoice[3]);
            richWidget.setOverflow("auto", "auto");
            richWidget.setDecorator("main");
            richWidget.setBackgroundColor("white");
            richWidget.setWidth(200);
            richWidget.setHeight(300);          
            container.add(richWidget);

            return(container);
    }
  }

I'm writing an application on qooxdoo. I have a class, which should return table with data and widget with clicked by user on row information (similar interface as in email client).

However information in html embedded widget is initialized only once at loading, after it not changing. How to rewrite code for showing user clicked row in html widget?
This is my code:

qx.Class.define("bank.InvoiceListBuilder",
{
  extend : qx.core.Object,
  statics:
  {
    createList : function(folder) {

        var box = new qx.ui.layout.VBox();
        box.setSpacing(0);

        var container = new qx.ui.container.Composite(box);
        container.setPadding(0);

        // table construction
            var data = new qx.data.Array;
            var invoice = new qx.data.Array;
            var tableModel = new qx.ui.table.model.Simple();
            tableModel.setColumns([ "id", "status", "name", "surname", "date", "email", "amount", "payexp", "description" ]);
            var rpc = new qx.io.remote.Rpc(
                "http://192.1.1.102/rpc",
                "mylist"
            );
            var handler = function(result, exc) {
              if (exc == null) 
              { 
                data = qx.lang.Json.parse(result);
                tableModel.setData(data);
              } else {
                alert("Exception during async call: " + exc);
              }
            };
            rpc.callAsync(handler, "listings", folder);
            var table = new qx.ui.table.Table(tableModel);
            var rowcontent = function(e)
            {
                var row = table.getFocusedRow();
                invoice = tableModel.getRowData(row);
                console.log(invoice);
            };
            table.addListener('cellClick', rowcontent, this);           
            table.getTableColumnModel().setColumnVisible(1, false);                 
            table.setShowCellFocusIndicator(false);
            table.setHeight(300);
            container.add(table);

            // invoice content view
            var rich = new qx.util.StringBuilder();

            if (invoice[2] == null)
            {
                rich.add("<b>Text</b>");
            } else {
                rich.add("<b>",invoice[2],"</b>");
            }
            var richWidget = new qx.ui.embed.Html(rich.get());
            console.log(rich.get());
            console.log(invoice[3]);
            richWidget.setOverflow("auto", "auto");
            richWidget.setDecorator("main");
            richWidget.setBackgroundColor("white");
            richWidget.setWidth(200);
            richWidget.setHeight(300);          
            container.add(richWidget);

            return(container);
    }
  }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

小鸟爱天空丶 2025-01-10 03:19:34

为了让 richWidget 更改其内容,您实际上必须更新它。仅更改数组的值在这里没有任何影响...(如果数组是 qooxdoo Array 对象并且您正在使用数据绑定,则可以...)。无论如何,与您在 rpc 回调中调用 setData 的方式相同,您必须在第二个回调中对丰富的小部件调用 setHtml

var richWidget = new qx.ui.embed.Html();
var rowcontent = function(e) {
    var row = table.getFocusedRow();
    var invoice = tableModel.getRowData(row);
    var rich = new qx.util.StringBuilder();
    if (invoice[2] == null) {
         rich.add("<b>Text</b>");
    } else {
         rich.add("<b>",invoice[2],"</b>");
    }
    richWidget.setHtml(rich.get());
};

不过还有更多。我建议不要创建静态函数,而是将您的实现基于 qx.ui.container.Composite 小部件,然后使用 newbank.InvoiceList() 实例化您的代码。 (这不会影响功能,但这是“正确的事情”。

for the richWidget to change its content, you actually have to update it. Just changing the value of an array does not have any effect here ... (it could, if the array was a qooxdoo Array object and you were using data bindings ...). In any event, in the same way you are calling setData in your rpc callback, you have to call setHtml on your rich widget in the second callback:

var richWidget = new qx.ui.embed.Html();
var rowcontent = function(e) {
    var row = table.getFocusedRow();
    var invoice = tableModel.getRowData(row);
    var rich = new qx.util.StringBuilder();
    if (invoice[2] == null) {
         rich.add("<b>Text</b>");
    } else {
         rich.add("<b>",invoice[2],"</b>");
    }
    richWidget.setHtml(rich.get());
};

There is more though. Instead of creating a static function, I would suggest to base your implementation on the qx.ui.container.Composite widget and then use new bank.InvoiceList() to instantiate your code. (this will not influence the functionality, but it is 'the right thing'.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文