js小知识点集合(不定期更新)

1.包装对象:

存取字符串,数字,布尔值的属性时创建(用String(),Number(),Boolean()构造函数来创建)的临时对象称作包装对象。

var s = 'test'; //创建字符串类型变量

s.len = 4; // 创建包装对象,并为该对象创建len属性,赋值为4

//此时引用完毕,包装对象将自动被销毁

console.log(s.len)//由于包装对象已经被销毁,故此时查询结果为undefined

总结:每次使用字符串的属性时,便会创建包装对象(也可理解为临时对象),常用的字符串属性如string.length, string.indexof()等,都是来自于创建包装对象,而使用完成之后便销毁掉。

2.函数声明提前:

第一个例子:

var foo = 1;

function func(){

  foo = 10;

   return;

  function foo(){} //此时函数声明会提前,使得该函数内的foo变为局部变量,该语句                             //同理于此处修改为var foo;

}

console.log(foo); //输出foo结果为1

第二个例子:

function bar() {

return foo;

foo = 10;

function foo() {}  //声明提前,所以输出"function"

var foo = 10;

}

console.log(typeof bar()); //输出"function"

当把function foo和var foo换位子之后,结果依然是输出"function",说明不存在一个先后顺序的声明覆盖问题。

当去掉function foo()后,输出的就是“undefined",说明var foo也会出现声明提前。

当去掉function foo()同时也去掉var foo后,则直接报错未定义。

回到原代码,那么为什么function foo()之后的var foo没有起作用让结果输出"undefined"?(暂无理解办法)

3.关于作用域:

var x =3;

var foo = {       

 x:2,        

baz: {            

     x:1,            

     bar:function(){

                returnthis.x;            

        }        

   }    

}

var go = foo.baz.bar;

console.log(go());//3, 此时该函数执行环境在window中

console.log(foo.baz.bar());//1,此时执行环境在baz中

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,842评论 2 17
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,923评论 18 139
  • 单例模式 适用场景:可能会在场景中使用到对象,但只有一个实例,加载时并不主动创建,需要时才创建 最常见的单例模式,...
    Obeing阅读 2,102评论 1 10
  • 第一章 编译原理 js是一门编译语言 传统编译语言流程: 分词/词法分析:把字符串分解成有意义的代码块 解析/语法...
    冥冥2017阅读 612评论 0 0
  • 游戏、小说这些千奇百怪娱乐方式就像磨人的小妖精群,意志坚定的人都时不时地被蛊惑一下,更不要提完全没有意志...
    萌砸小闺秀阅读 411评论 0 0