Javascript权威指南学习总结

1. 函数的定义总是覆盖变量的定义

function f(){

    alert( 1111 );

}

var f = 1;

alert( f );

此时输出的是1111

2. 函数变量的作用域不管定义在函数体内任何地方,都将是作用于整个函数体内

var x = 1;

function f(){

    alert( x );

    var x = 2;

}

f();

输出undefine,JS变量是在预编译期定义的,所以一开始全局变量x 和 局部变量x都已经被解析,函数体内此时的x的值是undefined.

3. hasOwnProperty isPrototypeOf constructor 区别

hasOwnProperty ( obj1.hasOwnProperty( '属性或方法' ) ) 判断属性、方法是否是某个对象的实际属性或方法而非继承来的.

var o = new Object();

o.name = 1;

alert( o.hasOwnProperty('name') );

// 输出 true 表示name是o的实际属性,非继承属性.

isPrototypeOf ( obj2.isPrototypeOf( obj1 ) ) 判断obj2是否在obj1的原型链上;

function o(){ // }

var obj = new o();

alert( o.prototype.isPrototypeOf( obj ) );

// 输出true 表示 o.prototype 在 obj的原型链上

constructor ( obj.constructor ) 返回对象的构造函数.

function o(){ // }

var obj = new o();

alert( obj.constructor ); // 输出o.

4. 构造函数里的成员 和 prototype 区别

定义在构造函数里的成员在每次构造实例的时,会把所有的成员重新定义在该实例上.

function o(){

    this.name = 1;

}

var obj = new o();

alert( obj.hasOwnProperty( 'name' ) );

// 输出true 说明 obj 已经有了非继承的属性name;

定义在 property 里的成员 是继承给实例对象的,实例对象本身并没有 name 属性

function o(){

    // 构造函数

}

o.prototype = {

    name : 1

}

var obj = new o();

alert( obj.hasOwnProperty( 'name' ) );

// 输出 false 说明 obj 的name属性是继承来的而不是本身实际有的name属性.

5. Image对象 图片缓存

1. 使用方法

var i = new Image();    

// 创建Image实例用于预加载图片

i.src = '1.jpg';    

// 此时完成1.jpg的预加载

// 当执行img的src时 如果i的图片加载完,则直接调用。

2. Image对象的方法

var i = new Image();

// onload 方法表示图片是否加载完成

i.onload = function (){

}

3.Image对象的属性 complete ,当complete值为false时表示图片的onload未执行,即img未加载完。当图片加载完成时,complete的值为true ( 前提是未调用Image对象的onerror和onabort事件,因为调用了这3个事件的任何一个complete的值都将边为true )

例子: 图片加载未完成时,可以载入一个加载中的gif动画,等img.onload事件执行时再加载图片.

window.onload = function (){

  var i = new Image();    

i.src = 'a.jpg';    

if(!i.complete){       

img.src='x.gif';     

}     

i.onload = function (){        

img.src=i.src;    

}

}

原文发布于微信公众号 - php(phpdaily)

原文发表时间:2017-10-30

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏柠檬先生

jquery 表单事件

.blur()    当元素失去焦点的时候触发事件。   .blur(handler(eventObject))     handler(even...

1769
来自专栏coding for love

JS入门难点解析6-作用域链

(注1:如果有问题欢迎留言探讨,一起学习!转载请注明出处,喜欢可以点个赞哦!) (注2:更多内容请查看我的目录。)

661
来自专栏黑白安全

PHP常量介绍

​变量和常量是计算机编程中的一个重要概念,变量或常量可以理解为是程序给一些数据取得名字,编程时,因为一些数据随着程序的运行而改变,所以不能直接使用这些数据,需要...

783
来自专栏日常学python

详解Python中的__init__和__new__的区别

使用Python写过面向对象的代码的同学,可能对 __init__ 方法已经非常熟悉了,__init__ 方法通常用在初始化一个类实例的时候。例如:

381
来自专栏程序员的碎碎念

ThinkPHP page分页类的学习

实例化数据对象 1.$user=M('user'); 查询总记录数 $count = $user->count();//直接读取数据表中条项总数 ...

3205
来自专栏GreenLeaves

JavaScript之字符串引号的使用技巧

在JavaScript中可以随意使用引号,但是最好根据字符串包含的字符来选择。 1.如果字符串里面包含了单引号,那就把字符串放在双引号里面 var age = ...

1727
来自专栏赵俊的Java专栏

Hexo优化 --- 利用 Markdown 语法画流程图

3123
来自专栏Java技术分享

Ajax请求中给全局变量赋值的解决方案

昨天PP遇到一个问题,ajax修改全局变量后,外面获取不到ajax里赋的值,结果为空 问题代码如下图: ? 输出结果如下图: ? 原因: 先在控制台看看是a...

1877
来自专栏林德熙的博客

dotnet 设计规范 · 数组定义

X 不建议设置数组类型的字段为只读。虽然用户不能修改字段,但是可以修改字段里面的元素。如果需要一个只读的集合,建议定义为只读集合。

431
来自专栏我是业余自学C/C++的

redis_3.0.7_sds.h_sdslen()

1353

扫码关注云+社区