`
lindexi-gd
  • 浏览: 140183 次
社区版块
存档分类
最新评论

win10 uwp ContentDialog 点确定不关闭

 
阅读更多

微软的ContentDialog不是一直有,而是UWP新的,可以使用Content放用户控件,使用很好,但是一点不好的是,默认的一点击下面按钮就会退出。

我们有时候需要ContentDialog用户输入,而用户没有输入我们想要的,给用户提示,不退出

那么要解决ContentDialog自动退出有两个方法:

第一个很简单,第二个更简单

简单的方法,做一个类继承ContentDialog,然后加一个属性

        /// <summary>
        /// 对话完成,如果没有完成会继续显示
        /// </summary>
        public bool Complete
        {
            set;
            get;
        }

在Closing判断他是不是为false,如果是,那么取消,取消在e那里

这个简单,就不放代码。

第二个方法,为什么我们要使用自带的按钮?其实可以在我们的控件自己写按钮

那么有新的问题,自己写按钮,那么怎么退出,其实我们可以使用ContentDialog的Hide()方法,这个方法可以让ContentDialog退出,是默认关闭。

我做到这发现,自己做的控件按钮实在有点麻烦,不如用一个简单的方法,我们在我们控件加个属性

        /// <summary>
        /// 对话完成,如果没有完成会继续显示
        /// </summary>
        public bool Complete
        {
            set;
            get;
        }

当然在PrimaryButtonClick,如果输入和我们要的一样,Complete = true; SecondaryButtonClick就不需要判断Complete = true;

在最后

            while (!控件.Complete)
            {
                await contentDialog.ShowAsync();
            }

知识共享许可协议
本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接:http://blog.csdn.net/lindexi_gd ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系

<script type="text/javascript"> $(function () { $('pre.prettyprint code').each(function () { var lines = $(this).text().split('\n').length; var $numbering = $('<ul/>').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($('<li/>').text(i)); }; $numbering.fadeIn(1700); }); }); </script>
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics