"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > JavaScript의 함수형 프로그래밍 소개: 렌즈 #9

JavaScript의 함수형 프로그래밍 소개: 렌즈 #9

2024-08-06에 게시됨
검색:686

Introduction to Functional Programming in JavaScript: Lenses #9

렌즈는 함수형 프로그래밍에서 불변 데이터 구조의 일부에 집중하고 조작하는 강력하고 우아한 방법입니다. 원본 데이터를 변경하지 않고 중첩된 개체나 배열 내에서 값을 가져오고 설정하는 메커니즘을 제공합니다.

렌즈란 무엇입니까?

렌즈는 데이터 구조의 일부에 액세스하고 업데이트하는 방법을 제공하는 일류 추상화입니다. 렌즈는 일반적으로 getter와 setter라는 두 가지 함수로 정의됩니다.

  • Getter: 데이터 구조에서 값을 추출하는 함수입니다.
  • Setter: 데이터 구조 내의 값을 업데이트하고 구조의 새 복사본을 반환하는 함수입니다.

렌즈는 원본 데이터를 변경하지 않고도 변경할 수 있으므로 불변 데이터 구조로 작업할 때 특히 유용합니다.

렌즈의 장점

  1. 불변성: 렌즈는 불변 데이터 구조 작업을 용이하게 하여 원본 데이터가 수정되지 않도록 보장합니다.
  2. 모듈화: 렌즈를 사용하면 데이터 액세스 및 업데이트를 모듈화하여 코드를 더 재사용 가능하고 유지 관리하기 쉽게 만들 수 있습니다.
  3. 합성: 렌즈는 데이터 구조의 중첩된 부분에 초점을 맞춰 구성될 수 있으므로 복잡한 데이터 조작을 더 간단하고 구성 가능한 작업으로 나눌 수 있습니다.

JavaScript로 렌즈 구현

JavaScript에서 렌즈의 기본 구현부터 시작해 보겠습니다.

기본 렌즈 구현

렌즈는 get 및 set 메소드를 사용하여 객체로 구현될 수 있습니다.

const lens = (getter, setter) => ({
  get: (obj) => getter(obj),
  set: (val, obj) => setter(val, obj),
});

const prop = (key) => lens(
  (obj) => obj[key],
  (val, obj) => ({ ...obj, [key]: val })
);

// Usage
const user = { name: 'Alice', age: 30 };

const nameLens = prop('name');

const userName = nameLens.get(user);
console.log(userName); // 'Alice'

const updatedUser = nameLens.set('Bob', user);
console.log(updatedUser); // { name: 'Bob', age: 30 }

이 예에서 prop은 물체의 특정 속성에 초점을 맞춘 렌즈를 만듭니다. get 메소드는 속성 값을 검색하고, set 메소드는 값을 업데이트하고 새 객체를 반환합니다.

렌즈 구성

렌즈는 중첩된 데이터 구조와 작동하도록 구성될 수 있습니다. 여기서는 렌즈를 구성하는 유틸리티를 작성하겠습니다.

const composeLenses = (outerLens, innerLens) => ({
  get: (obj) => innerLens.get(outerLens.get(obj)),
  set: (val, obj) => outerLens.set(innerLens.set(val, outerLens.get(obj)), obj),
});

// Usage with nested data
const addressLens = prop('address');
const cityLens = prop('city');

const userAddressCityLens = composeLenses(addressLens, cityLens);

const user = {
  name: 'Alice',
  address: {
    city: 'Wonderland',
    zip: '12345',
  },
};

const userCity = userAddressCityLens.get(user);
console.log(userCity); // 'Wonderland'

const updatedUser = userAddressCityLens.set('Oz', user);
console.log(updatedUser); // { name: 'Alice', address: { city: 'Oz', zip: '12345' } }

이 예에서 composeLenses를 사용하면 주소 객체 내부의 도시 속성에 초점을 맞추는 렌즈를 만들 수 있습니다. 이를 통해 재사용 가능한 모듈식 방식으로 중첩된 속성에 액세스하고 업데이트할 수 있습니다.

렌즈의 실제 응용

렌즈는 프런트 엔드 애플리케이션의 상태 관리와 같이 불변성과 모듈식 데이터 조작이 중요한 시나리오에서 특히 유용합니다.

React에서 상태 관리

React 애플리케이션에서 렌즈를 사용하면 보다 기능적이고 예측 가능한 방식으로 상태 업데이트를 관리할 수 있습니다.

import React, { useState } from 'react';

const App = () => {
  const [state, setState] = useState({
    user: {
      name: 'Alice',
      address: {
        city: 'Wonderland',
      },
    },
  });

  const userLens = prop('user');
  const addressLens = prop('address');
  const cityLens = prop('city');

  const userAddressCityLens = composeLenses(userLens, composeLenses(addressLens, cityLens));

  const updateCity = (newCity) => {
    const newState = userAddressCityLens.set(newCity, state);
    setState(newState);
  };

  return (
    

City: {userAddressCityLens.get(state)}

); }; export default App;

이 예에서는 렌즈를 사용하여 React 구성 요소 상태 내 중첩된 도시 속성의 액세스 및 업데이트를 모듈화합니다. 이 접근 방식을 사용하면 상태 업데이트를 더욱 예측 가능하고 관리하기 쉽게 만들 수 있습니다.

릴리스 선언문 이 기사는 https://dev.to/francescoagati/introduction-to-function-programming-in-javascript-lenses-9-3217?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]에 연락하여 삭제하시기 바랍니다. 그것
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3