1、var和let区别?
var声明的变量有变量提升 let没有
let作用域限定在代码块{}里
2、分析代码执行结果?
var a=123;
if(true){
a='zsh';
let a;
}
报错a is not defined 在代码块内,使用let命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”
3、补全代码
var person={
name:'zs',
age:12
}
let str=`用户的姓名为${person.name},年龄是${person.age}`;
结果呈现:用户的姓名为 ,年龄是
result.innerHTML=str;
4、将下面字符串改用模板字符串实现?
$("#result").append(
"He is <b>"+person.name+"</b>"+"and we wish to
know his"+person.age+".That is all" )
$("#result").append(
`He is <b>${person.name}</b>and we wish to
know his${person.age}.That is all` )
5、下面程序输出的结果是?
let object = { first: 'Bill', lasts: 'Gates' };
let { first: firstName, last: lastName } = object;
console.log(firstName+'\t'+lastName);
Bill undefined//解构的变量名last没有与lasts对应
6、下列程序执行f()函数运行的结果是?
var tmp = new Date();
function f(){
console.log(tmp);
if (false){
var tmp = "hello world";
}
}
f() //undefined tmp会变量提升到函数内部最顶部
7、对比以下两道程序输出的值相同吗?
//A程序:
var a = [];
for (let i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
}
a[8](); //8
a[9](); //9
//B程序
var a = [];
for (var i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
}
a[8](); //10 变量i是对外部变量i的引用,外部变量i在执行完循环变为10
a[9](); //10