[06] JavaScript 类型
下面对知识点总结:
1.类型分类
a.原始类型:number, string, boolean, null, undefined
b.对象类型:除了原始类型都是(例如:object,array, function, new xxx[构造函数 class对象 Date, RegExp, Error])
备注:NAN,非数字,与任何值都不等,包括NAN
2.浮点数的计算差值
任何二进制浮点数的编程语言中,都会出现以下问题.因此我们在金融的计算业务中,使用整数计算(例如使用1分代替0.01元)
var a = 0.3 - 0.2;
var b = 0.2 - 0.1;
console.log( a == b); // false
3.对象
3.1 对象的遍历方式
for ....in : 遍历自己可枚举的属性+ 继承的可枚举属性
Object.isOwnProperty(Object, property): 判断是否是自己的属性
3.2 对象的属性
对象上有两种属性:一般的属性和存取器属性。
var object = {
x: 10, // 一般属性
get y() { return 3*this.x},
set y(num) { this.x = num + this.x;}
}; object.y // 30 object.y = 20; // x = 30; object.y // 120
3.3 属性的特性: 值,可写,可枚举,可配置 || 存取器属性:读取(get), 写入(set), 可枚举,可配置
例如例子,复制属性的特性
Object.defineProperty(Object.prototype,
'extend',
{
writable: true,
enumerable: false,
configurable: true,
value: function(o) {
var names = Object.getOwnPropertyNames(o);
for( var i = 0; i < names.length; i ++) {
console.log(name[i]);
if(names[i] in this) {
continue;
}
else {
Object.defineProperty(this, names[i], Object.getOwnPropertyDescriptor(o, names[i]))
}
} }
}
) var a = {x:1};
var b ={y: 2};
a.extend(b); //{x:1,y: 2}
3.4 创建对象
1.字面量创建
var object = {a: 1}; // prototype: Object.prototype
Object.prototype.isPrototypeOf(object); // true
2. new 方式创建
function a() {}
var object = new a(); // prototype: a.prototype
object.__prop__ == a.prototype; // true a.prototype
a.prototype.isPrototypeOf(object); // true
3.Object.create()
var object = Object.create({y: 1}); // prototype: Object.prototype:
Object.prototype.isPrototypeOf(obejct); // true // Object.prototype: 就是Object的构造函数
// a.prototype: 就是a的构造函数
3.5 对象的三个属性
a.prototype
b.class 类属性
一般是取对象的toString()方法的第8个到倒数第二个位置的字符串
function A() {}
console.log(A.toString().substring(8, -1)); // Function 如果toString方法被重写,就不可以通过这种方式完成,可以通过以下方式:
function classOf(o) {
if(o === null ) { return 'null'};
if(o === undefined) { return 'undefined'}
return Object.prototype.toString.call(o).slice(8,-1)
}
function A() {}
classOf(A) // Function
c.可拓展性
表示对象是否可以添加新的属性。
Object.isExtensible(): 判断是否可拓展
Object.preventExtensions(obj); // 设置不可拓展 // 与上同理,但是可以将属性设置为不可配
Object.isSealed()
Object.seal(obj) //冻结, 更严格锁定对象,不仅可以设置不可拓展和将属性设置为不可配,可以将所有数据设置为只读(存取器属性不受影响)
Object.freeze()
Object.isFrozen()
[06] JavaScript 类型的更多相关文章
- 前端06 /JavaScript之BOM、DOM
前端06 /JavaScript 目录 前端06 /JavaScript 昨日内容回顾 js的引入 js的编程要求 变量 输入输出 基础数据类型 number string boolean null ...
- javascript类型与类型检测
1.javascript类型: 注:包装对象:如"hello".length实际为js为我们隐式创建了一个String临时对象,去调用该对象的length属性,调用过后再将该临时对 ...
- javascript类型注意事项
以下是javascript类型的注意事项: null:表示尚未存在的对象,注意,尽管尚未存在,也是个对象啊,所以用typeof检测一个null值变量的结果是Object:不过,为了便于写if语句,在j ...
- 谈谈JavaScript类型检测
javascript内置的类型检测机制并非完全可靠.比如typeof操作符,并不能准确的判断数据是哪个类型,比如:数组和对象就不能通过typeof来区分. typeof [] ==="o ...
- Javascript类型检测
原地址 http://www.cnblogs.com/fool/archive/2010/10/07/javascrpt.html 开门见山,我们先来看一下代码: var is = function ...
- JavaScript 类型浅解
对于JavaScript 类型,可简单地概括为:相对于强类型语言来说,它是弱(松散)类型的语言:有基本类型和引用类型,他们是区别是一个有固定空间存在于栈内存中,一个没有固定空间保存在堆内存中并且在栈内 ...
- JavaScript类型和语法
JavaScript类型和语法 一.类型 1.内置类型(null.undefined.boolean.number.string.object.symbol(es6中新增))(除对象之外,其它统称为基 ...
- 12.06 JavaScript
任务 掌握JavaScript基础知识,能够使用JavaScript编写一些复杂度不大的交互功能. 任务: JavaScript基础 做完任务一的时候深深地感觉到自己的基础非常的薄弱,在这里再次感谢一 ...
- JavaScript权威设计--JavaScript类型,值,变量(简要学习笔记三)
1.负号是一元求反运算 如果直接给数字直接量前面添加负号可以得到他们的负值 2.JavaScript中的运算超出了最大能表示的值不会报错,会显示Infinity. 超出最小也不报错,会显示-I ...
随机推荐
- MVC中路由的修改和浏览器的地址参数
在 ASP.NET MVC 应用程序中,它是更常见的做法在作为路由数据 (像我们一样与身份证上面) 比将它们作为查询字符串传递的参数中传递. ) { return HttpUtility.HtmlEn ...
- Android各版本代号、版本号、API/NDK级别、发布时间
代号 版本号 API/NDK级别 发布时间 牛轧糖 Nougat 7.1.2 API level 25 2017-2 7.1.1 2016-10 7.0 API level 24 2016-05 棉花 ...
- linq里lambda写的join查询,并附加动态拼接的条件,条件为enum类型的查询
因为查询条件不固定的原因,sql式的linq查询没法动态拼接条件. 网上搜的资料整理之后终于解决. 参考资料: enum使用 http://blog.csdn.net/slowlifes/articl ...
- jmeter实例,如果有说明错误,请各位大神批评
首先我们打开jmeter,今天录制的脚本的是获取QQ头像,找了好久才找到可以免费试用的接口,如果有什么错误的地方,欢迎大家提出来,我会及时修改,也给自己一次进步的机会,希望大家不吝赐教!!!如果有什么 ...
- 3、shader深度测试(Cull、ZWrite 、ZTest )
剔除和深度测试是渲染法线中的一个流程 Cull:默认情况下,Unity中给的所有Shader都是单面的,它都把反面的渲染给关闭掉了,如果你在开发的过程中需要使用到双面,只要把cull关闭(off)即可 ...
- 当我们在安装tensorflow时,我们在安装什么?- Intro to TF, Virtualenv, Docker, CUDA, cuDNN, NCCL, Bazel
(Mainly quoted from its official website) Summary: 1. TensorFlow™ is an open source software library ...
- day-13 python库实现简单非线性回归应用
一.概率 在引入问题前,我们先复习下数学里面关于概率的基本概念 概率:对一件事发生的可能性衡量 范围:0<=P<=1 计算方法:根据个人置信区间:根据历史数据:根据模拟数据. 条件概率:B ...
- linux备忘录-正则表达式与文件格式化处理
正则表达式 POSIX标准的符号 [:alnum:] -> 英文大小写字母和数字 0-9,A-Z,a-z [:alpha:] -> 英文大小写字母 A-Z,a-z [:blank:] -& ...
- BZOJ 3925 ZJOI2015 地震后的幻想乡 状压dp+期望
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3925 题意概述: 给出一张N点M边的最小生成树,其中每条边的长度为[0,1]的实数,求最小 ...
- MUI scroll 定位问题
做一个微信项目,使用MUI做框架,在使用scroll定位的时候,出现了定位不准确的问题,查询了好多资料,得知他是相对定位.折腾了好久,才搞定,现在做一个笔记. mui('body').on('tap' ...