렌즈는 함수형 프로그래밍에서 불변 데이터 구조의 일부에 집중하고 조작하는 강력하고 우아한 방법입니다. 원본 데이터를 변경하지 않고 중첩된 개체나 배열 내에서 값을 가져오고 설정하는 메커니즘을 제공합니다.
렌즈는 데이터 구조의 일부에 액세스하고 업데이트하는 방법을 제공하는 최고 수준의 추상화입니다. 렌즈는 일반적으로 getter와 setter라는 두 가지 기능으로 정의됩니다.
렌즈는 원본 데이터를 변경하지 않고도 변경할 수 있으므로 불변 데이터 구조로 작업할 때 특히 유용합니다.
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 애플리케이션에서 렌즈를 사용하면 보다 기능적이고 예측 가능한 방식으로 상태 업데이트를 관리할 수 있습니다.
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 ( <div> <p>City: {userAddressCityLens.get(state)}</p> <button onClick={() => updateCity('Oz')}>Move to Oz</button> </div> ); }; export default App;
이 예에서는 렌즈를 사용하여 React 구성 요소 상태 내 중첩된 도시 속성에 대한 액세스 및 업데이트를 모듈화합니다. 이 접근 방식을 사용하면 상태 업데이트를 더욱 예측 가능하고 관리하기 쉽게 만들 수 있습니다.
위 내용은 JavaScript의 함수형 프로그래밍 소개: 렌즈 #9의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!