当前位置: 首页 > news >正文

.net做的网站代码计算机网络技术培训

.net做的网站代码,计算机网络技术培训,海南网站建设开发,网站备案中是什么意思目录类一些常见原理混入行为委托委托理论类与对象更妙的设计与语法类型冷门关键词typeof 防范机制值原生函数访问内部属性类 一些常见原理 在继承或者实例化时,JavaScript 的对象机制并不会自动执行复制行为; 多态:JS 中的多态&#xff0c…

目录

        • 一些常见原理
        • 混入
      • 行为委托
        • 委托理论
        • 类与对象
        • 更妙的设计与语法
      • 类型
        • 冷门关键词
        • typeof 防范机制
      • 原生函数
        • 访问内部属性

一些常见原理

在继承或者实例化时,JavaScript 的对象机制并不会自动执行复制行为;

多态:JS 中的多态,子类是只能通过 super 得到父类的一个复制,而非父类的原本实力对象,所以子类只要不重写父类对应的方法,那么两个类之间就完全没有影响;

JS没有多继承机制!


混入

即从一个对象中复制所有属性到一个新对象里面去;
这是一个最简单的混入代码:

function mixin(source, target) {// 遍历原对象的所有属性for (var ket in source) {// 若新对象内和原对象属性没有重合,那么复制if (!(key in target)) {target[key] = source[key];}}// 返回新对象return target;
}

行为委托

委托理论

即定义一个父对象,并定义很多个子对象来存储对应的数据和行为,把特定的任务对象都关联到父对象上,让子对象们在需要的时候可以进行委托;

下面是一个简短的委托代码
Task 定义了一个父对象;
SubTask 使用 Object.create 所创建,这样就委托了父对象 Task;
子对象 SubTask 即可添加新的方法或者任意属性了!

注意:
委托者:SubTask,委托目标:Task
为 SubTask 新增的方法 prepareTask 是存储在 SubTask 内部的!
委托者必须尽量少的重写委托目标中的方法或者属性,否则会导致引用歧义

Task = {setID: function (ID) {this.id = ID;},outputID: function () {console.log(this.id);},
};
// 让SubTask委托Task
SubTask = Object.create(Task);
SubTask.prepareTask = function (ID, label) {this, setID(ID);this.label = label;
};

其他注意事项

  1. 无法在两个或两个以上互相(双向)委托的对象之间创建循环委托

类与对象

ES6 提供的 class 实际上依然是通过 prototype 机制实现的,因为 js 实际上并没有真正意义上的类

例子:创建一个 widget 类,并且其下有一个子类 button
对相关联风格委托方式写法:(下方代码中的单个$符号是我们引用 jQuery 后使用的!)

使用委托设计模式,可避免丑陋的显示伪多态调用!

var Widget = {init: function (width, height) {this.width = width || 50;this.height = height || 50;// $elem代表一个元素,这里先初始化为nullthis.$elem = null;},// 向指定位置插入元素,并且为元素赋予默认的width和heightinsert: function ($where) {if (this.$elem) {this.$elem.css({width: this.width + "px",height: this.height + "px",}).appendTo($where);}},
};var Button = Object.create(Widget);Button.setup = function (width, height, label) {// 委托调用this.init(width, height);this.label = label || "default";// 使用jQuery中的$来向指定元素插入text属性!this.$elem = $("<button>").text(this.label);
};

更妙的设计与语法

类实例内省:通过创建方式来判断对象的结构和功能。
以下代码展示了通过 instanceof 来推测对象的功能,也就是内省过程

function Foo() {}
Foo.prototype.method = function () {};
var a1 = new Foo();
if (a1 instanceof Foo) {a1.method();
}

类型

冷门关键词

因为 typeof 返回对应数据的类型,是一个字符串,所以一下结果毅然返回 string
typeof typeof 43

undefined!=undeclared
然而,使用 typeof 取 undefined 和 undeclared 的值返回的都是 undefined

var a;
a; // undefined
b; // undeclared

typeof 防范机制

可以使用 typeof 检测一个全局变量是否是 undefined,如果是的话就重新声明一个!
typeof function !== "undefined"


在 ES6 中(早期版本是没有 SAFE 和这个修饰的!):
整数的最大值:Number.MAX_SAFE_INTEGER
整数的最小值:Number.MIN_SAFE_INTEGER

NaNs 是特殊值,它和自身不相等,是唯一一个非自反值
即存在 NaN != NaN 返回 true


原生函数

访问内部属性

访问对象的内部属性需要使用以下方法

Object.prototype.toString.call("123");
// 返回 [Object string]

http://www.yayakq.cn/news/358240/

相关文章:

  • 山东省建设工会网站黄岩网站开发
  • 电影网站app怎么做的做网站 负责 域名备案
  • 网站宜昌高端大气
  • 青海兴远建设工程有限公司网站网站开发如何搭建框架
  • 专门建设网站的公司企业网站建设单位
  • 分享信息的网站富锦建设局网站
  • 做面食的网站深圳网站建设-中国互联
  • 安徽安搜做的网站怎么样任何东西都能搜出来的软件
  • 鲜花网站素材免费网站建设凡科
  • 门户网站开发万网和慧聪网
  • 怎么做网站在线玩游戏建站平台费用
  • 建设银行考试报名网站怎么建个免费英文网站
  • 电商网站建设任务分解结构网络营销典型推广案例
  • 做房地产网站广告销售个人网站转为企业网站
  • 西安网站建设求职简历网站购买广告位
  • 网站建设实验步骤百度首页网站的设计
  • 安徽住房和建设网站贵阳网站制作费用
  • 上海建设银行招聘网站wordpress 旅行社
  • 那个网站可以做链接网站建设推广方案模版
  • 网站制作网站维护牌子网排行榜
  • 做网站要什么语言建设久久建筑网站
  • 中国建设银行英语网站首页wordpress模板查询
  • 网站代备案流程图基础微网站开发代理商
  • 宁波做企业网站公司宁波seo排名方案优化
  • 五合一免费建站ai生成建筑网站
  • 上海人才招聘哪个网站好网站 多个ip 备案
  • 布吉网站建设多少钱美食网站建设实施方案
  • 广州市网站建设 骏域腾冲住房和城乡建设局网站
  • 厦门网站制作网站建设收费实物黄金哪个网站做的好
  • 中山最好的网站建设宁波网络推广方案公司推荐