win8: WinJS的面向对象 WinJS.Class

简介:

官方文档:http://msdn.microsoft.com/en-us/library/windows/apps/br229776.aspx

WinJS.Class.define 类定义

var object = WinJS.Class.define(constructor, instanceMembers, staticMembers);

三个参数是:构造函数,实例成员集合,静态成员集合。e.g.

复制代码
var Robot = WinJS.Class.define( function(name) {
    this.name = name;
}, 
{ modelName: "" }, 
{ harmsHumans: false });

var myRobot = new Robot("Mickey");

myRobot.modelName = "4500";
Robot.harmsHumans = false;
复制代码

对应的js代码是:

复制代码
function Robot(name) {
    this.name = name;
}

Robot.prototype.modelName = '4500';
Robot.harmsHumans = false;
复制代码

在JS中用 Object.defineProperty 定义modelName GET/SET时我们需要这么做:

Object.defineProperty(Robot.prototype, "modelName", {
    get: function () { this.computeModelName(); }
});

但在WinJS中:

复制代码
var Robot = WinJS.Class.define(
    function (name) { this.name = name; },
    {
        modelName: { get: function () { return this.computeModelName(); } }
    }
);
复制代码

 

WinJS.Class.derive 继承

 

var object = WinJS.Class.derive(baseClass, constructor, instanceMembers, staticMembers);

 

它通过调用Object.create 使用baseClass 的prototype 构造派生对象。

复制代码
var SpaceRobot = WinJS.Class.derive(Robot, function (name) {
    this.name = name;
},
{ airSupply: "" },
{ saveSelf: true });

var mySpaceRobot = new SpaceRobot("Myra");
mySpaceRobot.airSupply = "oxygen";
var save = SpaceRobot.saveSelf;
复制代码

WinJS.Class.mix 混合类

var object = WinJS.Class.mix(constructor);
复制代码
WinJS.Namespace.define("Robotics", {
    Robot: WinJS.Class.define( function(name) {
        this.name = name;
        }, 
        { name: name }, 
        { harmsHumans: false, obeysOrders: true })
    }); 

var Movable = {
    goForward: function () {
        document.getElementById("div").innerText = "go forward";
    },
    goBack: function () {
        document.getElementById("div").innerText = "go back";
    },
    turnRight: function () {
        document.getElementById("div").innerText = "turn right";
    },
    turnLeft: function () {
        document.getElementById("div").innerText = "turn left";
    };

WinJS.Class.mix(Robotics.Robot, Movable);

var myRobot = new Robotics.Robot("Mickey");

myRobot.goBack();
复制代码

当对象与WinJS.Utilities.eventMixin 等混合时,可以获取事件监听的功能等......

More info about mix , Check:http://msdn.microsoft.com/en-us/library/windows/apps/hh967789.aspx

 

 本文转自老Zhan博客园博客,原文链接:http://www.cnblogs.com/mybkn/archive/2012/10/04/2711519.html,如需转载请自行联系原作者

相关文章
|
6天前
|
云安全 人工智能 安全
AI被攻击怎么办?
阿里云提供 AI 全栈安全能力,其中对网络攻击的主动识别、智能阻断与快速响应构成其核心防线,依托原生安全防护为客户筑牢免疫屏障。
|
15天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
10天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
617 215
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
859 61
|
8天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1305 157
|
5天前
|
编解码 Linux 数据安全/隐私保护
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
246 138
|
7天前
|
存储 安全 固态存储
四款WIN PE工具,都可以实现U盘安装教程
Windows PE是基于NT内核的轻量系统,用于系统安装、分区管理及故障修复。本文推荐多款PE制作工具,支持U盘启动,兼容UEFI/Legacy模式,具备备份还原、驱动识别等功能,操作简便,适合新旧电脑维护使用。
539 109