js中一些容易混淆的方法
JavaScript中有一些名字十分冗长的函数名称,导致使用时会混乱,特此整理一番,加深印象。
①Object.getOwnPropertyDescriptor ——读取某个对象特定属性的属性描述符(value / writable / enumerable / configurable)
这个方法接受两个参数:(属性所在对象 , 要读取其描述符的属性名称),返回值是一个对象。
var o = Object.getOwnPropertyDescriptor({x : 1}, 'x');
//{value:1, writable:true, enumerable:true, configurable:true}
alert(o); // [object Object]
此方法只能取得自身的属性描述符,无法获得继承属性的特性:
var o = Object.getOwnPropertyDescriptor({}, 'toString');
alert(o); //undefined
②Object.defineProperty ——设置某个对象(单个)属性的特性或让新建属性具有某种特性
这个方法接受三个参数:(要修改的对象 , 要创建或修改的属性 、 属性描述符对象)。
var o = {};
Object.defineProperty(o, 'x', {
value : 1,
writable : true,
enumerable : false,
configurable : true
});
alert(o.x); // 1
Object.defineProperty(o, 'x', {writable : false});
o.x = 2; //不可行,不会报错,但不会修改, o.x = 1;
Object.defineProperty(o, 'x', {value : 2});
alert(o.x); // 2
③Object.defineProperties —— 设置某个对象(多个)属性的特性或让新建属性具有某种特性
这个方法接受两个参数:(修改的对象 , 映射表--包含所有新建或者修改属性的名称和属性描述符)。
Object.defineProperties({}, {
_year : {
value : 2016,
writable : true,
enumerable : true,
configurable : true
},
edition : {
value : 1
},
year : {
get : function(){
return this._year;
},
set : function(newValue){
if(newValue > 2004){
this._year = newValue;
this.edition += newValue - 2004;
}
}
}
});
以上在一个空对象中定义了两个数据属性(_year和edition),还有一个访问器属性(year),这里额属性都是同一时间创立。
④isPrototypeOf ——确定对象与原型之间存在的关系
function Person(){}
var friend = new Person();
alert(Person.prototype.isPrototypeOf(friend)); //true
因为friend对象内部有一个指向Person.prototype的指针,所以返回true。
⑤Object.getPrototypeOf ——方便地取得一个对象的原型
function Person(){}
Person.prototype.name = 'Tom';
var friend = new Person();
alert(Object.getPrototypeOf(friend) == Person.prototype); // true
alert(Object.getPrototypeOf(friend).name); // Tom
ES5中新增的方法,IE9+支持。
⑥hasOwnProperty ——检测一个属性是存在于实例中,还是存在于原型中
function Person(){}
Person.prototype.name = 'Tom';
Person.prototype.sayName = function(){
alert(this.name);
};
var frient1 = new Person();
frient1.name = 'Jery';
var frient2 = new Person();
alert(frient1.hasOwnProperty('name'));
alert(frient2.hasOwnProperty('name'));
使用hasOwnProperty()可以轻松知晓访问的是实例属性还是原型属性了。
js中一些容易混淆的方法的更多相关文章
- 判断js中各种数据的类型方法之typeof与0bject.prototype.toString讲解
提醒大家,Object.prototype.toString().call(param)返回的[object class]中class首字母是大写,像JSON这种甚至都是大写,所以,大家判断的时候可以 ...
- JavaScript -- 时光流逝(五):js中的 Date 对象的方法
JavaScript -- 知识点回顾篇(五):js中的 Date 对象的方法 Date 对象: 用于处理日期和时间. 1. Date对象的方法 <script type="text/ ...
- JavaScript -- 时光流逝(三):js中的 String 对象的方法
JavaScript -- 知识点回顾篇(三):js中的 String 对象的方法 (1) anchor(): 创建 HTML 锚. <script type="text/javasc ...
- 在JS中调用CS里的方法(PageMethods)
在JS中调用CS里的方法(PageMethods) 2014年04月28日 11:18:18 被动 阅读数:2998 最近一直在看别人写好的一个项目的源代码,感觉好多东西都是之前没有接触过的.今天 ...
- Angular.js中处理页面闪烁的方法详解
Angular.js中处理页面闪烁的方法详解 前言 大家在使用{{}}绑定数据的时候,页面加载会出现满屏尽是{{xxx}}的情况.数据还没响应,但页面已经渲染了.这是因为浏览器和angularjs渲染 ...
- JS中的五种去重方法
JS中的五种去重方法 第一种方法: 第二种方法: 第三种方法: 第四种方法: 第五种方法:优化遍历数组法 思路:获取没重复的最右一值放入新数组 * 方法的实现代码相当酷炫,* 实现思路:获取没重复的 ...
- JS中的call()和apply()方法(转)
转自:http://uule.iteye.com/blog/1158829 JS中的call()和apply()方法 博客分类: JS 1.方法定义 call方法: 语法:call([thisOb ...
- JS中的call()和apply()方法
1.方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[, [,.argN]]]]]) 定义:调用一个对象的一个方法,以另一个对象替换当前对象. 说明: call ...
- JS中的call()和apply()方法理解和使用
1.方法定义call方法: 语法:obj.method.call(thisObj[,arg1[, arg2[, [,.argN]]]]) 定义:调用对象(obj)的一个方法(method),以另一个对 ...
随机推荐
- lightoj 1018 (状态压缩DP)
设dp[s]表示状态s下所需要的线段的个数,s的二进制中第x位为1就表示该状态下第x个点没被线段覆盖.需要预处理出来在任意两点之间连线所覆盖点的状态O(n^3),然后记忆化搜索即可. #include ...
- linux常识
一.linux常识 1.为什么学习linux及如何学习linux? 基于linux的操作系统是一种自由和开放源代码的类UNIX操作系统,其定义组件是linux内核,其稳定性.安全性.处理多并发已经得到 ...
- Convert to Objective-C ARC
今天在进行代码走查时,竟然发现了下面这段代码: Bad Code 顿时感觉吐槽无力,虽然我反复强调内存管理问题,无非就是谁申请谁释放,利用强弱引用避免 retain-cycles,但是还是会有这样那样 ...
- matlab 函数说明--fspecial
好吧,这个函数在图像处理中运用得非常广泛,虽然我还是觉得不知道为啥要取这个名字,fspecial的作用如下: 产生一个预定义的2D 滤波器(create a predefined 2D ...
- grails2.3.11第一课
以指令的方式Getting Started 1. 创建一个项目 grails create-app HelloGrails 2. 因为我环境变量中配置的jdk是1.8的,所以我要把这个项目搞到IDEA ...
- MapReduce概述,原理,执行过程
MapReduce概述 MapReduce是一种分布式计算模型,运行时不会在一台机器上运行.hadoop是分布式的,它是运行在很多的TaskTracker之上的. 在我们的TaskTracker上面跑 ...
- HW6.1
import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner i ...
- Send email alert from Performance Monitor using PowerShell script (检测windows服务器的cpu 硬盘 服务等性能,发email的方法) -摘自网络
I have created an alert in Performance Monitor (Windows Server 2008 R2) that should be triggered whe ...
- 利用XSD配合XSLT產出特定格式Word檔案 -摘自网络
利用類別產生XSD檔 產出XSD檔的目的在於提供Word樣板設計之資料框架 在此使用微軟提供之XML Schema Definition Tool (Xsd.exe)工具產生XSD檔 1. 定義類別 ...
- bigData Ecosystem Unscramble
主题>>: cloudEra hadoop Ecosystem sim Unscramble; ruiy哥个人理解总结,其实我无非也还是站在那"砖家/叫兽"的肩上瞎扯扯 ...