js中神奇的函数指针

    xiaoxiao2025-07-21  11

    js中的函数指针是一个神奇的东西

    定义function check(){};对于上面这个函数,check(函数名)就是函数指针,check指向函数主体,如果alert(ckeck),那么弹出的信息就是function(){…}函数名就是函数指针,并且指向函数匿名函数主体,实际最好是替换,你可以将函数名替换为一个匿名函数即:function(){…},记住每个函数名都可以这样替换这里想说的是函数名运用时的几个注意点: 第一个例子:

                    function  hanshu(){

                            alert("我被执行了");                 }                 function diaoyong(){                         return hanshu();//注意这里,看似返回了函数,实际是什么都没返回,代码效果是在这执行了这个函数,你可以按照上面所说将匿名函数代进去看看.                                                       正确的应该是return hanshu;                 }                 var obj=diaoyong();   第二个例子                 obj.addEventListener("click",hanshu());                  或者                 obj.οnclick=hanshu();                 如果你这么写就大错特错了,原因还是一样,你根本都没添加任何监听事件,代码效果就好比,hanshu();一样,也就是在这个代码段中奖函数执行了一边                 正确的写法应该是                 obj.addEventListener("click",hanshu);                  或者                 obj.οnclick=hanshu; 第三个例子                 setInterval("hanshu()",1000);                 经过上面那两个例子,你是不是认为这样做也错了,这样写是对的,也只能这样写,因为这个hanshu()外面有引号,意思就是每个1秒,执行引号里面的内容即:hanshu(),                 你可以这样理解setInterval("alert('引号就好比作用域一样,外面加个引号,就好比加个匿名函数包围')");                 懂了吧   实际总结就是,只要外面没加引号,函数名加个括号就代表执行函数,特别是你返回一个函数时,一定要注意这点,你如果想传递一个函数,那么只需传递函数名就可以了            最好的方法就是记住函数名替换思想
    转载请注明原文地址: https://ju.6miu.com/read-1300916.html
    最新回复(0)