1

我目前正在对 TableView a 进行数据绑定,下面是代码:

<Alloy>
    <TableViewRow backgroundColor="{background}" id="businessRow">
        <Label id="st1" class="ribbonIcon1" color="{highlight1}" text="{st1}"/>
        <Label id="st2" class="ribbonIcon2" color="{highlight2}" text="{st2}"/>
        <Label id="st3" class="ribbonIcon3" color="{highlight3}" text="{st3}"/>
        <Label id="st4" class="ribbonIcon4" color="{highlight4}" text="{st4}"/>
        <Label id="st5" class="ribbonIcon5" color="{highlight5}" text="{st5}"/>
    </TableViewRow>
</Alloy>

每个标签都是由 定义的图标字体{st1}。我正在使用引用连字的 icomoon 字体,因此我可以相应地更改图标。我为此测试使用了复选框字体图标。

然后,我正在执行数据转换,以用蓝色突出显示与它们相关联的业务的图标,如果没有,则从 SQLite 数据库 (DesQuery) 中提取灰色。

SQL 片段和函数

...COUNT(BusinessSites.BusinessID) AS Bqty, sum(case when     Services.ServiceID = "1" then 1 else 0 end) ST1, sum(case when Services.ServiceID = "2" then 1 else 0 end) ST2, sum(case when Services.ServiceID = "3" then 1 else 0 end) ST3, sum(case when Services.ServiceID = "4" then 1 else 0 end) ST4, sum(case when Services.ServiceID = "5" then 1  else 0 end) ST5 FROM...



    function DescOrder(){
        Junctions.fetch({query:DesQuery});
        Junctions.setSortField("display_order", "DESC");
        Junctions.sort();
        transformJunctionList(Junctions);
        toggleOrder = "DESC";
    }

function AscOrder(){
    Junctions.fetch({query:DesQuery});
    Junctions.setSortField("display_order", "ASC");
    Junctions.sort();
    transformJunctionList(Junctions);
    toggleOrder = "ASC";
}

function transformJunctionList(model) {
    var transform = model.toJSON();
                transform.st1 = "checkbox";
                transform.ST1 > "0" ? transform.highlight1 = "#4993cc" : transform.highlight1 = "#ebe9e9";
                transform.st2 = "checkbox";
                transform.ST2 > "0" ? transform.highlight2 = "#4993cc" : transform.highlight2 = "#ebe9e9";
                transform.st3 = "checkbox";
                transform.ST3 > "0" ? transform.highlight3 = "#4993cc" : transform.highlight3 = "#ebe9e9";
                transform.st4 = "checkbox";
                transform.ST4 > "0" ? transform.highlight4 = "#4993cc" : transform.highlight4 = "#ebe9e9";
                transform.st5 = "checkbox";
                transform.ST5 > "0" ? transform.highlight5 = "#4993cc" : transform.highlight5 = "#ebe9e9";`

iOS 上的输出正常,但给了我这个警告:

`

[WARN] :通过的十六进制颜色看起来无效:

但是,它会在 tableView 加载时使 Android 崩溃。这适用于以前的版本,没有错误。如果我删除{highlight1}etc 并用有效的十六进制替换它运行正常。

这是 iPhone 上输出的当前屏幕片段。

表格中图标的屏幕截图

任何关于如何达到相同结果的建议都会很棒。

4

1 回答 1

0

我们在新版本中也遇到了这个问题。对我们来说,这是我们有时设置的颜色。在以前的版本中,它只会忽略没有颜色的那些,但在这个版本中,它会尝试解析 null。我们通过在转换函数中为所有模型设置默认颜色白色来修复它,然后根据需要进行更改。

于 2016-04-25T19:18:46.827 回答