• 由重写方法,产生的思考


    比如有下面这么一段代码

    var log = console.log;
    console.log = function(){
        log("准备开始执行log方法");
        log.apply(this,arguments);
        log("log方法执行结束");
    };
    console.log("js"); // 准备开始执行log方法 js log方法执行结束
    

    这段代码所做的事就是将console.log重写,但从执行的角度上看,这里无非就是在原有的console.log基础上添加了几条语句,再来看下面这段代码:

    function fn1(){
      console.log("fn1");
    }
    function fn2(){
      console.log("fn2");
    }
    function main(){
      fn1();
      fn2();
    }
    main(); // fn1 fn2
    

    从执行角度上看,它就像下面这样:

    function main(){
      console.log("fn1");
      console.log("fn2");
    }
    main(); // fn1 fn2
    

    最终它成了这样:

    console.log("fn1");
    console.log("fn2");
    

    举这些例子我想说的是,不管你写的代码有多复杂,程序始终还是一步一步的执行,除非是多线程,最大的区别就是它们有了作用域。

    那函数的意义是什么?

    组合代码,重用代码,隔离作用域

    • 组合代码的意义在于,当执行某个方法时,可以去执行多条语句。
    • 很大原因能重用代码是因为有了组合代码。
    • 因为代码不是全部写在一个空间里,因此才有了作用域的可能,但不一定得是函数。

    由此可以看出,不管代码文件有多大,有多少个代码块,程序无非就是多执行一些语句罢了。

    写的有些凌乱,勿见笑

  • 相关阅读:
    让svn自动更新代码注释中的版本号
    前端开发利器F5
    当inlineblock和textindent遇到IE6,IE7
    DSL与函数式编程
    [译]当Node.js遇上WebMatrix 2
    《大道至简》的读后感
    深度学习之卷积神经网络之一
    ORACLE TRUNC()函数
    oracle rownum
    ORACLE 忽略已有重复值 创建唯一约束
  • 原文地址:https://www.cnblogs.com/pssp/p/6827783.html
Copyright © 2020-2023  润新知