如何在三元运算符中使用 ASP.NET Eval() 函数?

2023-12-03

我希望评估数据集中的两个字符串,以使用三元运算符来识别类描述。 运行此代码时,我继续收到编译器错误,指出“需要表达式”。 我认为这与字符串的比较有关,但我尝试过其他比较运算符,但似乎无法让它工作。

<ItemTemplate>
<tr>
   <td><%# FormatDateTime(Eval("GameDate"), DateFormat.ShortDate)%></td>
   <td class="<%# (Eval("Team1Score").ToString() > Eval("Team2Score").ToString()) ? 'Winner':'' %>"><%# Eval("Team1")%></td>
   <td><%# Eval("Team1Score")%></td>
   <td><%# Eval("Team2")%></td>
   <td><%# Eval("Team2Score")%></td>
</tr>
</ItemTemplate>

这是我的示例数据:

    GameDate      Team1 Team1Score     Team2    Team2Score      Winner
    2012-04-14    Blues 5              Reds     3               Blues
    2012-04-13    A's   4              B's      2               A's
    2012-04-11    Blues 1              A's      1               Tie
    2012-04-13    B's   3              Reds     2               B's
    2012-04-10    Blues 7              B's      4               Blues

感谢您的帮助


我认为问题在于您试图在两个字符串之间进行比较。只需将值转换为 int 或类似的值即可进行比较。例如,将您的比较更改为如下所示:

<td class="<%# (Convert.ToInt32(Eval("Team1Score")) > Convert.ToInt32(Eval("Team2Score"))) ? 'Winner':'' %>"><%# Eval("Team1")%></td>

或者您可以将其转换为适当的类型:

<td class="<%# ((int)Eval("Team1Score") > (int)Eval("Team2Score")) ? 'Winner':'' %>"><%# Eval("Team1")%></td>

希望这可以帮助!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在三元运算符中使用 ASP.NET Eval() 函数? 的相关文章

随机推荐