我的JS 中级学习篇

在codefordream上进入中级学习后,感觉立马从js的基础学习往前跳了好远,上面的东西好像都是第一次看到一样.这时候才发现,说来也曾接触过js,但是这时候才发现对js的认识就停在知道两点:js中用var定义变量,用function定义函数!这时候有点羞愧了,说来真是对不起老师们的教导!之前接触js是用于编写网页,当时在dreamwever上编写网页很多功能都没有自己动手用函数实现,而是直接拖动组件等方法创建的,导致好像真的除了看到过js代码,自己还真的居然没有写过!


中级部分主要有:代码运行规则,类和对象,this引用,原型继承,和回调函数等需要学习的知识.

A.关于this引用:

1.函数调用模式的时候,this指向window.

2.方法调用模式的时候,this指向方法所在的对象

3.构造函数模式的时候,this指向新生成的实例

4.apply/call调用模式的时候,this指向apply/call方法中的第一个参数

对于一个函数,我们可以通过调用该函数(注意函数也是对象)的apply方法,来将该函数内部的this引用指向一个特定对象.eg:

 1 function Tool(name, usage){
 2     this.name = name;
 3     this.usage = usage;
 4     this.get_info = function() {console.log("This is " + this.name + ", the usage of it is " + this.usage + ".");};
 5 }
 6 var cycling = new Tool("cycling","transport");
 7 function display(date){
 8     console.log(this.name+","+this.usage+","+date);
 9 }
10 display.apply({name:"cycling",usage:"transport"},[1970]);
11 //cycling,transport,1970

B.关于类和对象:JS中有一种类似于'类'功能的函数,叫构造函数 ,构造函数是一种可以用来生成对象的函数.JS中的对象是一组属性的无序集合,每个属性可以是 一种简单数据类型值或者一个对象或者一个函数.eg:

1 var Robot = { //构造函数 Object() 生成一个对象 Robot
2     birthday:'1970年1月1日',
3     name:'DeepSky',//定义 name 和 birthday 两个属性
4     say_hello:function(){console.log("我的名字叫"+this.name+",是一个出生在"+this.birthday+"的机器人.");}  //为该对象添加 say_hello 方法,使该方法能够在console输出一句包含 name 和 birthday 属性值的话,
5     };

C.关于回调函数

在Javascript中,函数实际上是对象:它们能被“存储”在变量中,能作为函数参数被传递,能在函数中被创建,能从函数中返回。

 1 //全局变量
 2 var info = [];
 3 
 4 //普通的show函数,将数据的内容打印到控制台
 5 function show(data){
 6     info.push(data);
 7     //如果是可以直接输出的字符串则直接输出
 8     if ( typeof data === "string")
 9     {
10         console.log(data);
11     }
12     else if ( typeof data === "object"){
13         //遍历data
14         for(var item in data){
15             console.log(item + ": " + data[item]);
16         }
17     }
18 }
19 
20 //定义一个接收两个参数的函数,参数中后面一个是回调函数, 在函数体中调用回调函数,并将第一个参数传入回调函数.
21 function get_inputs(data,callback){
22 callback(data);
23 
24 }
25 //当我们调用get_inputs函数时,我们将show函数作为一个参数传递给它     
26 //因此show将会在get_inputs函数内被回调(或者执行)     
27 get_inputs({name:"bower",speciality:"Robot"}, show);
28 //最后会输出以下的内容:
29 //name: bower
30 //speciality: Robot

D.关于原型和对象:

自己觉得理解上有一些问题,随后了解清楚一点,会再补上!

这里有其他朋友的理解:http://www.cnblogs.com/wfsovereign/p/4276694.html

原文地址:https://www.cnblogs.com/meime7/p/4279130.html