摘要:解析的数据结构方法有属性属性返回结构的成员总数。方法返回的是当前的对象,因此可以采用链式写法。方法返回一个布尔值,表示某个键是否在当前对象之中。方法清除所有成员,没有返回值。例如,指定值为,结果为随便起个标志
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"})
解析:
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 }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/101435.html
摘要:顺便一说,这首歌的原唱是秋田,中岛当年嗓子坏了,才有这歌。中文是直接翻译来的,作曲是秋田。一部电影春夏秋冬又一春春夏秋冬又一春是由金基德执导,金英民吴英秀金基德主演的一部韩国电影。年月日于韩国上映。 原链接: http://bluezhan.me/weekly/#/9-2 1、web前端 Angular vs. React vs. Vue: A 2017 comparison 9 S...
摘要:顺便一说,这首歌的原唱是秋田,中岛当年嗓子坏了,才有这歌。中文是直接翻译来的,作曲是秋田。一部电影春夏秋冬又一春春夏秋冬又一春是由金基德执导,金英民吴英秀金基德主演的一部韩国电影。年月日于韩国上映。 原链接: http://bluezhan.me/weekly/#/9-2 1、web前端 Angular vs. React vs. Vue: A 2017 comparison 9 S...
摘要:九安卓中如何取出日志信息把安卓系统日志信息实时导入到本地运行使用某个,实时获取该的日志信息里面的返回信息接口自动化面试题一按你的理解,软件接口是什么答就是指程序中具体负责在不同模块之间传输或接受数据的并做处理的类或者函数。 ...
阅读 2652·2021-11-08 13:16
阅读 2281·2021-10-18 13:30
阅读 2205·2021-09-27 13:35
阅读 1962·2019-08-30 15:55
阅读 2413·2019-08-30 13:22
阅读 545·2019-08-30 11:24
阅读 2035·2019-08-29 12:33
阅读 1785·2019-08-26 12:10