Flex數(shù)據(jù)綁定中難以發(fā)現(xiàn)的無(wú)聲錯(cuò)誤
本文和大家重點(diǎn)討論一下Flex數(shù)據(jù)綁定陷阱中常見(jiàn)錯(cuò)誤,數(shù)據(jù)綁定會(huì)減緩程序的初始化,并且當(dāng)開(kāi)發(fā)者不是完全理解數(shù)據(jù)綁定的機(jī)制是如何工作的話,會(huì)引起一些開(kāi)發(fā)者意想不到的問(wèn)題。
Flex數(shù)據(jù)綁定陷阱中常見(jiàn)錯(cuò)誤
當(dāng)構(gòu)建Flex或者Adobe AIR程序時(shí),將一個(gè)對(duì)象的值自動(dòng)的傳遞給另一個(gè)對(duì)象這種處理是數(shù)據(jù)綁定最常用并最有用的特征之一。盡管如此,同時(shí)數(shù)據(jù)綁定會(huì)減緩程序的初始化,并且當(dāng)開(kāi)發(fā)者不是完全理解數(shù)據(jù)綁定的機(jī)制是如何工作的話,會(huì)引起一些開(kāi)發(fā)者意想不到的問(wèn)題。最好的解決方法及是確保你正確的使用了它并且在只有需要它的時(shí)候才使用它。在這篇文章中,我整理了十條開(kāi)發(fā)者在構(gòu)建應(yīng)用使用數(shù)據(jù)綁定時(shí)常見(jiàn)的陷阱和錯(cuò)誤。
Flex數(shù)據(jù)綁定陷阱第一條:難以發(fā)現(xiàn)的無(wú)聲錯(cuò)誤
這有些綁定操作似乎已經(jīng)工作,但是你最后卻沮喪的發(fā)現(xiàn)沒(méi)有并且無(wú)從下手修改的例子。
在綁定表達(dá)式或者在綁定框架里調(diào)用綁定方法時(shí)拋出的異常和錯(cuò)誤,只會(huì)默默的捕獲。因此你將在Flash Player調(diào)試版本中看不到任何運(yùn)行時(shí)錯(cuò)誤。不僅綁定沒(méi)有工作,而且沒(méi)有任何錯(cuò)誤顯示。為什么這些錯(cuò)誤被無(wú)聲捕獲?代碼實(shí)現(xiàn)綁定機(jī)制,在綁定發(fā)生前需要幾個(gè)先決條件。綁定機(jī)制會(huì)吞噬掉任何錯(cuò)誤以防止在運(yùn)行時(shí)拋出運(yùn)行時(shí)異常。如果你不希望在你的程序中看到這些可能出現(xiàn)的意外錯(cuò)誤,這是一個(gè)很好的事情。
思考下下面的簡(jiǎn)單綁定例子:
- <?xml version="1.0" encoding="utf-8"?>
- <s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
- xmlns:s="library://ns.adobe.com/flex/spark"
- xmlns:mx="library://ns.adobe.com/flex/mx"
- minWidth="1024" minHeight="768"
- preinitialize="handlePreinitialize()">
- <fx:Script>
- <![CDATA[
- [Bindable]
- private var xml:XML =
- <users>
- <user>
- <name>EladElrom</name>
- <address>1 Wall Street</address>
- </user>
- </users>;
- protected function handlePreinitialize():void
- {
- xml = null;
- //BindingManager.debugBinding("label.text");
- }
- ]]>
- </fx:Script>
- <s:Label id="label" text="{xml.user.name}"/>
- </s:Application>
我已經(jīng)添加了xml變量綁定到Label組件。這些代碼會(huì)運(yùn)行的很好;但是,我在組件預(yù)初始化時(shí)將xml變量設(shè)置為null。這個(gè)事件將在組件初始化序列開(kāi)始之前被派發(fā),此時(shí)Label組件還沒(méi)有被設(shè)置。這個(gè)xml變量被設(shè)置為null,因此沒(méi)有name屬性在xml對(duì)象上。如果你運(yùn)行這個(gè)程序,你會(huì)發(fā)現(xiàn)綁定沒(méi)有發(fā)生也沒(méi)有提示任何錯(cuò)誤。
調(diào)試Flex數(shù)據(jù)綁定
雖然錯(cuò)誤被無(wú)聲的捕獲,你仍然有辦法可以找出是怎么回事。使用BindingManager.as和Binding.as來(lái)進(jìn)行調(diào)試并不容易,因?yàn)槿绻銢](méi)有下載完整的Flex sdk的話,綁定類(lèi)是沒(méi)有的。相反,你可以設(shè)置一個(gè)斷點(diǎn)并跟蹤相關(guān)的綁定對(duì)象來(lái)找出問(wèn)題所在。在這種情況下,你會(huì)發(fā)現(xiàn)xml對(duì)象的值被設(shè)置為null,這就是為什么綁定為什么失敗的原因(看圖1)。
圖1. xml對(duì)象的值被設(shè)置為null
另一種方法更加直觀,是使用BindingManager類(lèi)的debugBinding方法。你設(shè)置你想觀察的組件和屬性,然后你就可以看到被捕獲的錯(cuò)誤。在上面的示例代碼中,我給下面的這行代碼加了注釋?zhuān)?
BindingManager.debugBinding("label.text");
把這行的注釋去掉并在debug模式下運(yùn)行它;你將在控制臺(tái)看到綁定錯(cuò)誤(見(jiàn)圖2)
圖2.控制臺(tái)輸出的Flex數(shù)據(jù)綁定錯(cuò)誤
看一下Binding.as和BindingManager.as類(lèi)的代碼。代碼中含有許多的try...catch表達(dá)式來(lái)確保形成有效綁定的條件。以下有一些在綁定時(shí)可能拋出的錯(cuò)誤類(lèi)型:
◆ Error #1006: Call attempted on an object that is not a function.
◆ Error #1009: Null has no properties.
◆ Error #1010: Undefined has no properties.
◆ Error #1055: Has no properties.
◆ Error #1069: Property - not found on - and there is no default value
◆錯(cuò)誤#1006:試圖調(diào)用的對(duì)象不是函數(shù)。
◆錯(cuò)誤#1009:空沒(méi)有屬性。
◆錯(cuò)誤#1010:未定義沒(méi)有屬性。
◆錯(cuò)誤#1055:沒(méi)有屬性。
◆錯(cuò)誤#1069:屬性 - 找不到 - 并且沒(méi)有默認(rèn)值
如果任何這些錯(cuò)誤發(fā)生,綁定對(duì)象將默默捕獲他們并不再實(shí)現(xiàn)綁定。你可以使用綁定管理的調(diào)試選項(xiàng)來(lái)看到這些錯(cuò)誤。綁定管理除了捕獲這些錯(cuò)誤之外還捕獲其他的錯(cuò)誤。
【編輯推薦】