发布网友 发布时间:2022-04-23 12:05
共2个回答
懂视网 时间:2022-05-05 02:46
使用enum property BOM2 项目中需要有一个单独的script控制mode的切换,其他scipt根据这个mode切换到哪一个enum来决定该mode下的一些功能的开启。一开 始我用的是inspector的方法,在enum的script里控制enum选择的值,然后在需要做判断的script里创建一个pub
使用enum property
BOM2 项目中需要有一个单独的script控制mode的切换,其他scipt根据这个mode切换到哪一个enum来决定该mode下的一些功能的开启。一开 始我用的是inspector的方法,在enum的script里控制enum选择的值,然后在需要做判断的script里创建一个public变量来接 受enum值的变化。后来我改为完全用类的enum方法实现。
//ModeSelector.cs using UnityEngine; using System.Collections; public enum ModeEnum { AssemblyView, TearView, ProfileView, TiffView } public class ModeSelector : MonoBehaviour { private static int myVar; public static ModeEnum ModeEnumProperty { get { return (ModeEnum)myVar; } set { myVar = (int)value; } } // Use this for initialization void Start() { ModeEnumProperty = ModeEnum.AssemblyView; } // Update is called once per frame void Update() { } void OnGUI() { if (GUI.Button(new Rect(Screen.width / 2 - 150, 50, 100, 20), "Tear Apart")) { ModeEnumProperty = ModeEnum.TearView; } if (GUI.Button(new Rect(Screen.width / 2 + 50, 50, 100, 20), "3D Viewer")) { ModeEnumProperty = ModeEnum.AssemblyView; } } }
//NavigationControl.cs OnGUI() { ... if(ModeSelector.ModeEnumProperty == ModeEnum.AssemblyView) { //something to do } ... }
热心网友 时间:2022-05-04 23:54
知道了这些,我们就可以把属性的遍历分为四种情况.
注:示例代码中,我们要遍历的对象是浏览器中的window,环境为Firefox 19,代码运行在空白页面中的script标签里.没有Firebug或者其他调试工具的影响(会导入一些全局变量,console等).
1.遍历可枚举的自身属性
可枚举的意思就是该属性的[[Enumerable]]特性为true,自身属性的意思就是该属性不是从原型链上继承下来的.
(function () {
var propertys = Object.keys(window);
alert(propertys.length); //3
alert(propertys.join("\n")); //window,document,InstallTrigger,除了最后一个是火狐私有的属性,原来window对象只有两个可枚举的自身属性.window属性指向window对象自身,一般没什么用.
})()
2.遍历所有的自身属性
特性为不可枚举的属性也并不是遍历不到,ES5给我们提供了getOwnPropertyNames方法,可以获取到一个对象的所有自身属性.
(function () {
var propertys = Object.getOwnPropertyNames(window);
alert(propertys.length); //72
alert(propertys.join("\n")); //Object,Function,eval等等
})()
3.遍历可枚举的自身属性和继承属性
继承属性怎么遍历,你应该知道,就是最常用的for in遍历
(function () {
var getEnumPropertyNames = function (obj) {
var props = [];
for (prop in obj) {
props.push(prop);
}
return props;
}
var propertys = getEnumPropertyNames(window);
alert(propertys.length); //185
alert(propertys.join("\n")); //addEventListener,onload等等
})()
4.遍历所有的自身属性和继承属性
这种遍历主要用在各种js调试工具的代码补全功能上.比如Firebug的.
(function () {
var getAllPropertyNames = function (obj) {
var props = [];
do {
props = props.concat(Object.getOwnPropertyNames(obj));
} while (obj = Object.getPrototypeOf(obj));
return props;
}
var propertys = getAllPropertyNames(window);
alert(propertys.length); //276
alert(propertys.join("\n")); //toString等
})()