"를 사용하여 함수를 정의할 수 있으며 구문은 "var function name=(parameter)=>{ ... }"; 3. 확장 요소 문자 "..."는 배열을 쉼표로 구분된 매개변수 시퀀스로 변환할 수 있으며 일부 데이터 구조를 배열로 변환할 수도 있습니다."/> "를 사용하여 함수를 정의할 수 있으며 구문은 "var function name=(parameter)=>{ ... }"; 3. 확장 요소 문자 "..."는 배열을 쉼표로 구분된 매개변수 시퀀스로 변환할 수 있으며 일부 데이터 구조를 배열로 변환할 수도 있습니다.">
찾다
웹 프론트엔드프런트엔드 Q&Aes6에는 어떤 새로운 확장이 추가되나요?

es6의 새로운 확장: 1. 함수 매개변수에 대한 기본값 설정을 허용합니다. 2. 화살표 함수를 추가했습니다. 화살표 "=>"를 사용하여 함수를 정의할 수 있습니다. 구문은 "var function name=(parameter)입니다. => {...}"; 3. 확장 요소 문자 "..."는 배열을 쉼표로 구분된 매개변수 시퀀스로 변환할 수 있으며 일부 데이터 구조를 배열로 변환할 수도 있습니다.

es6에는 어떤 새로운 확장이 추가되나요?

이 튜토리얼의 운영 환경: Windows 7 시스템, ECMAScript 버전 6, Dell G3 컴퓨터.

ES6 새 확장

1. 함수 매개변수

ES6에서는 함수 매개변수에 대한 기본값을 설정할 수 있습니다.ES6允许为函数的参数设置默认值

function log(x, y = 'World') {
  console.log(x, y);
}

console.log('Hello') // Hello World
console.log('Hello', 'China') // Hello China
console.log('Hello', '') // Hello

函数的形参是默认声明的,不能使用letconst再次声明

function foo(x = 5) {
    let x = 1; // error
    const x = 2; // error
}

参数默认值可以与解构赋值的默认值结合起来使用

function foo({x, y = 5}) {
  console.log(x, y);
}

foo({}) // undefined 5
foo({x: 1}) // 1 5
foo({x: 1, y: 2}) // 1 2
foo() // TypeError: Cannot read property 'x' of undefined

上面的foo函数,当参数为对象的时候才能进行解构,如果没有提供参数的时候,变量xy就不会生成,从而报错,这里设置默认值避免

function foo({x, y = 5} = {}) {
  console.log(x, y);
}

foo() // undefined 5

参数默认值应该是函数的尾参数,如果不是非尾部的参数设置默认值,实际上这个参数是没发省略的

function f(x = 1, y) {
  return [x, y];
}

f() // [1, undefined]
f(2) // [2, undefined]
f(, 1) // 报错
f(undefined, 1) // [1, 1]

二、函数属性

函数的length属性

length将返回没有指定默认值的参数个数

(function (a) {}).length // 1
(function (a = 5) {}).length // 0
(function (a, b, c = 5) {}).length // 2

rest 参数也不会计入length属性

(function(...args) {}).length // 0

如果设置了默认值的参数不是尾参数,那么length属性也不再计入后面的参数了

(function (a = 0, b, c) {}).length // 0
(function (a, b = 1, c) {}).length // 1

name属性

返回该函数的函数名

var f = function () {};

// ES5
f.name // ""

// ES6
f.name // "f"

如果将一个具名函数赋值给一个变量,则 name属性都返回这个具名函数原本的名字

const bar = function baz() {};
bar.name // "baz"

Function构造函数返回的函数实例,name属性的值为anonymous

(new Function).name // "anonymous"

bind返回的函数,name属性值会加上bound前缀

function foo() {};
foo.bind({}).name // "bound foo"

(function(){}).bind({}).name // "bound "

三、函数作用域

一旦设置了参数的默认值,函数进行声明初始化时,参数会形成一个单独的作用域

等到初始化结束,这个作用域就会消失。这种语法行为,在不设置参数默认值时,是不会出现的

下面例子中,y=x会形成一个单独作用域,x没有被定义,所以指向全局变量x

let x = 1;

function f(y = x) { 
  // 等同于 let y = x  
  let x = 2; 
  console.log(y);
}

f() // 1

四、严格模式

只要函数参数使用了默认值、解构赋值、或者扩展运算符,那么函数内部就不能显式设定为严格模式,否则会报错

// 报错
function doSomething(a, b = a) {
  'use strict';
  // code
}

// 报错
const doSomething = function ({a, b}) {
  'use strict';
  // code
};

// 报错
const doSomething = (...a) => {
  'use strict';
  // code
};

const obj = {
  // 报错
  doSomething({a, b}) {
    'use strict';
    // code
  }
};

五、箭头函数

使用“箭头”(=>)定义函数

var f = v => v;

// 等同于
var f = function (v) {
  return v;
};

如果箭头函数不需要参数或需要多个参数,就使用一个圆括号代表参数部分

var f = () => 5;
// 等同于
var f = function () { return 5 };

var sum = (num1, num2) => num1 + num2;
// 等同于
var sum = function(num1, num2) {
  return num1 + num2;
};

如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return语句返回

var sum = (num1, num2) => { return num1 + num2; }

如果返回对象,需要加括号将对象包裹

let getTempItem = id => ({ id: id, name: "Temp" });

注意点:

  • 函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象

  • 不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误

  • 不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替

  • 不可以使用yield

    console.log(...[1, 2, 3])
    // 1 2 3
    
    console.log(1, ...[2, 3, 4], 5)
    // 1 2 3 4 5
    
    [...document.querySelectorAll('p')]
    // [<p>, <p>, <p>]

    함수의 형식 매개변수는 기본적으로 선언되며 선언할 수 없습니다. 다시 선언하려면 let 또는 const를 사용하세요.
  • function push(array, ...items) {
      array.push(...items);
    }
    
    function add(x, y) {
      return x + y;
    }
    
    const numbers = [4, 38];
    add(...numbers) // 42
매개변수 기본값은 구조 분해 할당의 기본값과 결합되어

[...document.querySelectorAll(&#39;p&#39;)]
foo 함수 위의 경우 매개변수가 객체인 경우에만 구조 분해가 수행될 수 있습니다. 매개변수가 제공되지 않으면 변수 <code>xy가 생성되지 않습니다. 오류를 방지하려면 여기에서 기본값을 설정하세요.
const a1 = [1, 2];
const [...a2] = a1;
// [1,2]
기본 매개변수 값은 기본 매개변수 설정이 아닌 경우에는 실제로 이 매개변수가 생략되지 않습니다
const arr1 = [&#39;a&#39;, &#39;b&#39;];
const arr2 = [&#39;c&#39;];
const arr3 = [&#39;d&#39;, &#39;e&#39;];
[...arr1, ...arr2, ...arr3]
// [ &#39;a&#39;, &#39;b&#39;, &#39;c&#39;, &#39;d&#39;, &#39;e&#39; ]

2. 함수 속성

함수의 길이 속성

length은 지정된 기본값 없이 매개변수의 수를 반환합니다.

const arr1 = [&#39;a&#39;, &#39;b&#39;,[1,2]];
const arr2 = [&#39;c&#39;];
const arr3  = [...arr1,...arr2]
arr1[2][0] = 9999 // 修改arr1里面数组成员值
console.log(arr3 ) // 影响到arr3,[&#39;a&#39;,&#39;b&#39;,[9999,2],&#39;c&#39;]

rest 매개변수는 length 속성에서 계산되지 않습니다.

const [first, ...rest] = [1, 2, 3, 4, 5];
first // 1
rest  // [2, 3, 4, 5]

const [first, ...rest] = [];
first // undefined
rest  // []

const [first, ...rest] = ["foo"];
first  // "foo"
rest   // []

설정된 경우 기본값이 있는 매개변수는 tail 매개변수가 아니므로 다음에서 length 속성은 더 이상 계산되지 않습니다. 매개변수

const [...butLast, last] = [1, 2, 3, 4, 5];
// 报错

const [first, ...middle, last] = [1, 2, 3, 4, 5];
// 报错

name 속성

함수의 함수 이름을 반환합니다

[...&#39;hello&#39;]
// [ "h", "e", "l", "l", "o" ]

이름이 지정된 경우 함수가 변수에 할당되면 name 속성은 이름이 지정된 함수의 원래 이름을 반환합니다.

let nodeList = document.querySelectorAll(&#39;p&#39;);
let array = [...nodeList];

let map = new Map([
  [1, &#39;one&#39;],
  [2, &#39;two&#39;],
  [3, &#39;three&#39;],
]);

let arr = [...map.keys()]; // [1, 2, 3]
🎜Function 생성자, name에서 반환된 함수 인스턴스 속성의 값은 anonymous🎜
const obj = {a: 1, b: 2};
let arr = [...obj]; // TypeError: Cannot spread non-iterable object
🎜bind, name 속성 값 앞에 bound🎜
let arrayLike = {
    &#39;0&#39;: &#39;a&#39;,
    &#39;1&#39;: &#39;b&#39;,
    &#39;2&#39;: &#39;c&#39;,
    length: 3
};
let arr2 = Array.from(arrayLike); // [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;]
🎜🎜🎜3이 붙습니다. 함수 범위🎜🎜🎜🎜기본값은 매개변수가 설정되면 함수가 선언되고 초기화되면 매개변수가 별도의 범위를 형성합니다🎜🎜초기화가 완료되면 이 범위는 사라집니다. 다음 예에서 y=x는 별도의 범위를 형성하지만 x는 정의되지 않습니다. 전역 변수 를 가리킵니다. 수식은 엄격 모드로 설정됩니다. 그렇지 않으면 오류가 보고됩니다🎜
Array.from([1, 2, 3], (x) => x * x)
// [1, 4, 9]
🎜🎜🎜5. 화살표 함수🎜🎜🎜🎜"화살표"(=> code>) 함수를 정의합니다🎜
Array.of(3, 11, 8) // [3,11,8]
🎜화살표 함수에 매개변수가 필요하지 않거나 여러 매개변수가 필요한 경우 괄호를 사용하여 매개변수 부분을 표현합니다🎜
Array() // []
Array(3) // [, , ,]
Array(3, 11, 8) // [3, 11, 8]
🎜화살표 함수의 코드 블록이 둘 이상의 명령문인 경우, 이를 중괄호로 묶어야 하며 return 문을 사용해야 합니다. Return🎜
[1, 2, 3, 4, 5].copyWithin(0, 3) // 将从 3 号位直到数组结束的成员(4 和 5),复制到从 0 号位开始的位置,结果覆盖了原来的 1 和 2
// [4, 5, 3, 4, 5]
🎜객체를 반환하는 경우 객체를 괄호로 묶어야 합니다🎜
[1, 5, 10, 15].find(function(value, index, arr) {
  return value > 9;
}) // 10
🎜참고:🎜
  • 🎜함수 본문의 this 객체는 정의된 객체가 아니라, 이를 사용하는 객체🎜🎜
  • 🎜를 생성자로 사용할 수 없습니다. 즉, new 명령을 사용할 수 없습니다. 그렇지 않으면 오류가 발생합니다🎜🎜
  • 🎜함수 본문에 존재하지 않는 인수 개체를 사용할 수 없습니다. 사용하고 싶다면 rest 매개변수를 대신 사용해도 됩니다🎜🎜
  • 🎜yield 명령을 사용할 수 없으므로 화살표 함수를 함수로 사용할 수 없습니다. 생성기 함수🎜🎜🎜🎜🎜🎜6, 확장 연산자 🎜🎜🎜🎜ES6는 확장 요소 연산자를 사용합니다. 나머지 매개변수의 역연산과 마찬가지로 배열을 쉼표로 구분된 매개변수 시퀀스로 변환합니다. 🎜
    [1, 5, 10, 15].findIndex(function(value, index, arr) {
      return value > 9;
    }) // 2
    🎜는 주로 배열을 변환하는 함수를 호출할 때 사용됩니다. 매개변수 시퀀스🎜
    function f(v){
      return v > this.age;
    }
    let person = {name: &#39;John&#39;, age: 20};
    [10, 12, 26, 15].find(f, person);    // 26
    🎜로 일부 데이터 구조를 배열🎜
    [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;].fill(7)
    // [7, 7, 7]
    
    new Array(3).fill(7)
    // [7, 7, 7]
    🎜으로 변환할 수 있어 배열 복사가 더 쉬워집니다🎜
    [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;].fill(7, 1, 2)
    // [&#39;a&#39;, 7, &#39;c&#39;]
    🎜배열 병합도 더욱 간결해집니다🎜
    or (let index of [&#39;a&#39;, &#39;b&#39;].keys()) {
      console.log(index);
    }
    // 0
    // 1
    
    for (let elem of [&#39;a&#39;, &#39;b&#39;].values()) {
      console.log(elem);
    }
    // &#39;a&#39;
    // &#39;b&#39;
    
    for (let [index, elem] of [&#39;a&#39;, &#39;b&#39;].entries()) {
      console.log(index, elem);
    }
    // 0 "a"
    🎜참고 : 스프레드 연산자를 통해 달성되는 것은 참조가 가리키는 값을 수정하면 새 배열에 동기적으로 반영됩니다.🎜다음 예를 보면 더 명확해집니다🎜
    [1, 2, 3].includes(2)     // true
    [1, 2, 3].includes(4)     // false
    [1, 2, NaN].includes(NaN) // true
    🎜스프레드 연산자는 구조 분해 할당과 결합될 수 있습니다. 배열 생성🎜
    [1, 2, 3].includes(3, 3);  // false
    [1, 2, 3].includes(3, -1); // true
    🎜배열에 스프레드 연산자를 사용하는 경우 할당은 매개변수의 마지막 위치에만 배치할 수 있으며 그렇지 않으면 오류가 보고됩니다🎜
    [1, 2, [3, 4]].flat()
    // [1, 2, 3, 4]
    🎜문자열을 실제 배열로 변환할 수 있습니다🎜
    [1, 2, [3, [4, 5]]].flat()
    // [1, 2, 3, [4, 5]]
    
    [1, 2, [3, [4, 5]]].flat(2)
    // [1, 2, 3, 4, 5]
    🎜객체 Iterator(Iterator) 인터페이스를 정의하는 것은 스프레드 연산자를 사용하여 실제 배열로 변환할 수 있습니다. 배열🎜
    // 相当于 [[2, 4], [3, 6], [4, 8]].flat()
    [2, 3, 4].flatMap((x) => [x, x * 2])
    // [2, 4, 3, 6, 4, 8]
    🎜Iterator 인터페이스가 없는 객체에 스프레드 연산자를 사용하면 오류가 보고됩니다🎜
    const obj = {a: 1, b: 2};
    let arr = [...obj]; // TypeError: Cannot spread non-iterable object

    七、构造函数新增的方法

    关于构造函数,数组新增的方法有如下:

    • Array.from()
    • Array.of()

    Array.from()

    将两类对象转为真正的数组:类似数组的对象和可遍历(iterable)的对象(包括 ES6 新增的数据结构 Set 和 Map)

    let arrayLike = {
        &#39;0&#39;: &#39;a&#39;,
        &#39;1&#39;: &#39;b&#39;,
        &#39;2&#39;: &#39;c&#39;,
        length: 3
    };
    let arr2 = Array.from(arrayLike); // [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;]

    还可以接受第二个参数,用来对每个元素进行处理,将处理后的值放入返回的数组

    Array.from([1, 2, 3], (x) => x * x)
    // [1, 4, 9]

    Array.of()

    用于将一组值,转换为数组

    Array.of(3, 11, 8) // [3,11,8]

    没有参数的时候,返回一个空数组
    当参数只有一个的时候,实际上是指定数组的长度
    参数个数不少于 2 个时,Array()才会返回由参数组成的新数组

    Array() // []
    Array(3) // [, , ,]
    Array(3, 11, 8) // [3, 11, 8]

    八、实例对象新增的方法

    关于数组实例对象新增的方法有如下:

    • copyWithin()
    • find()、findIndex()
    • fill()
    • entries(),keys(),values()
    • includes()
    • flat(),flatMap()

    copyWithin()

    将指定位置的成员复制到其他位置(会覆盖原有成员),然后返回当前数组
    参数如下:

    • target(必需):从该位置开始替换数据。如果为负值,表示倒数。
    • start(可选):从该位置开始读取数据,默认为 0。如果为负值,表示从末尾开始计算。
    • end(可选):到该位置前停止读取数据,默认等于数组长度。如果为负值,表示从末尾开始计算。
    [1, 2, 3, 4, 5].copyWithin(0, 3) // 将从 3 号位直到数组结束的成员(4 和 5),复制到从 0 号位开始的位置,结果覆盖了原来的 1 和 2
    // [4, 5, 3, 4, 5]

    find()、findIndex()

    find()用于找出第一个符合条件的数组成员
    参数是一个回调函数,接受三个参数依次为当前的值、当前的位置和原数组

    [1, 5, 10, 15].find(function(value, index, arr) {
      return value > 9;
    }) // 10

    findIndex返回第一个符合条件的数组成员的位置,如果所有成员都不符合条件,则返回-1

    [1, 5, 10, 15].findIndex(function(value, index, arr) {
      return value > 9;
    }) // 2

    这两个方法都可以接受第二个参数,用来绑定回调函数的this对象。

    function f(v){
      return v > this.age;
    }
    let person = {name: &#39;John&#39;, age: 20};
    [10, 12, 26, 15].find(f, person);    // 26

    fill()

    使用给定值,填充一个数组

    [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;].fill(7)
    // [7, 7, 7]
    
    new Array(3).fill(7)
    // [7, 7, 7]

    还可以接受第二个和第三个参数,用于指定填充的起始位置和结束位置

    [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;].fill(7, 1, 2)
    // [&#39;a&#39;, 7, &#39;c&#39;]

    注意,如果填充的类型为对象,则是浅拷贝

    entries(),keys(),values()

    keys()是对键名的遍历、values()是对键值的遍历,entries()是对键值对的遍历

    or (let index of [&#39;a&#39;, &#39;b&#39;].keys()) {
      console.log(index);
    }
    // 0
    // 1
    
    for (let elem of [&#39;a&#39;, &#39;b&#39;].values()) {
      console.log(elem);
    }
    // &#39;a&#39;
    // &#39;b&#39;
    
    for (let [index, elem] of [&#39;a&#39;, &#39;b&#39;].entries()) {
      console.log(index, elem);
    }
    // 0 "a"

    includes()

    用于判断数组是否包含给定的值

    [1, 2, 3].includes(2)     // true
    [1, 2, 3].includes(4)     // false
    [1, 2, NaN].includes(NaN) // true

    方法的第二个参数表示搜索的起始位置,默认为0
    参数为负数则表示倒数的位置

    [1, 2, 3].includes(3, 3);  // false
    [1, 2, 3].includes(3, -1); // true

    flat(),flatMap()

    将数组扁平化处理,返回一个新数组,对原数据没有影响

    [1, 2, [3, 4]].flat()
    // [1, 2, 3, 4]

    flat()默认只会“拉平”一层,如果想要“拉平”多层的嵌套数组,可以将flat()方法的参数写成一个整数,表示想要拉平的层数,默认为1

    [1, 2, [3, [4, 5]]].flat()
    // [1, 2, 3, [4, 5]]
    
    [1, 2, [3, [4, 5]]].flat(2)
    // [1, 2, 3, 4, 5]

    flatMap()方法对原数组的每个成员执行一个函数相当于执行Array.prototype.map(),然后对返回值组成的数组执行flat()方法。该方法返回一个新数组,不改变原数组

    // 相当于 [[2, 4], [3, 6], [4, 8]].flat()
    [2, 3, 4].flatMap((x) => [x, x * 2])
    // [2, 4, 3, 6, 4, 8]

    flatMap()方法还可以有第二个参数,用来绑定遍历函数里面的this

    九、数组的空位

    数组的空位指,数组的某一个位置没有任何值

    ES6 则是明确将空位转为undefined,包括Array.from、扩展运算符、copyWithin()、fill()、entries()、keys()、values()、find()和findIndex()

    建议大家在日常书写中,避免出现空位

    十、排序稳定性

    将sort()默认设置为稳定的排序算法

    const arr = [
      &#39;peach&#39;,
      &#39;straw&#39;,
      &#39;apple&#39;,
      &#39;spork&#39;
    ];
    
    const stableSorting = (s1, s2) => {
      if (s1[0] < s2[0]) return -1;
      return 1;
    };
    
    arr.sort(stableSorting)
    // ["apple", "peach", "straw", "spork"]

    排序结果中,straw在spork的前面,跟原始顺序一致

위 내용은 es6에는 어떤 새로운 확장이 추가되나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
React의 이점 : 성능, 재사용 성 등React의 이점 : 성능, 재사용 성 등Apr 15, 2025 am 12:05 AM

React의 인기에는 성능 최적화, 구성 요소 재사용 및 풍부한 생태계가 포함됩니다. 1. 성능 최적화는 가상 DOM 및 Diffing 메커니즘을 통해 효율적인 업데이트를 달성합니다. 2. 구성 요소 재사용은 재사용 가능한 구성 요소에 의해 중복 코드를 줄입니다. 3. 풍부한 생태계와 일원 데이터 흐름은 개발 경험을 향상시킵니다.

React : 동적 및 대화식 사용자 인터페이스 생성React : 동적 및 대화식 사용자 인터페이스 생성Apr 14, 2025 am 12:08 AM

React는 동적 및 대화식 사용자 인터페이스를 구축하기위한 선택 도구입니다. 1) 구성 요소화 및 JSX는 UI 분할 및 재사용을 간단하게 만듭니다. 2) State Management는 Usestate 후크를 통해 구현되어 UI 업데이트를 트리거합니다. 3) 이벤트 처리 메커니즘은 사용자 상호 작용에 응답하고 사용자 경험을 향상시킵니다.

React vs. 백엔드 프레임 워크 : 비교React vs. 백엔드 프레임 워크 : 비교Apr 13, 2025 am 12:06 AM

React는 사용자 인터페이스를 구축하기위한 프론트 엔드 프레임 워크입니다. 백엔드 프레임 워크는 서버 측 응용 프로그램을 구축하는 데 사용됩니다. React는 구성 및 효율적인 UI 업데이트를 제공하며 백엔드 프레임 워크는 완전한 백엔드 서비스 솔루션을 제공합니다. 기술 스택, 프로젝트 요구 사항, 팀 기술 및 확장 성을 선택할 때는 고려해야합니다.

HTML 및 React : 마크 업과 구성 요소의 관계HTML 및 React : 마크 업과 구성 요소의 관계Apr 12, 2025 am 12:03 AM

HTML과 React의 관계는 프론트 엔드 개발의 핵심이며, 현대 웹 애플리케이션의 사용자 인터페이스를 공동으로 구축합니다. 1) HTML은 컨텐츠 구조와 의미를 정의하고 React는 구성 요소화를 통해 동적 인터페이스를 구축합니다. 2) 부품은 JSX 구문을 사용하여 HTML을 포함하여 지능형 렌더링을 달성합니다. 3) 구성 요소 수명주기는 상태 및 속성에 따라 HTML 렌더링 및 업데이트를 동적으로 관리합니다. 4) 구성 요소를 사용하여 HTML 구조를 최적화하고 유지 관리 가능성을 향상시킵니다. 5) 성능 최적화에는 불필요한 렌더링을 피하고 주요 속성 사용 및 구성 요소 단일 책임을 유지하는 것이 포함됩니다.

반응 및 프론트 엔드 : 대화 형 경험 구축반응 및 프론트 엔드 : 대화 형 경험 구축Apr 11, 2025 am 12:02 AM

React는 대화식 프론트 엔드 경험을 구축하는 데 선호되는 도구입니다. 1) 반응은 구성 요소화 및 가상 DOM을 통해 UI 개발을 단순화합니다. 2) 구성 요소는 기능 구성 요소 및 클래스 구성 요소로 나뉩니다. 기능 구성 요소는 더 간단하고 클래스 구성 요소는 더 많은 수명주기 방법을 제공합니다. 3) RECT의 작동 원리는 가상 DOM 및 조정 알고리즘에 의존하여 성능을 향상시킵니다. 4) 주 경영진은 usestate 또는 this.state를 사용하며 ComponentDidMount와 같은 수명주기 방법은 특정 논리에 사용됩니다. 5) 기본 사용에는 구성 요소 생성 및 상태 관리가 포함되며 고급 사용량은 사용자 정의 후크 및 성능 최적화가 포함됩니다. 6) 일반적인 오류에는 부적절한 상태 업데이트 및 성능 문제, 디버깅 기술은 ReactDevTools 사용 및 우수

반응 및 프론트 엔드 스택 : 도구 및 기술반응 및 프론트 엔드 스택 : 도구 및 기술Apr 10, 2025 am 09:34 AM

React는 핵심 구성 요소 및 상태 관리 기능을 갖춘 사용자 인터페이스를 구축하기위한 JavaScript 라이브러리입니다. 1) 구성 요소화 및 상태 관리를 통해 UI 개발을 단순화합니다. 2) 작업 원칙에는 화해 및 렌더링이 포함되며 최적화는 React.Memo 및 Usememo를 통해 구현할 수 있습니다. 3) 기본 사용법은 구성 요소를 작성하고 렌더링하는 것입니다. 고급 사용법에는 후크 및 컨텍스트를 사용하는 것이 포함됩니다. 4) 부적절한 상태 업데이트와 같은 일반적인 오류는 ReactDevTools를 사용하여 디버그 할 수 있습니다. 5) 성능 최적화에는 React.Memo, 가상화 목록 및 코드플릿을 사용하는 것이 포함되며 코드를 읽을 수 있고 유지 관리 가능하게 유지하는 것이 가장 좋습니다.

HTML에서 React의 역할 : 사용자 경험 향상HTML에서 React의 역할 : 사용자 경험 향상Apr 09, 2025 am 12:11 AM

React는 JSX와 HTML을 결합하여 사용자 경험을 향상시킵니다. 1) JSX는 개발을보다 직관적으로 만들기 위해 HTML을 포함시킨다. 2) 가상 DOM 메커니즘은 성능을 최적화하고 DOM 운영을 줄입니다. 3) 유지 보수성을 향상시키기위한 구성 요소 기반 관리 UI. 4) 상태 관리 및 이벤트 처리는 상호 작용을 향상시킵니다.

반응 구성 요소 : HTML에서 재사용 가능한 요소 생성반응 구성 요소 : HTML에서 재사용 가능한 요소 생성Apr 08, 2025 pm 05:53 PM

반응 구성 요소는 함수 또는 클래스로 정의 할 수 있으며 UI 로직을 캡슐화하고 소품을 통해 입력 데이터를 수락합니다. 1) 구성 요소 정의 : 기능 또는 클래스를 사용하여 반응 요소를 반환합니다. 2) 렌더링 구성 요소 : 반응 호출 렌더 메소드 또는 기능 구성 요소를 실행합니다. 3) 멀티플렉싱 구성 요소 : 소품을 통해 데이터를 전달하여 복잡한 UI를 구축합니다. 구성 요소의 수명주기 접근 방식을 통해 다른 단계에서 논리를 실행하여 개발 효율성 및 코드 유지 관리 가능성을 향상시킬 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구