JavaFX发现之旅(3) JavaFX Script With Eclipse 入门

标签(Labels)

JavaFX Label类支持HTML内容。使用Label您可以使用HTML和CSS创建样式文本和图像,非常类似于典型的Web应用。此外,通过使用JavaFX嵌入表达式,您可以在Swing应用中象Web页面作者使用类似JSTLVelocity工具一样创建动态的HTML内容。

考虑以下虚拟购物车示例:

import javafx.ui.*;   class Item {             attribute id: String;             attribute productId: String;             attribute description: String;             attribute inStock: Boolean;             attribute quantity: Number;             attribute listPrice: Number;             attribute totalCost: Number;        }          attribute Item.totalCost = bind quantity*listPrice;         class Cart {             attribute items: Item*;             attribute subTotal: Number;        }          operation sumItems(itemList:Item*) {             var result = 0.00;            for (item in itemList) {                 result += item.totalCost;            }            return result;        }          attribute Cart.subTotal = bind sumItems(items);          var cart = Cart {             items:            [Item {                 id: "UGLY"                 productId: "D100"                 description: "BullDog"                 inStock: true                 quantity: 1                 listPrice: 97.50            },             Item {                 id: "BITES"                 productId: "D101"                 description: "Pit Bull"                 inStock: true                 quantity: 1                 listPrice: 127.50            }]        };        Frame {              content: Label {                 text: bind                    "                        

Shopping Cart

                       
Item IDProduct IDDescriptionIn Stock?QuantityList PriceTotal Cost
'8'>Your cart is empty.
"                              else foreach (item in cart.items)                                  "'#FFFF88'>                                   {item. id }                                   {item. productId }                                   {item. description }                                   { if item. inStock then "Yes" else "No" }                                   {item. quantity }                                   'right'> {item. listPrice }                                   'right'> {item. totalCost }                                                                      "                            }                                                                                                  Sub Total: ${cart.subTotal}                                                                                                                                              "                 }                 visible: true         }

运行以上程序,显示如下:

bb

如果您编程删除购物车内容:

delete cart.items;

您将看到如下内容:

bb

在以上示例中,内嵌的JavaFX表达式(粗体显示)动态创建HTML表格列和表格单元的内容。当这些表达式依赖的对象有变化时,Label的HTML内容将自动更新。

以上示例还非常有趣,因为其演示了使用表达式定义属性值的用法。Item类的totalCost属性和Cart类的subTotal属性被绑定为表达式以计算它们的值。任何时候这些表达式的依赖对象发生变化,属性值将被自动重新计算并更新。考虑在电子表格中,某些单元格包含指向其他单元格的表达式,当您在这些其他单元格输入数据,包含依赖它们的表达式的单元格值也被自动更新了。

HTML中的图像

JavaFX Label类实际上封装了一个特殊的JEditPane,该JEditorPane使用一个支持用Java类转载器从JAR文件中载入图像的共享图像缓存。因此,您可以就像普通的文件URL一样使用HTML的元素引用您的应用的图像资源包。

超链接

Label类同样支持HTML超链接,内嵌一个特殊的URL给HTML元素的href属性。

这样的URL使用JavaFX #操作符创建,该操作符生成一个字符串化对象引用(Stringified Object Reference)指向后续可以被JavaFX复引用的操作对象。?操作符,例如:

var a = 20;var b = #a;assert b instanceof String; // 通过var c = (Number) ?b;assert a == c;  // 通过

Label类的HTML显示器认识诸如HTML的这样的URL,使用URL来响应元素的鼠标点击,并且如果URL值指向一个函数或操作的话,它可以调用该函数或操作。

例如,以下是使用带超链接标签代替按钮的前面按钮点击示例的重写版本:

import javafx.ui.*;import java.lang.System; class ButtonClickModel { attribute numClicks: Number;} var model = new ButtonClickModel(); var win = Frame {   width: 300   height:200   menubar: MenuBar {     menus: Menu {       text: "File"       mnemonic: F       items: MenuItem {         text: "Exit"         mnemonic: X         accelerator: {           modifier: ALT           keyStroke: F4           }         action: operation() {          System.exit(0);           }        }      }   }   content: GridPanel {     border: EmptyBorder {  top: 30  left: 30  bottom: 30  right: 30     }     rows: 2     columns: 1     vgap: 10     cells:    [Label {        text: bind       "                        I'm a hyperlink!                    "       },     Label {        text: bind "Number of button clicks: {model.numClicks}"      }]  }   visible: true};

以上示例中粗体的表达式创建一个新的递增model的numClicks属性的操作。使用#操作符生成后续将被键入到HTML标记中的指向该操作的URL。

运行该程序,显示如下:

bb

点击超链接两次后,显示如下:

bb

fj.png13270562_200803190836291.jpg

fj.png13270562_200803190836292.jpg

fj.png13270562_200803190836293.jpg

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/13270562/viewspace-211610/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/13270562/viewspace-211610/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值