原文参考,http://www.cnblogs.com/TomXu/archive/2012/02/10/2342098.html

Tom大叔的博客深入理解Javascript系列真是我们学习Javascript的领航明灯, http://www.cnblogs.com/TomXu/archive/2011/12/15/2288411.html

有兴趣的朋友自己去学习下吧. 一下是对他出的6到题的解答.

第一题:找出数字数组中最大的元素(使用Match.max函数)

原本的我答案是这样

function getMax(array) {
var max= array[0];
array.forEach(function(element){
max<element?max=element:max;
});
return max;
}
var arr = [12, 5, 8, 130, 44,99,888];
console.log(getMax(arr)); //888

看到提示,查了Match.max文档 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Math/max

发现其实只要这样就可以了.

var arr = [12, 5, 8, 130, 44,99,888];
console.log(Math.max.apply(null, arr));

其实这题是考的apply的用法和平时多api文档是否熟悉.要熟悉应该是非常简单旳.

第二题:转化一个数字数组为function数组(每个function都弹出相应的数字)

function NumberToFunction(arr){
var funarr = [];
arr.forEach(convert);
function convert(element,index,array){
function log(element){
return function(){console.log(element);};
}
funarr.push(log(element));
}
return funarr;
} var arr = [12, 5, 8, 130, 44,99,888];
var funa = NumberToFunction(arr);
//验证结果
funa.forEach(function(elment){
elment.call();
});

这道题我理解是考closures的概念,就是闭包. 有两点要注意

1. 循环中不能使用闭包 所以创建了function convert.

2. push里如果要接受convert的参数element不能使用闭包. 所有又添加了function log. 否则虽然可以创建function数组,但是数组里打印不出结果.

第三题: 给object数组进行排序(排序条件是每个元素对象的属性个数)

var persons = [
{
name: 'Jason',
age: 20,
gender:'male'
}, {
name: 'Tom',
age: 18
}, {
name: 'May',
age: 18,
gender: 'female',
high: '165cm'
}
]; persons.sort(function(a,b){
if(Object.getOwnPropertyNames(a).length >Object.getOwnPropertyNames(b).length){
return 1;
}
if(Object.getOwnPropertyNames(a).length<Object.getOwnPropertyNames(b).length){
return -1;
}
return 0;
}); console.log(persons);

Object.keys().length也可以.考api常识 Array.sort,Object.getOwnPropertyNames()或Object.keys()

第四题: 利用JavaScript打印出Fibonacci数(不使用全局变量)

function PFibonacci(){
var arrFib = [0,1];
var count = arguments[0]?arguments[0]:10;
return {
print:function(){
console.log(arrFib[0]);
console.log(arrFib[1]);
for(var i = 2; i< count;i++){
arrFib[i] = arrFib[i-1] + arrFib[i-2];
console.log(arrFib[i] );
}
}
}
} PFibonacci(20).print();

第五题:实现如下语法的功能:var a = (5).plus(3).minus(6);

Number.prototype.plus= function(x){
return this + x;
}; Number.prototype.minus = function(x){
console.log(this);
return this - x;
};
console.log((5).plus(3).minus(6)); //2

考prototype的用法.

第六题:实现如下语法的功能:var a = add(2)(3)(4); //9

var add = function (){
var x = arguments[0];
return function(){
x += arguments[0];
return function(){
return x += arguments[0];
}
};
};
console.log(add(2)(3)(4));//9

这题很纠结,想写出一个add()()()(...),无限下去的方法失败. 只能固定3重连加了.

解Tom大叔出的Javascript题目的更多相关文章

  1. TOM大叔的几道Javascript题目与解答

    几道JS题目 之前没有深入研究js语言,最近几年前端越来越工程化,需要扎实的js基础,看到博客园上有很多大牛分享JS学习文章,幸运看到tom大叔的blog,抽时间潜心学习了其文章,遇到到其出的几道题目 ...

  2. 汤姆大叔 javascript 系列 第20课 最后的5到javascript题目

    博客链接:http://www.cnblogs.com/TomXu/archive/2012/02/10/2342098.html 原题: 大叔注:这些题目也是来自出这5个题目的人,当然如果你能答对4 ...

  3. javascript - 浏览TOM大叔博客的学习笔记

    part1 ---------------------------------------------------------------------------------------------- ...

  4. 看看国外的javascript题目,你能全部做对吗?(分享)

    本文转自@Aaron的博客,拿过来分享一下.原文:看看国外的javascript题目,你能全部做对吗? 题目一: (function(){ return typeof arguments; })(); ...

  5. js便签笔记(11)——浏览TOM大叔博客的学习笔记 part1

    1. 前言 这两天看了一下TOM大叔的<深入理解js系列>中的基础部分,根据自己的实际情况,做了读书笔记,记录了部分容易绊脚的问题.写篇文章,供大家分享. 2. 关于HTMLCollect ...

  6. 容易出错的JavaScript题目集锦

    容易出错的JavaScript题目集锦 1.typeof(null) 会得到什么?object,在JavaScript中null被认为是一个对象. 2.下列代码将输出控制台的是什么?为什么? 1234 ...

  7. 试试看 ? 离奇古怪的javascript题目

    来源地址: http://dmitrysoshnikov.com/ecmascript/the-quiz/#q1 另一篇帖子 看看国外的javascript题目,你能全部做对吗? http://www ...

  8. c语言贪吃蛇详解-2.画出蛇

    c语言贪吃蛇详解-2.画出蛇 前几天的实验室培训课后作业我布置了贪吃蛇,今天有时间就来写一下题解.我将分几步来教大家写一个贪吃蛇小游戏.由于大家c语言未学完,这个教程只涉及数组和函数等知识点. 蛇的身 ...

  9. c语言贪吃蛇详解1.画出地图

    c语言贪吃蛇详解-1.画出地图 前几天的实验室培训课后作业我布置了贪吃蛇,今天有时间就来写一下题解.我将分几步来教大家写一个贪吃蛇小游戏.由于大家c语言未学完,这个教程只涉及数组和函数等知识点. 首先 ...

随机推荐

  1. youtube不显示其他人头像

    我用的是ss , 右键ss选择pac->编辑本地pac 把ggpht.com加入pac列表即可

  2. JVM参数(三)打印所有XX参数及值

    本篇文章基于Java 6(update 21oder 21之后)版本, HotSpot JVM 提供给了两个新的参数,在JVM启动后,在命令行中可以输出所有XX参数和值. -XX:+PrintFlag ...

  3. 鸟哥的Linux私房菜第零章

    CPU从主存中读取数据通过微指令集控制和进行计算.主存储器内的数据则是从输入单元所传输进来,而CPU处理完毕的数据也必须要先写回主存储器中, 最后数据才从主存储器传输到输出单元.内存又称主存,是CPU ...

  4. Blackfin DSP(二):寄存器操作与GPIO

    BlackfinDSP的寄存器是通过指针操作的,与51.ARM等MCU一样,通过“或”操作来置1,通过“与”操作清零. 在DSP上最简单的外设非IO口莫属,但是由于其功能强大,远非一般IO口可比,因此 ...

  5. 36. Construct Binary Tree from Inorder and Postorder Traversal && Construct Binary Tree from Preorder and Inorder Traversal

    Construct Binary Tree from Inorder and Postorder Traversal OJ: https://oj.leetcode.com/problems/cons ...

  6. ASP.NET Page对象各事件执行顺序(转)

    很久没写 asp.net 的东西了,search 了一下 page 的事件执行顺序,找到如下的东西,仅仅做记录用 Page.PreInit 在页初始化开始时发生 Page.Init 当服务器控件初始化 ...

  7. webstrom 2016 破解

    本篇文章经过笔者实验结果,网友均可放心使用 版权声明:本文为博主原创文章,未经博主允许不得转载. 工欲善其事,必先利其器 websrtom作为前端开发神器,现在是越来越多的用户使用.很多小白们下载好了 ...

  8. COOKIE&&SESSION

    ---------------------------------------------------------------------------COOKIE------------------- ...

  9. c# winform 打包部署 自定义界面 或设置开机启动

    添加安装部署项目后,鼠标右键安装项目->视图->注册表, 要使软件在开机就运行,可以在HKEY_CURRENT_USER\Software\Microsoft\Windows\Curren ...

  10. C语言的time.h解释python的time

    clock_t clock(void),对比python的clock() 返回程序执行的时间,clock_t的实际类型是long #include<Windows.h> Sleep(); ...