FCC ES6篇中的解构赋值

1、使用解构赋值从对象中分配变量

function getLength(str) {
     
  "use strict";
  // 在这行以下修改代码
  const {
     length: len} = {
     length:str.length}; // change this
  // 在这行以上修改代码
  return len; // 你必须在这行将 length 赋值给 len
}
console.log(getLength('FreeCodeCamp'));

FCC ES6篇中的解构赋值_第1张图片
第一个我一直通不了关,望兄弟姐妹们指点迷津

2、 使用解构赋值从嵌套对象中分配变量

const LOCAL_FORECAST = {
     
  today: {
      min: 72, max: 83 },
  tomorrow: {
      min: 73.3, max: 84.6 }
};
function getMaxOfTmrw(forecast) {
     
  "use strict";
  // 在这行以下修改代码
  const {
     tomorrow:{
     max:maxOfTomorrow}} = forecast; // 改变这一行
  // 在这行以上修改代码
  return maxOfTomorrow;
}
console.log(getMaxOfTmrw(LOCAL_FORECAST)); // 应该为 84.6

3、使用解构赋值从数组中分配变量

let a = 8, b = 6;
(() => {
     
  "use strict";
  // 在这行以下修改代码
  var arr = [a,b];
  [b,a] = arr;
  // 在这行以上修改代码
})();
console.log(a); // 应该等于 6
console.log(b); // 应该等于 8

4、使用解构赋值配合 rest 操作符来重新分配数组元素

const source = [1,2,3,4,5,6,7,8,9,10];
	function removeFirstTwo(list) {
     
		"use strict";
		// 在这行以下修改代码
		 const [a,b,...arr] = list; // change this
		// 在这行以上修改代码
		return arr;
	}
const arr = removeFirstTwo(source);
console.log(arr); // 应该为 [3,4,5,6,7,8,9,10]
console.log(source); // 应该为 [1,2,3,4,5,6,7,8,9,10];

除了第一个有问题外,其他的都是对的,如果有更好的解题方法,期待分享!

你可能感兴趣的:(es6)