js 杂谈
js解释器有自己的内存管理机制(垃圾回收:自动回收无引用指向对象)
js采用一种数字类型(64位浮点数),100与1e2完全相等
条件判断是被当为假的值:false、null、undefined、‘’、0、NaN
Infinity 属性用于存放表示正无穷大的数值。-Infinity 属性用于存放表示负无穷大的数值
数字、字符串、布尔值不可变,不是对象,对象是可变的键控集合(如:数组、函数、正则表达式、对象)。
NaN!==NaN (不等于自己的数)
isNaN() (NaN或者非数字如对象,返回true)
isFinite() (不是NaN Infinity -Infinity 时返回 true)
0===-0 1/0!==1/-0 (正负无穷不等)
if(undefined){} if语句将undefined转换为false, ‘==’ 运算符从不试图将其操作数转换为布尔值
String(false) 'false'
除null、undefined,都有toString()方法
+运算符的一个操作数是字符串,会把另外一个操作数转换为字符串 x+‘’ == String(x)
一元+将操作数转换为数字 +x == Number() == x-0
一元!将操作数转换为布尔值并取反 !!x == Boolean(x)
var n=17 ; n.toString(2) // ' 10001'
Number类 var n=12.78; n.toFixed(0) 13
Number()只能基于十进制转换,且str不能出现非法的尾随字符
parseInt()、parseFloat()是全局函数,不从属于任何类的方法,更加灵活
所有对象转到原始布尔值时均为true new Boolean(false) 是对象,为true
var i=1,j=++i; // 2 2
var i=1,j=i++; // 2 1
'one' <3 // false(其中一个操作数是NaN ,比较操作符总数返回false)
0==-0 0===-0 true
11<3
'11'>3 (任意一个不是字符串,比较)
'11'<'3' (两个都是字符串时,字符串比较)
&& ‘短路’(即:只有当左侧表达式运算为true时才开始计算第二个表达式)
if(a==b) stop() (a==b) && stop() (只有当a==b为真时执行stop)
三元运算符
x>0?x:-x;
str='name'+(username?username:'hello');
(typeof val=='string') ? "'"+val+"'":val
typeof 区分对象与原始值
instanceof \class\constructor 区分对象的类
原始类型 属性调用解释、存储机制 (容错处理)
var str='123'
str.length 3 // new String(123) new String(123).length
str.a='a' str.a - undefined // new String(123) new String(123).a='a' delete new String(123).a str.a new String(123).a undefined
var a=0; a = (a++) + (++a) - (a++) - (a++); // -3 0/1 + 2/2 - 2/3 -3/4
换为字符串
'' + 10 === '10'; // true
转换为数字
+'10' === 10; // true
Number('010') === 10
parseInt('010', 10) === 10 // 用来转换为整数
转换为布尔型
!!'foo'; // true
js注释优选行注释 // (/* */ 块注释与正则表达式冲突)
一种面向对象语言需要向开发者提供四种基本能力:
封装 - 把相关的信息(无论数据或方法)存储在对象中的能力 (。dll、class-class)
聚集 - 把一个对象存储在另一个对象内的能力
继承 - 由另一个类(或多个类)得来类的属性和方法的能力
多态 - 编写能以多种方法运行的函数或方法的能力 (龙生九子各不相同)
<script src="js/require.js" defer async="true" ></script>
异步加载
js库细则
1.不要使用版本检测,而要使用能力检测
2.使用命名空间
3.()在JavaScript中有两种含义:一是运算符;二是分隔符。
js中对象是可变的键控集合,除了number string Boolean null undefined,其他都是对象。
js中,每个对象都连接到一个原型对象,并且从中继承属性,
所有通过对象字面量创建的对象都连接到 Object.prototype 这个标准的js对象。
(函数对象连接到 Function.prototype ,该原型本身又连接到 Object.prototype ,
同时,每个函数在创建时附有两个隐藏属性:函数上下文,实现函数行为的代码
)
原型连接在更新时不起作用,对某个对象做出改变不会触及原型
原型连接在检索时: 对象本身属性 - Object.prototype ,这一过程就是委托。
原型关系是动态关系,添加属性到原型,所有基于此原型的对象即时拥有此属性。
hasOwnProperty方法不检查原型链
fight.hasOwnPreperty("number") //true
fight.hasOwnPreperty('constructor') //false
var obj = {
"name":"wj",
"age":27
};
for( ele in obj ){
if (obj.hasOwnProperty(ele)) {
console.log(ele,obj[ele]);
};
};
delete 可删除对象属性,不会触及原型链中对象及其属性
(删除对象属性可以让来自原型链中属性浮现出来)
函数 包含一组语句 是js基础模块单元
用于代码复用、信息隐藏、组合调用(指定对象行为)
编程,就是将一组需求分解成一组函数与数据结构的技能。
通过函数字面量创建的函数对象包含一个连接到外部上下文的链接,这就是闭包。
调用运算符 是 函数表达式后的一对圆括号
js 杂谈的更多相关文章
- Js杂谈-DOM
前言 对jQuery的依赖.导致js的原生方法的淡忘,如果是封装自己的库,那势必要用到js的许多原生方法.从Jquery强大的dom处理开始,我们开始回顾javascript那些古老而坚挺的DOM方法 ...
- Js杂谈-插件包读后感
最近有幸得到了一份项目上的前端封装的插件库代码,花了一个下午时间,仔细地研读了一下.对于我很想做自己的类库,搞自己的组件包很有启蒙意义. 相比较我之前阅过的框架或是类库,这份比较简单. 项目是jQue ...
- Js杂谈-正则的测试与回溯次数
例子来源于<精通正则表达式(第三版)>这本书,我贴出来: 这里的NFA是正则的一种引擎,书中介绍了一共三种引擎:NFA,DFA和POSIX NFA.像一般我们常用的.NET,java.ut ...
- Js杂谈-单体模式
单体模式的思想:保证一个特定类仅有一个实例,意味着第二次使用同一个类创建新对象的时候,应该得到与第一次所创建对象完全相同的对象. 下面举几个实现的例子 1.new操作符 这种思想在于当使用同一个构造函 ...
- 2014 Hangjs 见闻流水账第二天
前言 第一天传送门: 2014 Hangjs 见闻流水账第一天 写作风格跟第一天还是一样的. Slide 每个slide我都会根据自己的理解重新命名一次,用于表达自己的第一看法,主观意见,不喜可吐槽, ...
- iframe自适应高度(转)
iframe自适应高度 (2013-04-23 17:29:49) 标签: iframe 高度 自适应 js 杂谈 分类: 网页制作 有时候我们的网站需要引入其他网站的东西,比如评论,这时候就需要使用 ...
- Esri的开源JS项目杂谈
一提到Esri大家首先想到的是庞大的ArcGIS产品大家族,其产品包含从桌面端,到服务器/云端,再到web/移动端.作为一名极客,不聊开源逼格似乎上不去啊.其实,Esri作为一个开放的平台,不仅有稳定 ...
- JS,JQuery杂谈
JS返回页面: JS返回前一个页面,经常看到有人用window.history.go(-1)这种方法 这种放的确可以返回,也仅仅只是返回,返回的页面信息却没有刷新.也有人用windows.histo ...
- <经验杂谈>介绍Js简单的递归排列组合
最近在开发SKU模块的时候,遇到这样一个需求,某种商品有N(用未知数N来表示是因为规格的数组由用户制定且随时可以编辑的,所以对程序来说,它是一个未知数)类规格,每一类规格又有M个规格值,各种规格值的组 ...
随机推荐
- 豆瓣API接口开发,结合angularJS来做,感觉爽歪歪!
第一次做还是先说下API 是什么鬼? API : application program interface 应用程序编程接口: 有那些常见的API: webAPI : 通过WEB方式提供结构叫 WE ...
- 素数测试算法(基于Miller-Rabin的MC算法) // Fermat素数测试法
在以往判断一个数n是不是素数时,我们都是采用i从2到sqrt(n)能否整除n.如果能整除,则n是合数;否则是素数.但是该算法的时间复杂度为O(sqrt(n)),当n较大时,时间性能很差,特别是在网络安 ...
- jQuery Ajax 全解析(转载)
本文地址: jQuery Ajax 全解析 本文作者:QLeelulu 转载请标明出处! jQuery确实是一个挺好的轻量级的JS框架,能帮助我们快速的开发JS应用,并在一定程度上改变了我们写Java ...
- spring cloud多个消费端重复定义feign client问题
spring cloud消费端调用服务提供者,有两种方式rest+ribbon和Feign,Feign是一个声明式的伪Http客户端更为简单易用,所以我们项目选用Feign作为服务通讯方式 项目有6个 ...
- HDU 1403 Eight&POJ 1077(康拖,A* ,BFS,双广)
Eight Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
- 让ASP.NET OutputCache使用http.sys kernel-mode cache
在默认情况下,http.sys kerne mode cache只缓存静态文件. 那我们如何让ASP.NET OutputCache直接使用http.sys kerne mode cache?这样缓存 ...
- HDU_5517_Triple
Triple Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
- Qt 模拟鼠标点击(QApplication::sendEvent(ui->pushbutton, &event0);)
QPoint pos(0,0);QMouseEvent event0(QEvent::MouseButtonPress, pos, Qt::LeftButton, Qt::LeftButton, Qt ...
- Python并行编程(十二):进程同步
1.基本概念 多个进程可以协同工作来完成一项任务,通常需要共享数据.所以在多进程之间保持数据的一致性就很重要,需要共享数据协同的进程必须以适当的策略来读写数据.同步原语和线程的库类似. - Lock: ...
- Python总结篇——知识大全
python基础 Python开发环境搭建 Python变量和基本数据类型 python基本数据类型之操作 python的语法规范及for和while python编码 python文件操作 pyth ...