zoukankan      html  css  js  c++  java
  • 由重写方法,产生的思考

    比如有下面这么一段代码

    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");
    

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

    那函数的意义是什么?

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

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

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

    写的有些凌乱,勿见笑

  • 相关阅读:
    Ajax校验
    Struts2国际化
    OGNL
    Struts2基础数据校验和框架校验
    http
    AES,BigInteger,MD5加密
    随笔 js-----------------------------------------------------------------------------------------------------
    13年总结js,css,java xml
    window、linux安装jdk,excel 导入oracle,WebService,window 端口查看,svn服务安装,oracle用户解锁
    经典sql语句
  • 原文地址:https://www.cnblogs.com/pssp/p/6827783.html
Copyright © 2011-2022 走看看