天天推送各种框架和库的,看起来也挺累的。。。今天放松一下,做几道 JavaScript 基础题找找自信吧!
创新互联建站是一家集网站建设,鄂州企业网站建设,鄂州品牌网站建设,网站定制,鄂州网站建设报价,网络营销,网络优化,鄂州网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
function Animal(){
this.type = "animal"
}
function Dog(){
this.name = "dog"
}
Dog.prototype = new Animal()
var PavlovPet = new Dog();
console.log(PavlovPet.__proto__ === Dog.prototype)
console.log(Dog.prototype.__proto__ === Animal.prototype)
console.log 打印出的值是?
var arr = [5, 22, 14, 9];
console.log(arr.sort());
console.log 打印出的值是?
for (let i = 0; i < 3; i++) {
const log = () => {
console.log(i)
}
setTimeout(log, 100)
}
console.log 打印出的值是?
const length = 4
const numbers = []
for (var i = 0; i < length; i++);{
numbers.push(i + 1)
}
console.log(numbers)
console.log 打印出的值是?
const clothes = ['shirt', 'socks', 'jacket', 'pants', 'hat']
clothes.length = 0
console.log(clothes[3])
console.log 打印出的值是?
var a = 1
function output () {
console.log(a)
var a = 2
console.log(a)
}
console.log(a)
output()
console.log(a)
console.log 打印出的值是?
function foo() {
let a = b = 0
a++
return a
}
foo()
console.log(typeof a)
console.log(typeof b)
console.log 打印出的值是?
console.log(+true)
console.log(!"ConardLi")
console.log 打印出的值是?
// module.js
export default () => "Hello world"
export const name = "c"
// index.js
import * as data from "./module"
console.log(data)
console.log 打印出的值是?
const a = {};
const b = { key: "b" };
const c = { key: "c" };
a[b] = 123;
a[c] = 456;
console.log(a[b]);
console.log 打印出的值是?
把原型的基础知识记清楚这道题就错不了:
所有的对象都有 [[prototype]] 属性(通过 _proto_ 访问),该属性对应对象的原型;所有的函数对象都有 prototype 属性,该属性的值会被赋值给该函数创建的对象的 _proto_ 属性。
答案是:
true
true
抱歉,答案不是 [5, 9, 14, 22] 。如果不传入排序函数,sort 函数会将每个元素转换成字符串,然后根据它们的 UTF-16 值排序。
答案是:
[14, 22, 5, 9]
这题我会,因为:
定时器是异步执行,浏览器会优先执行同步任务,在遇到定时器时会先把它们暂存在一个宏任务队列中,待当前宏任务队列的所有任务执行完毕后才会去执行队列中的任务,此时循环已执行完毕,i 已经是 3。
所以答案是:
0
1
2
哎不对?答案为啥不是 3、3、3 ?
因为循环里的 i 是用 let 声明的,而不是用 var 声明的!
let 声明的变量拥有块级作用域。即在 for 循环或 if 中用 let 定义变量,在外面是访问不到的。
形如 for (let i...) 的循环在每次迭代时都为 i 创建一个新变量,并以之前迭代中同名变量的值将其初始化,所以上面的代码实际上相当于:
for (let i = 0) {
const log = () => {
console.log(i)
}
setTimeout(log, 100)
}
for (let i = 1) {
const log = () => {
console.log(i)
}
setTimeout(log, 100)
}
for (let i = 2) {
const log = () => {
console.log(i)
}
setTimeout(log, 100)
}
要看仔细啊,看到小括号和大括号之间有个;吗?
答案是:
[5]
将数组的长度赋值为 0 就相当于从数组中删除所有元素。
答案是:
undefined
答案是:
1
undefined
2
1
let a 是一个局部变量。typeof a 检查的是未声明的变量。
b 是个全局变量,它在 foo 函数中被赋值。
答案是:
undefined
number
+ 运算符首先会尝试将 boolean 类型转换为数字类型,true 被转换为 1,false 被转换为 0。
字符串 'ConardLi' 是一个真值,所以 !'ConardLi' 为 false。
答案是:
1
false
考察下你对 ES Module 的认识。
答案是:
{ default: function default(), name: "c" }
对象能做对象的 key 吗?当然不能,两次赋值实际上是:
a["Object object"] = 123;
a["Object object"] = 456;
答案是:
456
怎么样,找到自信了吗?
本文名称:进来做几道JavaScript基础题找找自信?
文章地址:http://www.shufengxianlan.com/qtweb/news25/262025.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联