連接Flex數(shù)據(jù)庫行之有效的辦法
本文和大家重點(diǎn)討論一下連接Flex數(shù)據(jù)庫的方法,F(xiàn)lex應(yīng)用程序并不直接與一個(gè)Flex數(shù)據(jù)庫進(jìn)行連接,所以你需要使用某種類型的服務(wù)來支持對(duì)數(shù)據(jù)的使用。并且連接Flex數(shù)據(jù)庫的***步是生成將在Flex程序中使用到的數(shù)據(jù)。
連接Flex數(shù)據(jù)庫的方法
Flex應(yīng)用程序并不直接與一個(gè)Flex數(shù)據(jù)庫進(jìn)行連接,所以你需要使用某種類型的服務(wù)來支持對(duì)數(shù)據(jù)的使用。
連接Flex數(shù)據(jù)庫的***步是生成將在Flex程序中使用到的數(shù)據(jù)。在與PHP的應(yīng)用中,你將采用如下的步驟:
1.創(chuàng)建一個(gè)Flex數(shù)據(jù)庫(如MySQL)。
2.編寫一個(gè)PHP腳本連接MySQLFlex數(shù)據(jù)庫并生成XML格式的數(shù)據(jù)。
這些步驟同樣適合于在其它工作平臺(tái)上生成的數(shù)據(jù)(如ASP.NET、JSP等)。
連接外部數(shù)據(jù)源
對(duì)于PHP所生成的XML格式數(shù)據(jù),你可以使用HTTPService組件來請(qǐng)求獲取數(shù)據(jù),就象這樣:
- <mx:Applicationxmlns:mxmx:Applicationxmlns:mx="http://www.adobe.com/2006/mxml"layout="absolute">
- <mx:HTTPService
- id="productsRequest"
- url="http://www.somesite.com/products.php"/>
- ...
HTTPService組件定義了一個(gè)請(qǐng)求ID,你將使用這個(gè)ID來控制提供數(shù)據(jù)的URL或者服務(wù)器與數(shù)據(jù)之間的綁定。
外部數(shù)據(jù)與數(shù)據(jù)驅(qū)動(dòng)控制的綁定
通過數(shù)據(jù)與數(shù)據(jù)驅(qū)動(dòng)控制(data-drivencontrol)的綁定,你就可以處理HTTPService的結(jié)果(XML數(shù)據(jù)),就象這樣:
- <mx:DataGridxmx:DataGridx="20"y="80"id="productGrid"width="400"
- dataProvider="{productRequest.lastResult.products.items}">
- <mx:columns>
- <mx:DataGridColumnheaderTextmx:DataGridColumnheaderText="Name"dataField="name"/>
- <mx:DataGridColumnheaderTextmx:DataGridColumnheaderText="Price"dataField="price"/>
- < span>mx:columns>
- < span>mx:DataGrid>
Flex數(shù)據(jù)庫中數(shù)據(jù)綁定的語法顯示在數(shù)據(jù)控制的dataProvider屬性中(在波浪形的括號(hào)里),它包含了HTTPService請(qǐng)求ID、lastResult方法、以及XML文件的數(shù)據(jù)結(jié)構(gòu)。在這個(gè)例子中,XML數(shù)據(jù)源的數(shù)據(jù)結(jié)構(gòu)看起來就象這樣:
- <XML>
- <products>
- <item>
- <name>MobilePhone< span>name>
- <price>$199< span>price>
- < span>item>
- <item>
- <name>CarCharger< span>name>
- <price>$34< span>price>
- < span>item>
- ...
通過設(shè)置dataField屬性,項(xiàng)目數(shù)據(jù)(name和price)作為數(shù)據(jù)柵格中每一列的數(shù)據(jù)。
在運(yùn)行時(shí)加載數(shù)據(jù)
你還可以在Flex程序開始運(yùn)行時(shí)加載Flex數(shù)據(jù)庫數(shù)據(jù),就象隨后所示,在HTTPService中向某個(gè)特定的URL發(fā)送一個(gè)請(qǐng)求:
- <mx:Applicationxmlns:mxmx:Applicationxmlns:
- mx=http://www.adobe.com/2006/mxml
- layout="absolute"creationComplete="productsRequest.send()">
當(dāng)你將creationComplete方法添加到應(yīng)用程序標(biāo)簽里后,數(shù)據(jù)會(huì)在運(yùn)行時(shí)進(jìn)行加載并交于數(shù)據(jù)驅(qū)動(dòng)控制(在這個(gè)例子中是數(shù)據(jù)柵格)。
你還可以將HTTPService請(qǐng)求添加到一個(gè)控制事件上而不是程序里的標(biāo)簽中,就象如下所示:
- <mx:Buttonxmx:Buttonx="50"y="8"
- label="GetData"click="productsRequest.send();"/>
Flex提供許多方法去連接、管理、格式化、以及校驗(yàn)數(shù)據(jù)。你可以通過使用遠(yuǎn)程程序調(diào)用、數(shù)據(jù)服務(wù)、或者其它企業(yè)級(jí)技術(shù)來操縱和管理數(shù)據(jù)。
【編輯推薦】