JS框架设计读书笔记之-小知识
这一篇写一点小知识
JS中0.1+0.2为什么不等于0.3?
关于这个问题之前也很疑虑,老师也只是笼统的讲这是JS的语言问题,但是内部具体的情况却没有讲,看了书才发现原理如此简单。
简单来讲,计算机识别的数字长度是有限制的,过大的数字计算会出现infinity或者NAN,这个好理解,但是为什么小数也会出现呢?如果从二进制的角度思考就很简单了,对于一定范围内的正数,总是可以表示成对应的二进制,但是小数就有问题了,十进制的0.5相当于热二进制的0.1,0.25 => 0.01,0.125 => 0.001,0.0625 => 0.0001...那么问题来了,0.1和0.2是多少?从这个规律来看,大概是0.01-0.001与0.001-0.0001的一个数,而且肯定是一个无限循环的数字。前面讲了,数字长度是有限的,碰到这种无限长的,只能从中间砍掉,比如0.1在二进制是0.0001100110011...的循环,可能在某个部位就砍掉了,丢失后面的循环;同理,0.2也被砍掉了,导致的结果就是被砍掉后的0.3000...004
new操作符做了什么?
1. 创建了一个空对象
2. instance.__proto__ = constructor.prototype
3. 将构造函数里面的 this => instance
4. 执行construtor里面的代码
5. 判定构造函数是否有返回值,没有返回默认为undefined,如果返回复合数据类型,直接返回,否则返回this
如何判断浏览器类型
// 判断是否在浏览器环境
var inBrowser = typeof window !== 'undefined';
// window.navigator.userAgent => 获取浏览器信息
// Google Chrome返回下列字符串
// Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36
// IE8返回下列字符串
// Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.1; Win64; x64; Trident/4.0; .NET CLR 2.0.50727; SLCC2; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET4.0C; .NET4.0E; InfoPath.3)
var UA = inBrowser && window.navigator.userAgent.toLowerCase(); // IE
var isIE = UA && /msie|trident/.test(UA);
// IE9
var isIE9 = UA && UA.indexOf('msie 9.0') > 0;
// edge
var isEdge = UA && UA.indexOf('edge/') > 0;
// android
var isAndroid = UA && UA.indexOf('android') > 0;
// IOS
var isIOS = UA && /iphone|ipad|ipod|ios/.test(UA);
Object.creat(null)
Object.create(null)会生成一种叫纯空对象的东西,没有toString、valueOf,什么都没有,在Object.prototype被污染或极需节省内存的情况下有用。
关于Object.preventExtensions/Object.seal/Object.freeze
Object.preventExtensions
1. 阻止添加本地属性
2. 可以删除本地属性
3. 可以修改本地属性
4. 可以添加原型属性
Object.seal
1. 阻止添加本地属性
2. 允许修改本地属性
3. 不允许删除本地属性,内部实现是遍历属性,并将configurable改为false
Object.freeze
改都不可以了~
兼容问题
getElementById:IE6,IE7下会选取到name属性
[].slice.call():IE6-IE8下无法切割NodeList,即DOM节点集合
getElementByTagName:IE6-IE8会混杂注释节点
getElementByName:只能选取表单元素
关于querySelectorAll
该方法返回一个StaticNodelist对象,而常规的方法返回的是NodeList。
具体区别看下面代码就明白了。
var tag = 'getElementsByTagName',
query = 'querySelectorAll';
console.log(document[tag]('div') == document[tag]('div')); //true
console.log(document[query]('div') == document[query]('div')); //false
简单来讲,querySelectorAll每次都返回一个不一样的Object,而tag方法会从缓存中取。因此,普通方法要比querySelectorAll快上10倍以上。
另外,还有一个问题,IE8下,对StaticNodelist对象取不存在的下标不会返回undefined,而是抛出一个异常,这样的话while(len--){...}这样的表达式就不好使了。
JS框架设计读书笔记之-小知识的更多相关文章
- JS框架设计读书笔记之-节点模块
节点的创建 浏览器提供了多种手段创建API,从流行程度依次是document.createElement.innerHTML.insertAdjacentHTML.createContextualFr ...
- JS框架设计读书笔记之-核心模块
随笔记录一下读书心得 1. 框架模块-核心模块 该模块是框架最先执行的部分,jQuery与vue中都有初始化的代码. 模块的功能主要是:对象扩展.数组化.类型判定.事件绑定和解绑.无冲突处理.模块加载 ...
- JS框架设计读书笔记之-动画
基础概念 CSS样式可分为两种,一种值接近无限的集合(color,width),一种值只有几种(display),可以进行计算的样式,产生了动画效果.\ 1. 动画的第一步是获得元素的精确样式值. 2 ...
- JS框架设计读书笔记之-选择器引擎01
选择符 选择符是指CSS样式规则最左边的部分,例如 p{},#id{},.class{},p.class{} 等等 总共可以分为四大类: 并联选择器 => 逗号 => $('div,spa ...
- JS框架设计读书笔记之-异步
setTimeout/setInterval 1. 如果回调执行时间大于间隔时间,真正的间隔时间会大一些. 2. 存在一个最小的时间间隔,即使seTimeout(fn,0),在IE6-IE8中大概为1 ...
- JS框架设计读书笔记之-选择器引擎02
选择器引擎涉及相关概念 概念 以Sizzle的主函数声明为例,来说明引擎的相关概念. function Sizzle(selector, context, results, seed) { //... ...
- JS框架设计读书笔记之-函数
这次写一些函数 1.模拟Object.keys方法 Object.keys = Object.keys || function(obj){ var a = []; // a[0],a[1]...分别赋 ...
- javascript框架设计(读书笔记)
我觉得多看几本进阶的书 与其十本书读一遍,不如一本书读十遍 读书的启示: 读好书(看推荐) 精读(重复看) 能读厚书(javascript权威指南) Object.keys Object.keys=O ...
- js框架设计1.1命名空间笔记
借到了司徒正美的写的js框架设计一书,司徒大神所著有些看不太懂,果然尚需循序渐进,稳扎js基础之中. 第一张开篇司徒阐述了种子模块的概念 种子模块亦为核心模块,框架最先执行模块,司徒见解应包含:对象扩 ...
随机推荐
- Activiti常见问题解决
1,工作流activiti eclipse 插件不自动生成png window ——> preferences——>activiti——>save——>选中create pro ...
- 【Spring】Spring的bean装配
前言 bean是Spring最基础最核心的部分,Spring简化代码主要是依赖于bean,下面学习Spring中如何装配bean. 装配bean Spring在装配bean时非常灵活,其提供了三种方式 ...
- jdk版本切换
安装1.6/1.7/1.8版本的jdk 保存jdk的安装目录下的文件 卸载所有jdk 将jdk各个版本拷贝到一个文件夹下 配置环境变量 因为安装之后系统会有注册表之类的文件,单纯的修改环境是不会修改成 ...
- 【京东账户】——Mysql/PHP/Ajax爬坑之添加购物车
一.引言 做京东账户项目中的购物车模块,功能之一就是添加购物车.要用到的是Apach环境,Mysql.PHP以及Ajax. 预计效果:用户点击->"加入购物车" 添加成功 ...
- java equals()方法
java基础学习总结--equals方法 一.equals方法介绍 1.1.通过下面的例子掌握equals的用法 1 package cn.galc.test; 2 3 public class Te ...
- EntityFramework Core饥饿加载忽略导航属性问题
前言 .NET Core项目利用EntityFramework Core作为数据访问层一直在进行中,一直没有过多的去关注背后生成的SQL语句,然后老大捞出日志文件一看,恩,有问题了,所以本文产生了,也 ...
- 动易CMS-搜索结果页显示自定义字段
最终的页面: 步骤: 1.搜索标签代码 <input id="keyword" type="text" class="text" on ...
- leetCode in Java (一)
前言 感觉写博客是一个很耗心力的东西T_T,简单的写了似乎没什么用,复杂的三言两语也只能讲个大概,呸呸...怎么能有这些消极思想呢QAQ!那想来想去,先开一个leetcode的坑,虽然已经工作了 ...
- 移植Linux-3.4.2内核到S3C2440
一.BootLoader引导内核过程 1.Bootloader的工作 1.1.将内核读入内存 2.2.保存内核启动参数到指定位置,内核启动时去这个位置解析参数 3.3. ...
- 从入门到精通之Boyer-Moore字符串搜索算法详解
本文讲述的是Boyer-Moore算法,Boyer-Moore算法作为字符串搜索算法,兴趣之下就想了解这个算法,发现这个算法一开始还挺难理解的,也许是我理解能力不是很好吧,花了小半天才看懂,看懂了过后 ...