1.
var arr = [];
arr['a'] = 1;
console.log(arr.length); // A
arr['4'] = 2;
console.log(arr.length); // B
arr.length = 0;
console.log(arr) // C
A、B、C离别输出什么?
运转效果以下:
var arr = [];
arr['a'] = 1;
console.log(arr); // [a: 1]
console.log(arr.length); // 0
arr['4'] = 2;
console.log(arr) // (5) [empty × 4, 2, a: 1]
console.log(arr.length); // 5
arr.length = 0;
console.log(arr) // [a: 1]
console.log(arr.length); // 0
所以A为0,B为5,C为[a:1]
2.
for(var i=0; i < 5; i ++) {
// 在此处编写代码
// 每隔一秒按递次输出i值
}
解法:
for (var i = 0; i < 5; i++) {
// 在此处编写代码
// 每隔一秒按递次输出i值
(function(i) {
setTimeout(() => {
console.log(i)
}, 1000 * i)
})(i)
}
这道题假如没有限制给出给定的代码,还能够依据ES6块级作用域的学问把for循环中的var改成let,或许用Promise
var arr = []
var output = (i) => new Promise(resolve => {
setTimeout(() => {
console.log(i);
resolve()
}, 1000 * i)
});
for (var i = 0; i < 5; i++) {
arr.push(output(i))
};
3.有以下代码:
var f = function g() {
return 23;
};
typeof g()
运转效果是:
报错
(扩大:假如题目中typeof f === ‘function’, typeof f() === ‘number’)
4.有以下代码:
function showCase(value) {
switch (value) {
case 'A':
console.log(1);
break;
case 'string':
console.log(2);
break;
case undefined:
console.log(3);
break;
case 'undefined':
console.log(4);
break;
default:
console.log(5)
}
}
showCase(new String('A'))
运转效果是:
5
(扩大:console.log(new String(‘A’)) => String {“A”})
5.请用JavaScript完成map的数据构造,请求数据只能经由过程map供应的接口举行接见。
剖析:
map的数据构造要领有
size属性 size属性返回 Map 构造的成员总数。
set(key, value) set要领设置键名key对应的键值为value,然后返回全部 Map 构造。假如key已经有值,则键值会被更新,不然就新天生该键。set要领返回的是当前的Map对象,因而能够采纳链式写法。
get(key) get要领读取key对应的键值,假如找不到key,返回undefined。
has(key) has要领返回一个布尔值,示意某个键是不是在当前 Map 对象当中。
delete(key) delete要领删除某个键,返回true。假如删除失利,返回false。
clear() clear要领消灭一切成员,没有返回值。
参考:
function MyMap() {
this.map = new Object();
this.length = 0;
this.size = function() {
return this.length;
}
this.set = function(key, value) {
if (!this.map[key]) {
++this.length;
}
this.map[key] = value;
}
this.get = function(key) {
return this.map[key] ? this.map[key] : undefined;
}
this.has = function(key) {
return this.map[key] ? true : false;
}
this.delete = function(key) {
if (this.map[key]) {
--this.length;
delete this.map[key];
return true;
} else {
return false;
}
}
this.clear = function() {
this.map = new Object();
this.length = 0;
}
}
6.给定一个排好序的整数数组,推断个中是不是存在两个数之和即是指定的值,时候复杂度最好能到达O(n)。(比方:[1,2,3,4,5,9],指定值为12,效果为true)
var twoSum = function(nums, target) {
var arr = {};
for (var i = 0; i < nums.length; i++) {
if (arr[nums[i]] == "goon") {
return true
}
arr[target - nums[i]] = 'goon' // 随意起个标志
}
return false
}