javascript的调用函数方法有哪些


本文摘自PHP中文网,作者coldplay.xixi,侵删。

javascript的调用函数方法有:1、使用makeArray函数作为它的一个方法,使用json的方式来声明一个对象;2、使用【obj.myFunction()】方法调用语法。

本教程操作环境:windows7系统、javascript1.8.5版,DELL G3电脑。

javascript的调用函数方法有:

JavaScript函数调用规则1

在没有通过明确所有者对象而直接调用的函数中,如myFunction(),将导致this的值成为默认对象(浏览器中的窗口)。

函数调用

让我们现在创建一个简单的对象,使用 makeArray函数作为它的一个方法,我们将使用json的方式来声明一个对象,我们也来调用这个方法

1

2

3

4

5

6

7

8

9

10

11

12

//creating the object

var arrayMaker = {

    someProperty: 'some value here',

    make: makeArray

};

  

//invoke the make() method

arrayMaker.make('one', 'two');

// => [ arrayMaker, 'one', 'two' ]

// alternative syntax, using square brackets

arrayMaker['make']('one', 'two');

// => [ arrayMaker, 'one', 'two' ]

看到这里的不同了吧,this的值变成了对象本身.你可能会疑问原始的函数定义并没有改变,为何它不是window了呢.好吧,这就是函数在JSavacript中传递的方式,函数在JavaScript里是一个标准的数据类型,确切的说是一个对象.你可以传递它们或者复制他们.就好像整个函数连带参数列表和函数体都被复制,且被分配给了 arrayMaker里的属性make,那就好像这样定义一个 arrayMaker:

1

2

3

4

5

6

var arrayMaker = {

    someProperty: 'some value here',

    make: function (arg1, arg2) {

        return [ this, arg1, arg2 ];

    }

};

JavaScript函数调用规则2

在一个使用方法调用语法,像 obj.myFunction()或者 obj['myFunction'](),这时this的值为obj

这是事件处理代码中bug的主要源头,看看这些例子

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

<input type="button" value="Button 1" id="btn1"  />

<input type="button" value="Button 2" id="btn2"  />

<input type="button" value="Button 3" id="btn3"  onclick="buttonClicked();"/>

  

<script type="text/javascript">

function buttonClicked(){

    var text = (this === window) ? 'window' : this.id;

    alert( text );

}

var button1 = document.getElementById('btn1');

var button2 = document.getElementById('btn2');

  

button1.onclick = buttonClicked;

button2.onclick = function(){   buttonClicked();   };

</script>

点击第一个按钮将会显示”btn”因为它是一个方法调用,this为所属的对象(按钮元素) 点击第二个按钮将显示”window”因为 buttonClicked是被直接调用的(不像 obj.buttonClicked().) 这和我们第三个按钮,将事件处理函数直接放在标签里是一样的.所以点击第三个按钮的结果是和第二个一样的.

使用像jQuery的JS库有这样的优点,当在jQuery里定义了一个事件处理函数,JS库会帮助重写this的值以保证它包含了当前事件源元素的引用,

1

2

3

4

//使用jQuery

$('#btn1').click( function() {

    alert( this.id ); // jQuery ensures 'this' will be the button

});

相关免费学习推荐:javascript视频教程

以上就是javascript的调用函数方法有哪些的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

javascript分号规则的知识介绍(附示例)

javascript怎样验证手机号码

javascript可不可以跨平台

node.js和javascript区别是什么

javascript是什么

怎么在javascript中进行多行注释

javascript实现递归算法的方法介绍

javascript专题之八:数组扁平化

javascript分不分整数浮点数

javascript中如何将url转换成汉字

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




打赏

取消

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

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

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

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

评论

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