UWP漢堡菜單之MVVM模式實(shí)現(xiàn)

小廣告
今年開始使用簡(jiǎn)書列粪,同時(shí)也產(chǎn)生了寫博文的興趣了,在寫完文章發(fā)現(xiàn)沒有.NET專題,于是創(chuàng)建了.NET專題也希望大家多多投稿,歡迎來"搞"!
吐槽
吐槽一下博客園,本來下了很大的勇氣將UWP漢堡菜單的使用發(fā)到了博客園并提交到了首頁(yè),可惜被移除了营罢,太失望了,不知道博客園是什么審核機(jī)制饼齿,吐槽完畢饲漾!

前面說道了UWP漢堡菜單的使用,今天主要是以MVVM的模式來實(shí)現(xiàn)漢堡菜單和大家分享,有什么不正確的地方望指正缕溉,我也是初學(xué)者考传,有什么問題也可以在微博上與我討論。

項(xiàng)目結(jié)構(gòu)圖
漢堡菜單

1.XAML
XAML代碼和前面的幾乎一致证鸥,需要注意的是數(shù)據(jù)綁定的模式僚楞。

    x:Class="HamburgNavigation.View.MainView"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:HamburgNavigation"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Page.Resources>
        <ResourceDictionary>
            <DataTemplate x:Key="MenuItemDataTemplate">
                <StackPanel Orientation="Horizontal">
                    <SymbolIcon Symbol="{Binding Icon}" />
                    <TextBlock Text="{Binding Text}" Margin="18" />
                </StackPanel>
            </DataTemplate>
        </ResourceDictionary>
    </Page.Resources>

    <Grid x:Name="rootGrid" Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
        <SplitView x:Name="mainSplitView" OpenPaneLength="150" CompactPaneLength="45" PaneBackground="LightGray" DisplayMode="CompactOverlay" IsPaneOpen="{Binding IsPaneOpen,Mode=TwoWay}">
            <SplitView.Pane>
                <Grid>
                    <Grid.RowDefinitions>
                        <RowDefinition Height="auto" />
                        <RowDefinition  Height="*"/>
                    </Grid.RowDefinitions>
                    <StackPanel Orientation="Horizontal">
                        <Button x:Name="hamburgButton" FontFamily="Segoe MDL2 Assets" Content="&#xE700;" FontSize="24" Command="{Binding HamburgButtonCommand}" />
                        <TextBlock Margin="10,10,0,0" Text="{Binding HamburgTitle}" />
                    </StackPanel>
                    <ListView Grid.Row="1" x:Name="mainListView" ItemsSource="{Binding MenuItems}" ItemTemplate="{StaticResource MenuItemDataTemplate}" />
                </Grid>
            </SplitView.Pane>
            <Frame>
                
            </Frame>
        </SplitView>

    </Grid>
</Page>

2.ViewModel

    public class MainViewModel : NotficationObject
    {
        private ObservableCollection<MenuItem> _menuItems;
        /// <summary>
        /// 漢堡菜單集合
        /// </summary>
        public ObservableCollection<MenuItem> MenuItems
        {
            get { return _menuItems; }
            set
            {
                _menuItems = value;
                ProperyChange("MenuItems");
            }
        }

        private bool _isPaneOpen;
        /// <summary>
        /// 漢堡菜單是否打開
        /// </summary>
        public bool IsPaneOpen
        {
            get { return _isPaneOpen; }
            set
            {
                _isPaneOpen = value;
                ProperyChange("IsPaneOpen");
            }
        }

        private string _hamburgTitle;

        /// <summary>
        /// 漢堡菜單標(biāo)題名稱
        /// </summary>
        public string HamburgTitle
        {
            get { return _hamburgTitle; }
            set
            {
                _hamburgTitle = value;
                ProperyChange("HamburgTitle");
            }
        }

        public MainViewModel()
        {
            HamburgTitle = "漢堡菜單";

            MenuItems = new ObservableCollection<MenuItem>()
            {
                 new MenuItem() { Icon=Symbol.People,Text="People"},
                 new MenuItem() { Icon=Symbol.Phone,Text="Phone" },
                  new MenuItem() { Icon=Symbol.Message, Text="Message"},
                   new MenuItem() { Icon=Symbol.Mail,Text="Mail"}
            };
            HamburgButtonCommand = new DelegateCommand();
            HamburgButtonCommand.ExecuteAction = new Action<object>(HamburgButton);
        }

        public DelegateCommand HamburgButtonCommand { get; private set; }

        private void HamburgButton(object paramenter)
        {
            IsPaneOpen = IsPaneOpen ? false : true;
        }
    }

3.使用
在MainView的構(gòu)造函數(shù)中添加如下代碼即可。

DataContext = new MainViewModel();

4.源碼
度娘盤

參考地址:DataBinding msdn

END

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末枉层,一起剝皮案震驚了整個(gè)濱河市泉褐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌鸟蜡,老刑警劉巖膜赃,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異揉忘,居然都是意外死亡跳座,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門泣矛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來疲眷,“玉大人,你說我怎么就攤上這事您朽】袼浚” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵哗总,是天一觀的道長(zhǎng)几颜。 經(jīng)常有香客問我,道長(zhǎng)魂奥,這世上最難降的妖魔是什么菠剩? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮耻煤,結(jié)果婚禮上具壮,老公的妹妹穿的比我還像新娘。我一直安慰自己哈蝇,他們只是感情好棺妓,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著炮赦,像睡著了一般怜跑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天性芬,我揣著相機(jī)與錄音峡眶,去河邊找鬼。 笑死植锉,一個(gè)胖子當(dāng)著我的面吹牛辫樱,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俊庇,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼狮暑,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了辉饱?” 一聲冷哼從身側(cè)響起搬男,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎彭沼,沒想到半個(gè)月后缔逛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體默赂,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡救湖,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年弛车,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秘血。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片昔榴。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡枕扫,死狀恐怖卵酪,靈堂內(nèi)的尸體忽然破棺而出的诵,到底是詐尸還是另有隱情望众,我是刑警寧澤匪补,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站烂翰,受9級(jí)特大地震影響夯缺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜甘耿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一踊兜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧佳恬,春花似錦捏境、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至倾剿,卻和暖如春筷频,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工凛捏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留担忧,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓葵袭,卻偏偏與公主長(zhǎng)得像涵妥,于是被迫代替她去往敵國(guó)和親乖菱。 傳聞我的和親對(duì)象是個(gè)殘疾皇子坡锡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容