zoukankan      html  css  js  c++  java
  • js练习题

      1 //1.预解释毫无节操-自执行函数
      2     f=function(){return true};
      3     g=function(){return false};
      4     (function(){
      5         if(g()&&[]==![]){   //匿名函数中的g,即下面定义的方法g。  // []==![] 返回true
      6             f=function(){return false;}
      7             function g(){return true;}
      8         }
      9     })();
     10     alert(f());  //false
     11     alert(g());  //false
     12 
     13 
     14 
     15 // 2.自执行函数的预解释
     16 (function f(){
     17     function f(){ return 1; }
     18     alert (f());       //2
     19     function f(){ return 2; }
     20 })();
     21 
     22 
     23 
     24 // 3.作用域链
     25 var a=12;
     26 function show(){
     27     alert(a);
     28     a=15;
     29 }
     30 show();   //12
     31 alert(a); //15
     32 
     33 
     34 
     35 // 4.预解释:变量声明早于代码运行
     36 var a=12;
     37 function show(){
     38     alert(a);
     39     var a=15;
     40 }
     41 show();   //undefined
     42 alert(a); //12
     43 
     44 
     45 // 5.预解释:变量声明早于代码运行
     46 var uname = 'jack'
     47 function change() {
     48     alert(uname)      //undefined
     49     var uname = '三峰'
     50     alert(uname)      //'三峰'
     51 }
     52 change()   
     53 
     54 
     55 // 6.在没有形参的情况下:函数声明早于变量声明
     56 function change() {
     57     alert(typeof fn)    // function
     58     function fn() {
     59         alert('hello')
     60     }
     61     var fn
     62 }
     63 change();
     64 
     65 
     66 // 7.带var和不带var的区别;
     67 function abc(){
     68     a=12;
     69     alert(a);   //12
     70 }
     71 function b(){
     72     alert(a)    //12
     73 }
     74 abc();
     75 b();
     76 
     77 // 面试题
     78 // 1.关于内存释放的面试题
     79 function fn() {
     80     var i = 10;
     81     return function (n) {
     82         console.log(n + (++i));
     83     }
     84 }
     85     var f = fn(); //首先把fn执行,然后把执行的结果赋值给f,函数执行只要看函数里面有没有return
     86     f(15);    //26  //引用,执行完不会立即释放
     87     f(20);    //32
     88     fn()(15); //26  //每次执行完内存释放,作用域销毁
     89     fn()(15); //26
     90     fn()(20); //31
     91     fn()(30); //41
     92     f(30);    //43
     93 
     94 
     95 // 2.综合面试题
     96 // 考察:this指向
     97     var num = 10;
     98     var obj = {
     99         num: 20,
    100         fn: (function (num) {
    101             this.num *= 2;
    102             num += 10;
    103             return function () {
    104                 this.num *= 3;
    105                 num += 1;
    106                 console.log(num);
    107             }
    108         })(num)
    109     };
    110     var fn = obj.fn;
    111     fn();           //this->window   21
    112     obj.fn();       //this->obj      22
    113     console.log(window.num, obj.num);  //60, 60
    114 //https://zhidao.baidu.com/question/2270540468949188628.html
    115 //http://www.imooc.com/qadetail/161604?t=227246
    116 //https://www.zhihu.com/question/49789706
    117 
    118 
    119 // 3.关于this和||的运用;
    120 var name='三峰';
    121 var age=500;
    122 name=(function(name,age){
    123     arguments[0]='三峰';
    124     age=age||this.age;
    125     console.log(name,age);  //三峰 500
    126 })(name);
    127 console.log(name,age)  // undefined 500
    128 
    129 
    130 // 4.
    131 var i=3;
    132 function fn(){
    133     i*=2;
    134     return function(n){
    135         console.log(n*(++i))
    136     }
    137 }
    138 var f=fn();
    139 f(3)     //21
    140 fn()(3); //45
    141 f(4);    //64
    142 fn()(3); //99
  • 相关阅读:
    【读书笔记】iOS-简单的数据驱动程序
    数据结构—单链表(类C语言描写叙述)
    使用Hadoop ACL 控制訪问权限
    Iocomp控件之数字显示【图文】
    维护的JSP站点数据丢失
    Simditor用法
    Android实战简易教程-第二十六枪(基于ViewPager实现微信页面切换效果)
    Deferred Rendering(三)反锯齿和半透明问题
    iOS Code Sign error: Provisioning profile can't be found 解决方式
    spring
  • 原文地址:https://www.cnblogs.com/guorange/p/7210662.html
Copyright © 2011-2022 走看看