首页 > 编程语言 > 详细

JavaScript 44 Puzzlers

时间:2016-07-04 23:36:24      阅读:287      评论:0      收藏:0      [点我收藏+]

http://mp.weixin.qq.com/s?__biz=MzAxODE2MjM1MA==&mid=2651550987&idx=1&sn=f7a84b59de14d0b99d5e12a265d55fd2&scene=0#wechat_redirect

http://mp.weixin.qq.com/s?__biz=MzAxODE2MjM1MA==&mid=2651550991&idx=1&sn=ed60b424de47cceb2b81e7df40b57efa&scene=0#wechat_redirect

http://javascript-puzzlers.herokuapp.com/

/*
44 javascript puzzlers
http://javascript-puzzlers.herokuapp.com/

// 001
var res = [‘1‘,‘2‘,‘3‘].map(parseInt);
console.log(res);// 输出结果为:[1,NaN,NaN]
// 输出结果为:[parseInt(‘1‘,0),parseInt(‘2‘,1),parseInt(‘3‘,2)]

function foo1(){ // 查看传入的参数都是啥;
    var l = arguments.length;
    console.log(‘arguments begin:‘);
    for(var i=0;i<l;i++){
        console.log(arguments[i]);
    }
    console.log(‘arguments end;‘);
}
var res2 = [‘1‘,‘2‘,‘3‘].map(foo1);

// map方法会给原数组中的每一个元素都按顺序调用一次callback函数;
// callback函数会被传入3个参数:数组元素,元素索引,原数组本身;

var a = ‘global a‘;
function foo2(){
    console.log(this.a);
}

foo2(); // 直接调用会输出 ‘global a‘

var obj = {};
obj.a = ‘object a‘;

var res = [1,2,3].map(foo2,obj); // 会输出三个‘object a‘
// map方法传入一个回调函数,并且传入一个回调函数中的this对象;
console.log(res); // [undefined, undefined, undefined]


// 002
var res = [typeof null, null instanceof Object];
console.log(res); // [‘object‘,false]
// js共有6种数据类型 Undefined,String,Number,Boolean,Object,Null
// 每种对应的typeof为‘undefined‘,‘string‘,‘number‘,‘boolean‘,‘object‘,‘object‘
// Function 不是数据类型,但是typeof Function 返回 ‘function‘

// JavaScript instanceof运算符代码
// http://www.ibm.com/developerworks/cn/web/1306_jiangjj_jsinstanceof/
function instance_of(L,R){ // L表示左表达式,R表示右表达式
    var O = R.prototype; // 取R的显示原型
    L = L.__proto__; // 取L的隐式原型
    while(true){
        if(L === null){
            return false;
        }
        if(O === L){ // 这里重点:当O严格等于L时,返回true
            return true;
        }
        L = L.__proto__;
    }
}

function Aoo(){}
function Foo(){}
Foo.prototype = new Aoo(); // JavaScript原型继承
var foo = new Foo();
console.log(foo instanceof Foo); // true
console.log(foo instanceof Aoo); // true
console.log(Object instanceof Object); //true
console.log(Function instanceof Function); //true
console.log(Number instanceof Number); // false
console.log(String instanceof String); // false
console.log(Function instanceof Object); // true
console.log(Foo instanceof Function); // true
console.log(Foo instanceof Foo); // false

// 003
//var res = [[3,2,1].reduce(Math.pow),[].reduce(Math.pow)]; // 这一行就会直接报 TypeError,不能对空数组调用reduce方法;
//console.log(res);

//var res = [3,2,1].reduce(Math.pow);
//console.log(res); // 输出9 , Math.pow(3,2),Math.pow(9,1)

function foo1(){
    var l = arguments.length;
    console.log(‘arguments begin:‘);
    for(var i=0;i<l;i++){
        console.log(arguments[i]);
    }
    console.log(‘arguments end:‘);
}
//var res = [‘a‘,‘b‘,‘c‘].reduce(foo1);
// reduce中的回调函数会获得四个参数: 初始值(或者上一次回调函数的返回值,没有返回值就是undefined),当前值,当前值索引,原数组
// 如果没有初始值,就会把数组第一个值作为初始值;
//var res = [‘a‘,‘b‘,‘c‘].reduce(foo1,‘A‘);

//var obj = {};
//var res = [1,2,3].reduce(obj); // 如果回调函数不是函数,也会直接抛出TypeError异常

// 004

var val = ‘smtg‘;
console.log(‘Value is ‘ + (val===‘smtg‘)?‘Something‘:‘Nothing‘);
// + 优先级 大于 ? , 等价于 ‘Value is true‘?‘Something‘:‘Nothing‘



// 005

var name=‘World‘;
(function(){
    if(typeof name === ‘undefined‘){
        var name = ‘Jack‘;
        console.log(‘Goodbye ‘+name); 
    }else{
        console.log(‘Hello ‘+name);
    }
})();

(function(){
    var a;
    if(typeof a === ‘undefined‘){
        var name = ‘Jack‘;
        console.log(‘Goodbye ‘+name); 
    }else{
        console.log(‘Hello ‘+name);
    }
})();

(function(){
    var a=‘‘;
    if(typeof a === ‘undefined‘){
        var name = ‘Jack‘;
        console.log(‘Goodbye ‘+name); 
    }else{
        console.log(‘Hello ‘+name); // 这个变量的确被提升了;Hoisting
    }
})();

(function(){
    var a=‘‘;
    if(typeof a === ‘undefined‘){
        var name = ‘Jack‘;
        console.log(‘Goodbye ‘+name); 
    }else{
        console.log(‘Hello ‘+name1); //  这个就会报异常,name1 is not defined
    }
})();



// 006

var END = Math.pow(2,53); // 9007199254740992
var START = END - 100;
var count = 0;

//for(var i= START;i<=END;i++){ // 这个就是死循环了;
//    count++; 
//}
//console.log(count);

var end1 = END+1; // end1与END是一样的;
console.log(END);
console.log(end1);

var end2 = Math.pow(2,100); // 已经是指数表示方式了;1.2676506002282294e+30
var end21 = end2+1;
console.log(end2);
console.log(end21);
// 在console中可以表示的最大值是Math.pow(2,1023),8.98846567431158e+307
// Math.pow(2,1024)终于显示Infinity
// Number.MAX_VALUE = 1.7976931348623157e+308



// 007

var ary = [0,1,2];
ary[10] = 10;
var res = ary.filter(function(x){return x===undefined;});
console.log(res);

// 官方Array.filter()的polyfill:
if (!Array.prototype.filter) {
  Array.prototype.filter = function(fun/*, thisArg*[DEL THIS]/) {
    ‘use strict‘;

    if (this === void 0 || this === null) {
      throw new TypeError();
    }

    var t = Object(this);
    var len = t.length >>> 0;
    if (typeof fun !== ‘function‘) {
      throw new TypeError();
    }

    var res = [];
    var thisArg = arguments.length >= 2 ? arguments[1] : void 0;
    for (var i = 0; i < len; i++) {
      if (i in t) { // 首先判断是否在数组内;
        var val = t[i];

        // NOTE: Technically this should Object.defineProperty at
        //       the next index, as push can be affected by
        //       properties on Object.prototype and Array.prototype.
        //       But that method‘s new, and collisions should be
        //       rare, so use the more-compatible alternative.
        if (fun.call(thisArg, val, i, t)) {
          res.push(val);
        }
      }
    }

    return res;
  };
}




*/


// 008
var one = 0.1;
var two = 0.2;
var six = 0.6;
var eight = 0.8;

var res = [two-one==one, eight-six==two];
console.log(res); // [true,false]

 

JavaScript 44 Puzzlers

原文:http://www.cnblogs.com/stono/p/5641897.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!