热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

前段面试题题目

题目1:a在什么条件下成立vara?if(a1&&a2&&a3){console.log(条件成立)}方法1使用toStringvara{i:0,toSt

题目1:

// a在什么条件下成立
var a = ?
if (a == 1 && a == 2 && a == 3) {console.log('条件成立')
}

方法1

// 使用toString
var a = {i: 0,toString() {return ++this.i;}
}
if (a == 1 && a == 2 && a == 3) {console.log('条件成立')
}

方法2

// 数据劫持实现
var i = 0;
Object.defineProperty(window, 'a', {get() {return ++i;}
})
if (a == 1 && a == 2 && a == 3) {console.log('条件成立')
}

方法3

var a = [1,2,3]
a.toString = a.shift
if (a == 1 && a == 2 && a == 3) {console.log('条件成立')
}

题目2

var x = 20;
var a = {x : 15,fn : function(){var x = 30;return function(){return this.x;};}
};
console.log(a.fn());
console.log((a.fn())());
console.log(a.fn()());
console.log(a.fn()() == (a.fn())());
console.log(a.fn().call(this));
console.log(a.fn().call(a));
//function(){return this.x;}
//20
//20
//true
//20
//15

题目3(同步与异步)

Promise.resolve().then(()=>{console.log('Promise1')setTimeout(()=>{console.log('setTimeout2')},0)
})setTimeout(()=>{console.log('setTimeout1')Promise.resolve().then(()=>{console.log('Promise2')})
},0)
//Promise1 -> setTimeout1 -> Promise2 -> setTimeout2

题目4(同步与异步)

console.log('begin')
setTimeout(()=>{console.log('a');Promise.resolve().then(()=>{console.log('b');setTimeout(()=>{console.log('c');var arr1 = [];console.log(arr1 instanceof Array)});}).then(()=>{console.log('d');});
},0);
console.log('e')

题目5:下面代码,浏览器控制台上会打印什么?

var a = 10;
function foo(){console.log(a)var a = 20;
}
foo()

题目6:如果我们使用let或const代替var,输出是否相同

var a = 10;
function foo(){console.log(a)var a = 20;
}
foo()

题目7:有以下两个函数,定义一个对象使其拥有这两个函数属性。

function mobile(){return 'mobile';
}
function phone(){return 'phone';
}
var a = {};
a.mobile = mobile();
a.phone = phone();
console.log(a);

题目8:(考察了对象变量和堆内存)

var a = {n:10,m:20};
var b = a;
b.n = 30;
console.log(a.n);
console.log(b);

题目9:6、编写一个函数fn(Number n),将数字转为大写输出,如输入123,输出一百二十三。

function fn(n){if(!/^([1-9]\d*)/.test(n)){return &#39;非法数据&#39;;}var unit &#61; &#39;千百十亿千百十万千百十个&#39;;if(n.length > unit.length){return &#39;数据过长&#39;;}var newStr &#61; &#39;&#39;;var nlength &#61; n.length;unit &#61; unit.substr(unit.length - nlength);for(var i &#61; 0; i < nlength; i&#43;&#43;){newStr &#43;&#61; &#39;零一二三四五六七八九&#39;.charAt(n[i]) &#43; unit.charAt(i);}newStr &#61; newStr.substr(0,newStr.length-1);newStr &#61; newStr.replace(/零(千|百|十)/g,&#39;零&#39;).replace(/(零)&#43;/g,&#39;零&#39;).replace(/零(亿|万)/g,&#39;$1&#39;);return newStr;
}
console.log(fn(&#39;205402002103&#39;));

算法考察&#xff1a;


  1. 有36辆自动赛车和6条跑道&#xff0c;没有计时器的前提下&#xff0c;最少用几次比赛可以筛选出最快的三辆赛车&#xff1f;

    首先分为6组跑一次&#xff0c;6次
    A1 A2 A3 A4 A5 A6
    B1 B2 B3 B4 B5 B6

    每组的第一都跑一次&#xff0c; 一共为7次&#xff0c;取前三名&#xff0c;暂定为&#xff08;A1 B1 C1&#xff09;&#xff0c;此时第一名已经定了为A1

    那么其他三个组D组 E组 F组肯定直接被淘汰&#xff0c;因为他们的第一名都跑不进前三&#xff0c;所以不用考虑改组的其他赛车

    接着ABC组缩小范围
    A组 A2 A3 参加比赛&#xff0c;因为只有A1作为参照物&#xff0c;而A1是冠军 所有它俩都机会,A1>A2>A3
    B组 B1 B2 参加比赛&#xff0c;B3跑输 B1 B2 &#xff0c;B1跑输A1,因此B2之后的拿不到前三&#xff0c;A1>B1>B2
    C组 C1 参加比赛&#xff0c;同理&#xff0c;A1>B1>C1

    最后 A2 A3 B1 B2 C1 可以决出前三 &#xff0c;总共为8次

  2. 一面墙&#xff0c;单独工作时&#xff0c;A花18小时砌好&#xff0c;B花24小时&#xff0c;C花30小时&#xff0c;现A, B, C的顺序轮流砌&#xff0c;每人工作1小时换班&#xff0c;完工时&#xff0c;B总共干了多少小时?()
    A. 9小时
    B. 8小时
    C. 7小时
    D. 6小时48分
    在这里插入图片描述


  • 推荐&#xff1a;
  • 添加链接描述
  • 添加链接描述

推荐阅读
author-avatar
侯faulds_534
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有