亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Windows Phone 7 不溫不火學(xué)習(xí)之《頁(yè)面導(dǎo)航》

系統(tǒng) 2009 0

用于Windows Phone 的SilverLight 提供了 PhoneApplicationFrame 和 PhoneApplicationPage類,這兩個(gè)類是微軟針對(duì)Silverlight for Windows Phone 另外封裝的,它為導(dǎo)航提供了使得。

  PhoneApplicationPage 控件代表了內(nèi)容相互分離的區(qū)段,一個(gè)應(yīng)用程序可以有多個(gè)PhoneApplicationPage 。

  PhoneApplicationFrame 扮演了頁(yè)面控件容器的角色,對(duì)頁(yè)面之間的導(dǎo)航提供了便利,一個(gè)應(yīng)用程序有一個(gè)獨(dú)立的PhoneApplicationFrame。

  Windows Phone 7是通過(guò) 使用URI【通用資源標(biāo)志符(Uniform Resouce Identifier )】映射進(jìn)行頁(yè)面導(dǎo)航的。下面通過(guò) DEMO 來(lái)了解一下Windows Phone 7的各種導(dǎo)航的寫法吧。

第一種通過(guò)使用NavigationService 進(jìn)行導(dǎo)航控制,如下代碼:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " /Layout/SecondPage.xaml " ,UriKind.Relative));

UriKind 是一個(gè)枚舉類型,自帶有三種類型,這里我們使用相對(duì)路徑。

第二種通過(guò)直接使用控件自帶功能,即使用微軟的HyperLink控件,直接導(dǎo)航,代碼如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < HyperlinkButtonContent = " 點(diǎn)轉(zhuǎn) " NavigateUri = " /Layout/SecondPage.xaml " Height = " 30 " HorizontalAlignment = " Left " Margin = " 101,68,0,0 " Name = " hyperlinkButton1 " VerticalAlignment = " Top " Width = " 200 " />

第三種我們可以為我們的URI路徑起一個(gè)別名,然后在調(diào)用時(shí)調(diào)用別名即可,可以方便我們管理,使用步驟如下:

a).在App.xaml的文件上注冊(cè)Windows.Navigation 命名空間,該空間位于Reference目錄下的Microsoft.Phone組件,代碼如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> xmlns:nav = " clr-namespace:System.Windows.Navigation;assembly=Microsoft.Phone "

b).為應(yīng)用程序添加資源,代碼如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < Application.Resources >
< nav:UriMapperx:Key = " UriMapper " >
< nav:UriMappingUri = " SecondPage " MappedUri = " /Layout/SecondPage.xaml " />

</ nav:UriMapper >
</ Application.Resources >

c).添加完成后,進(jìn)入 App.xaml.cs 在它的構(gòu)造函數(shù)里面為應(yīng)用程序的RootFrame下所在的UriMapper 賦值,這用的話我們應(yīng)用程序就可以通過(guò)它去映射我們傳給它的URI 別名。代碼如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> this .RootFrame.UriMapper = Resources[ " UriMapper " ] as UriMapper;

Tip:這里的Resources 是一個(gè)字典型數(shù)據(jù),鍵值必須跟上面App.xaml 添加資源的UriMapper Key要相對(duì)應(yīng)。

d).注冊(cè)好別名之后,我們就可以在程序中如下使用:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " SecondPage " ,UriKind.Relative));

或者在HyperLinkButton 中如下使用:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < HyperlinkButtonContent = " 點(diǎn)轉(zhuǎn) " NavigateUri = " SecondPage " Height = " 30 " HorizontalAlignment = " Left " Margin = " 101,68,0,0 " Name = " hyperlinkButton1 " VerticalAlignment = " Top " Width = " 200 " />

好了,說(shuō)完如何通過(guò)URI導(dǎo)航到指定Page 頁(yè)面,下面來(lái)嘗試一下如何通過(guò)URI導(dǎo)航傳遞數(shù)據(jù)吧。

做過(guò)Asp.Net 的童鞋相信對(duì)地址欄傳值不陌生,比如我現(xiàn)在在博客園寫文章的路徑如下:

后面的“?”跟著的就是相關(guān)的參數(shù)或者要表達(dá)的某些請(qǐng)求,這種寫法很好,又直接。做過(guò)WEB的又好理解,不過(guò)慶幸的是微軟把這個(gè)非常棒的功能加入到Windows phone 7的頁(yè)面?zhèn)鬟f中來(lái),這真是一大另人興奮的事,怎么樣呢?就這樣用:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " /Layout/SecondPage.xaml?opt=1 " ,UriKind.Relative));

或者

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < HyperlinkButtonContent = " 點(diǎn)轉(zhuǎn) " NavigateUri = " /Layout/SecondPage.xaml?opt=1 " Height = " 30 " HorizontalAlignment = " Left " Margin = " 101,68,0,0 " Name = " hyperlinkButton1 " VerticalAlignment = " Top " Width = " 200 " />

簡(jiǎn)單明了,不帶一絲拖拉看來(lái)WEB開發(fā)人員進(jìn)入Windows Phone 7開發(fā)也可以喲。。。呵呵~!!

我們剛才的縮寫也是同樣直接這種URI帶參數(shù)的寫法的,同樣還是來(lái)到App.xaml頁(yè)面,寫法如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < Application.Resources >
< nav:UriMapperx:Key = " UriMapper " >
< nav:UriMappingUri = " SecondPage " MappedUri = " /Layout/SecondPage.xaml " />
< nav:UriMappingUri = " SecondPage/{content} " MappedUri = " /Layout/SecondPage.xaml?name={content} " />
</ nav:UriMapper >
</ Application.Resources >

這里要注意三點(diǎn):

  • SecondPage/{content}與后面name={content}這兩個(gè)content一定要相同
  • content 不可以寫數(shù)字0,寫數(shù)字0會(huì)報(bào)運(yùn)行時(shí)錯(cuò)誤。可以為數(shù)字1,但不可以為其他數(shù)字。為“1”時(shí)編譯器解析正常,但為其他數(shù)字時(shí)雖不會(huì)報(bào)運(yùn)行時(shí)錯(cuò)誤,但編譯器解析出錯(cuò),不能夠正確解析傳進(jìn)來(lái)的參數(shù),會(huì)直接打印比如SecondPage/{111}在另外的頁(yè)面就直接打印{111}。
  • MappedUri 后面“?”的查詢字段區(qū)分大小寫。

添加資源完成后,在頁(yè)面使用如下方法即可調(diào)用縮寫并傳參數(shù):

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " SecondPage/terry " ,UriKind.Relative));

試試效果吧,在頁(yè)面中的按鈕點(diǎn)擊然后跳轉(zhuǎn)到第二頁(yè),看會(huì)不會(huì)顯示“terry”,如圖:

Windows Phone 7 不溫不火學(xué)習(xí)之《頁(yè)面導(dǎo)航》

獲取參數(shù)跟Asp.net 差不多,見下方代碼:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> if (NavigationContext.QueryString.Count > 0 )
{
UriTextBox.Text
= NavigationContext.QueryString[ " name " ].ToString();
}

  Windows Phone 7 的NavigationContext.QueryString 是不支持傳遞對(duì)象的,那么如果我們現(xiàn)在有個(gè)對(duì)象需要傳遞該如何實(shí)現(xiàn)呢?看了Jake Lin 老師的視頻后才知道可以在App 里面定義一個(gè)對(duì)象屬性,然后這個(gè)屬性就可以提供全局訪問(wèn)。是不是我可以理解成這個(gè)屬性其實(shí)也可以放在一個(gè)公用的靜態(tài)類上呢?呵呵,下面看如何實(shí)現(xiàn)吧。

步驟一:

聲明一個(gè)對(duì)象名為Model寫下如何函數(shù):

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> public class Model
{
public string name{ get ; set ;}
public string file{ get ; set ;}
}

然后在App.xaml.cs 里面將Model 聲明為一個(gè)公用的靜態(tài)屬性:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> public static Class.ModelMyAppModel{ get ; set ;}

余下的功夫就是為其賦值和取值的操作了,點(diǎn)擊跳往下一頁(yè)的按鈕時(shí),為App.Model 賦值。在第二頁(yè)時(shí)取出App.Model的值,代碼編寫見下方:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> private void button1_Click( object sender,RoutedEventArgse)
{
App.MyAppModel
= new Class.Model{name = " terry " ,file = " my " };
NavigationService.Navigate(
new Uri( " SecondPage/terry " ,UriKind.Relative));
}

第二頁(yè)Loaded完畢后:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> private void PhoneApplicationPage_Loaded( object sender,RoutedEventArgse)
{
if (NavigationContext.QueryString.Count > 0 )
{
UriTextBox.Text
= NavigationContext.QueryString[ " name " ].ToString();
}
Class.Modelmodel
= App.MyAppModel;

Debug.WriteLine(model.name
+ " ===>>> " + model.file);
}

見輸出日志信息:

我們還可以通過(guò)別名傳參的方法,動(dòng)態(tài)的指定頁(yè)面跳轉(zhuǎn),先看看界面:

Windows Phone 7 不溫不火學(xué)習(xí)之《頁(yè)面導(dǎo)航》

頁(yè)面上有三個(gè)單選按鈕,然后工程中對(duì)應(yīng)有三個(gè)頁(yè)面:

選擇后,點(diǎn)擊按鈕將會(huì)通過(guò)下標(biāo)動(dòng)態(tài)跳轉(zhuǎn)到不同的頁(yè)面,代碼編寫看下方。

首先,App.xaml的資源添加:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < Application.Resources >
< nav:UriMapperx:Key = " UriMapper " >
< nav:UriMappingUri = " SecondPage " MappedUri = " /Layout/SecondPage.xaml " />
< nav:UriMappingUri = " SecondPage/{content} " MappedUri = " /Layout/SecondPage.xaml?name={content} " />
< nav:UriMappingUri = " page/{number} " MappedUri = " /Layout/Page{number}.xaml " />
</ nav:UriMapper >
</ Application.Resources >

然后,在主頁(yè)上聲明一個(gè)全局索引,接著編寫如下代碼,即可完成:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> private void firstRb_Checked( object sender,RoutedEventArgse)
{
index
= 1 ;
}

private void secondRb_Checked( object sender,RoutedEventArgse)
{
index
= 2 ;
}

private void threeRb_Checked( object sender,RoutedEventArgse)
{
index
= 3 ;
}

private void chooseButton_Click( object sender,RoutedEventArgse)
{
NavigationService.Navigate(
new Uri( " page/ " + index,UriKind.Relative));
}

頁(yè)面導(dǎo)航和數(shù)據(jù)傳遞的課程學(xué)習(xí)完畢到這里先,如果你覺(jué)得對(duì)你有幫助,別忘了推薦一下,謝謝。

------點(diǎn)擊發(fā)布,才記起忘了發(fā)源碼: 導(dǎo)航DEMO

Windows Phone 7 不溫不火學(xué)習(xí)之《頁(yè)面導(dǎo)航》


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 亚洲国产中文字幕 | 91久久亚洲国产成人精品性色 | 国产91福利在线精品剧情尤物 | 男人天堂a在线 | 四虎影视精品永久免费 | 亚洲成人福利 | 日韩一级精品视频在线观看 | 99热精品在线播放 | 日韩激情中文字幕一区二区 | 青青在线成人免费视频 | 日日摸日日碰夜夜爽久久 | 欧美肥婆xxxx欧美另类 | 欧美日韩亚洲国产一区二区综合 | 综合网亚洲| 九天玄帝诀王凡小说免费阅读 | 99精品视频在线在线视频观看 | 日韩 欧美 亚洲国产 | 四虎影院久久 | 天天综合天天 | 手机看片福利盒子久久 | 欧美日本免费观看αv片 | 四虎永久地址4hu2019 | 久久久久久久亚洲精品 | 99热精品在线 | 狠狠干夜夜骑 | 国产成人高清亚洲一区91 | 女人一级毛片免费观看 | 日韩成人在线网站 | 99久久精品国产自免费 | 亚洲欧美综合乱码精品成人网 | 亚洲成人高清 | 天天操夜夜草 | 99视频精品全部免费观看 | 欧美精品亚洲一区二区在线播放 | 欧美成人亚洲欧美成人 | 香蕉视频亚洲 | 亚洲国产精品自产在线播放 | 外国成人网在线观看免费视频 | 爱爱小视频免费体验区在线观看 | 亚洲美日韩 | 视频在线观看91 |