JavaScript中function的详细理解(附代码)


本文摘自PHP中文网,作者不言,侵删。

本篇文章给大家带来的内容是关于JavaScript中function的详细理解(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

JavaScript 中的 function 有多重意义。它可能是一个构造器(constructor),承担起对象模板的作用; 可能是对象的方法(method),负责向对象发送消息。还可能是函数,没错是函数,和对象没有任何关系独立存在的可以被调用的函数。

由于语言设计者的妥协,在 JavaScript 加入了一些 class 相关的特性,以使 JavaScript 看起来确实象 Java,可以 “面向对象”。虽然 JavaScript 添加了 new 和 this, 但却没有 class (ES已加)。最后 function 临时担负起 class 的任务。

语义1:作为构造器的 function

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

/**

@class Tab

@param nav {string} 页签标题的class

@param content {string} 页面内容的class

**/

function Tab(nav, content) {

 this.nav = nav;

 this.content = content;

}

Tab.prototype.getNav = function() {

 return this.nav;

};

Tab.prototype.setNav = function(nav) {

 this.nav = nav;

};

Tab.prototype.add = function() {

};

// 创建对象

var tab = new Tab('tab-nav', 'tab-content');

这里定义了一个类 Tab,创建了一个对象 tab。以上使用了 function ,this, new。this, new 是常见的面向对象语言中的关键字, 这里的 function 则担负传统面向对象语言中的 class 作用。当然这时候标识符的命名一般遵循 “首字母大写” 规则。

语义2:作为对象方法的 function

由于 JavaScript 中无需类也可以直接创建对象,因此有两种方式给对象添加方法。第一种先定义类,方法挂在原型上,如上例的 Tab,原型上有 getNav、setNav 和 add 方法。以下还有一种,直接在 function 内的 this 上添加方法。

1

2

3

4

5

6

7

8

9

10

11

12

13

function Tab(nav, content) {

 this.nav = nav

 this.content = content

 this.getNav = function() {

// ...

}

 this.setNav = function() {

// ...

}

 this.add = function() {

// ...

}

}

这里 Tab 是语义, this.getNav/this.setNav/this.add 是语义,作为对象的方法。 另外,可以直接定义对象及其方法

1

2

3

4

5

6

7

8

9

10

11

12

13

var tab = {

 nav: '',

 content: '',

 getNav: function() {

// ...

},

 setNav: function() {

// ...

},

 add: function() {

// ...

}

}

tab.getNav/tab.setNav/tab.add 是语义,作为对象 tab 的方法。
语义3:作为独立的函数

阅读剩余部分

相关阅读 >>

教你用html5画一个馋人的西瓜

javascript怎么获取dom元素

javascript变量的命名规则是什么

移动端h5页面实现生成图片的代码

javascript中如何取值

node.js和javascript区别是什么

javascript如何实现图片切换

javascript中的关键字有哪些

使用rxjs管理react应用状态的介绍

javascript的超集是什么

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...