博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
win8: WinJS的面向对象 WinJS.Class
阅读量:7145 次
发布时间:2019-06-29

本文共 2029 字,大约阅读时间需要 6 分钟。

官方文档:

 类定义

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(); } }    });

 

 继承

 

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

 

它通过调用 使用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;

 混合类

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();

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

More info about mix , Check:

 

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

你可能感兴趣的文章
如何通过扫描二维码下载多版本APP
查看>>
他看了几千份技术简历,愿意把技术简历的秘籍传授给你
查看>>
safari Iframe 溢出 body
查看>>
[译]基于 React Router 4 的可复用 Layout 组件
查看>>
前言与链表实现数组
查看>>
Python - jieba分词
查看>>
使用nodejs自带debug工具调试nodejs
查看>>
JavaScript 闭包
查看>>
Docker再曝安全漏洞,这次是PWD的问题
查看>>
2017敏捷沙滩大会概述:学习、心理安全和持续交付的重要性
查看>>
管理众包测试
查看>>
机器学习研究的七个迷思
查看>>
响应式布局设计
查看>>
马蜂窝张矗:绩效考核是为了激发工作潜力,而不是逃避问题
查看>>
ChaosConf 2018:混沌实验的演变
查看>>
区块链技术精华:四十种智能合约支持平台(三)
查看>>
MySQL · B+树并发控制机制的前世今生
查看>>
ArchSummit全球架构师峰会 重新定位架构师的价值
查看>>
微软在C# 8中引入预览版可空引用类型
查看>>
FoundationDB宣布记录层支持关系数据库语义、模式管理和索引功能
查看>>