[英]When do we need to set ProcessStartInfo.UseShellExecute to True?
[英]When do we need to use [Browsable(true)]?
我们什么时候需要使用[Browsable(true)]
?
编辑 (由SLaks):他问(我假设)为什么人们需要传递true
作为参数,因为默认情况下它已经是true
。
MSDN说明了一切 :
指定是否应在“属性”窗口中显示属性或事件。
例如,如果您正在创建用户控件,则可能需要使用[Browsable(false)]
修饰与UI无关的属性,以便通过“属性”窗口无法使用它们。
此外,它还可以控制PropertyGrid
可以看到对象的哪些属性。
至于为什么我们可以明确地传递true
,我相信这是由于PropertyGrid
BrowsableAttributes
属性。 您可以将其设置为包含BrowsableAttribute.No
,以便属性网格将显示所有不可浏览的成员。
可能当你想确定没有人改变它时:P
// I want to see this, dont change it to false or I'll hunt you down...
[Browsable(true)]
public int MyProperty {
get {
// Insert code here.
return 0;
}
set {
// Insert code here.
}
}
问题是默认情况下可以浏览。 我能想到的唯一场景是覆盖一个成员并改变可浏览性......这里F
只是因为派生类中的[Browsable(true)]
而可见 - 没有它,它是不可见的。
using System.ComponentModel;
using System;
using System.Windows.Forms;
static class Program
{
[STAThread]
static void Main() {
Application.EnableVisualStyles();
Application.Run(new Form { Controls = {new PropertyGrid {
Dock = DockStyle.Fill, SelectedObject = new Bar()
}}});
}
}
public class Foo
{
public virtual string A { get; set; }
public virtual string B { get; set; }
public virtual string C { get; set; }
[Browsable(false)] public virtual string D { get; set; }
[Browsable(false)] public virtual string E { get; set; }
[Browsable(false)] public virtual string F { get; set; }
[Browsable(true)] public virtual string G { get; set; }
[Browsable(true)] public virtual string H { get; set; }
[Browsable(true)] public virtual string I { get; set; }
}
public class Bar : Foo
{
public override string A { get { return base.A; } set { base.A = value; } }
[Browsable(false)] public override string B { get { return base.B; } set { base.B = value; } }
[Browsable(true)] public override string C { get { return base.C; } set { base.C = value; } }
public override string D { get { return base.D; } set { base.D = value; } }
[Browsable(false)] public override string E { get { return base.E; } set { base.E = value; } }
[Browsable(true)] public override string F { get { return base.F; } set { base.F = value; } }
public override string G { get { return base.G; } set { base.G = value; } }
[Browsable(false)] public override string H { get { return base.H; } set { base.H = value; } }
[Browsable(true)] public override string I { get { return base.I; } set { base.I = value; } }
}
ComponentModel中的类型和属性并不特定地绑定到任何特定的设计器。 虽然我不知道你需要“选择加入”设计师可浏览的任何特定场景,但我想可以想象你可以让一些组件设计师假设可浏览(错误)。
我想你也可以覆盖一个指定了browsable(false)的虚拟属性,并在重写的成员中应用browsable(true)。
BrowsableAttribute类(System.ComponentModel)
文件说明:
可视化设计器通常在“属性”窗口中显示那些没有可浏览属性或标记为BrowsableAttribute构造函数的可浏览参数设置为true的成员。
[Browsable]
也默认为true。
......从技术上讲,你永远不需要[Browsable(true)]
除非你想要非常明确。
可视化设计器通常在“属性”窗口中显示那些没有可浏览属性或标记为BrowsableAttribute构造函数的可浏览参数设置为true的成员。 可以在设计时修改这些成员。 标有BrowsableAttribute构造函数的可浏览参数设置为false的成员不适合设计时编辑,因此不会显示在可视化设计器中。 默认值为true 。
所以,答案是你永远不必 ,因为它是默认完成的。
根据文档 ,当它应该显示在VS的属性窗口中时,您希望它是真实的。 基本上它适用于设计器中使用的类。
此属性变得重要的一个例子是在Sharepoint的WebPart开发期间。 在这种情况下,您将为Sharepoint提供元信息,以确定您的webpart是否应该可供选择等。还有其他类似的属性,如Category和FriendlyName等,这些也被考虑在内。
请参阅以下示例:
另一个有sharepoint webpart编辑器的图像反映了你的属性:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.