Vue를 이제 막 배우기 시작한 사람들에게는 메서드, 계산된 속성, 관찰자의 차이점이 다소 혼란스러울 수 있습니다. 각각을 사용하여 거의 동일한 작업을 수행할 수 있지만 어떤 면에서 다른 것보다 나은지 아는 것이 중요합니다.
이 빠른 팁에서는 Vue 애플리케이션의 세 가지 중요한 측면과 사용 사례를 살펴보겠습니다. 이 세 가지 방법을 각각 사용하여 동일한 검색 구성 요소를 구축하겠습니다.
메소드
메소드 는 여러분이 기대하는 것과 거의 비슷합니다. 객체의 속성인 함수입니다. 메서드를 사용하여 DOM에서 발생하는 이벤트에 반응하거나 구성 요소의 다른 곳(예: 계산된 속성 또는 관찰자)에서 메서드를 호출할 수 있습니다. 메소드는 일반적으로 사용되는 기능을 그룹화하는 데 사용됩니다(예: 양식 제출 처리 또는 Ajax 요청 작성과 같은 재사용 가능한 기능 구축).
메소드 객체 내부의 Vue 인스턴스에 메소드를 생성할 수 있습니다:
new Vue({ el: "#app", methods: { handleSubmit() {} } })
이를 템플릿에서 사용하려면 다음을 수행할 수 있습니다.
<div id="app"> <button @click="handleSubmit"> Submit </button> </div>
v-on 지시문을 사용하여 이벤트 핸들러를 연결합니다. DOM 요소에 추가하며 @
기호로 축약할 수도 있습니다. @
符号。
handleSubmit方法将在每次单击按钮时被调用。例如,当你想要传递方法体中需要的参数时,你可以执行以下操作:
<div id="app"> <button @click="handleSubmit(event)"> Submit </button> </div>
在这里,我们传递了一个事件对象,例如,它可以防止我们在提交表单时阻止浏览器的默认操作。
但是,由于我们使用指令附加事件,因此可以利用修饰符更优雅地实现同一件事:@click.stop="handleSubmit"
。
现在,让我们看一个使用方法筛选数组中的数据列表的示例。
在演示中,我们要呈现数据列表和搜索框。每当用户在搜索框中输入值时,呈现的数据都会更改。模板将如下所示:
<div id="app"> <h2 id="Language-nbsp-Search">Language Search</h2> <div class="form-group"> <input type="text" v-model="input" @keyup="handleSearch" placeholder="Enter language" class="form-control" /> </div> <ul v-for="(item, index) in languages" class="list-group"> <li class="list-group-item" :key="item">{{ item }}</li> </ul> </div>
正如您所看到的,我们引用一个handleSearch方法,每次用户在搜索字段中键入内容时都会调用该方法。我们需要创建方法和数据:
new Vue({ el: '#app', data() { return { input: '', languages: [] } }, methods: { handleSearch() { this.languages = [ 'JavaScript', 'Ruby', 'Scala', 'Python', 'Java', 'Kotlin', 'Elixir' ].filter(item => item.toLowerCase().includes(this.input.toLowerCase())) } }, created() { this.handleSearch() } })
handleSearch方法使用输入字段的值更新列出的项目。需要注意的一件事是,在methods对象中,不需要使用this.handleSearch引用该方法(在react中必须这样做)。
计算属性
尽管以上示例中的搜索按预期工作,但更优雅的解决方案是使用计算属性。 计算属性对于从现有资源中组合新数据非常方便,并且与方法相比,它们的一大优点是可以缓存其输出。 这意味着,如果页面上与计算属性无关的某些内容发生更改,并且UI会重新呈现,则将返回缓存的结果,并且将不会重新计算计算属性,从而为我们节省了潜在的昂贵操作。
计算属性使我们能够使用可用的数据即时进行计算。 在这种情况下,我们有一系列需要排序的项目。 我们想要在用户在输入字段中输入值时进行排序。
我们的模板看起来与之前的迭代几乎相同,除了我们向v-for
指令传递了一个计算属性(filteredList
):
<div id="app"> <h2 id="Language-nbsp-Search">Language Search</h2> <div class="form-group"> <input type="text" v-model="input" placeholder="Enter language" class="form-control" /> </div> <ul v-for="(item, index) in filteredList" class="list-group"> <li class="list-group-item" :key="item">{{ item }}</li> </ul> </div>
脚本部分略有不同。我们在data
属性中声明语言(以前这是一个空数组),而不是将方法转移到计算属性中的方法:
new Vue({ el: "#app", data() { return { input: '', languages: [ "JavaScript", "Ruby", "Scala", "Python", "Java", "Kotlin", "Elixir" ] } }, computed: { filteredList() { return this.languages.filter((item) => { return item.toLowerCase().includes(this.input.toLowerCase()) }) } } })
filteredList
计算的属性将包含一个包含输入字段值的项目数组。 在第一次渲染时(当输入字段为空时),将渲染整个数组。 当用户在字段中输入值时,filteredList
computed: { fullName() { return `${this.firstName} ${this.lastName}` } }여기서 이벤트 개체
는 예를 들어 양식을 제출할 때 브라우저의 기본 작업을 차단하는 것을 방지합니다.
🎜그러나 지시문을 사용하여 이벤트를 첨부하므로 수정자 🎜를 활용하여 더 우아해지세요 동일한 결과를 얻으려면@click.stop="handleSubmit"
을 사용하세요. 🎜🎜이제 배열의 데이터 목록을 필터링하는 메서드를 사용하는 예를 살펴보겠습니다. 🎜🎜데모에서는 데이터 목록과 검색 상자를 렌더링하려고 합니다. 사용자가 검색 상자에 값을 입력할 때마다 렌더링된 데이터가 변경됩니다. 템플릿은 다음과 같습니다. 🎜<div id="app"> <h2 id="Language-nbsp-Search">Language Search</h2> <div class="form-group"> <input type="text" v-model="input" placeholder="Enter language" class="form-control" /> </div> <ul v-for="(item, index) in languages" class="list-group"> <li class="list-group-item" :key="item">{{ item }}</li> </ul> </div>🎜보시다시피, 사용자가 검색 필드에 입력할 때마다 호출되는 handlerSearch 메소드를 참조합니다. 메소드와 데이터를 생성해야 합니다. 🎜
new Vue({ el: "#app", data() { return { input: '', languages: [] } }, watch: { input: { handler() { this.languages = [ 'JavaScript', 'Ruby', 'Scala', 'Python', 'Java', 'Kotlin', 'Elixir' ].filter(item => item.toLowerCase().includes(this.input.toLowerCase())) }, immediate: true } }})🎜handleSearch 메소드는 나열된 항목을 입력 필드의 값으로 업데이트합니다. 한 가지 주목할 점은 메소드 객체에서 this.handleSearch를 사용하여 메소드를 참조할 필요가 없다는 것입니다(대응 시 이 작업을 수행해야 함). 🎜🎜🎜🎜🎜계산된 속성🎜🎜🎜위 예의 검색은 예상대로 작동하지만 보다 우아한 해결책은 계산된 속성 🎜. 계산된 속성은 기존 리소스의 새 데이터를 결합하는 데 매우 편리하며 메서드에 비해 큰 장점 중 하나는 출력을 캐시할 수 있다는 것입니다. 즉, 계산된 속성과 관련되지 않은 페이지의 내용이 변경되고 UI가 다시 렌더링되면 캐시된 결과가 반환되고 계산된 속성은 다시 계산되지 않으므로 잠재적으로 비용이 많이 드는 작업이 절약됩니다. 🎜🎜계산된 속성을 사용하면 사용 가능한 데이터를 사용하여 즉시 계산을 수행할 수 있습니다. 이 경우 정렬해야 할 일련의 항목이 있습니다. 사용자가 입력 필드에 값을 입력하면 정렬을 원합니다. 🎜🎜우리 템플릿은 계산된 속성(
filteredList
)을 v-for
지시어에 전달한다는 점을 제외하면 이전 반복과 거의 동일해 보입니다. 🎜rrreee🎜스크립트 섹션 생략 차이점이 있습니다. 메소드를 계산된 속성으로 이동하는 대신 data
속성(이전에는 빈 배열)에서 언어를 선언합니다. 🎜rrreee🎜filteredList
계산된 속성은 다음을 포함합니다. 입력 필드 값을 포함하는 항목 배열입니다. 첫 번째 렌더링 시(입력 필드가 비어 있는 경우) 전체 배열이 렌더링됩니다. 사용자가 필드에 값을 입력하면 filteredList
는 필드에 입력된 값이 포함된 배열을 반환합니다. 🎜🎜계산된 속성을 사용할 때 계산할 데이터를 사용할 수 있어야 합니다. 그렇지 않으면 응용 프로그램 오류가 발생합니다. 🎜🎜계산된 속성은 새로운 FilterList 속성을 생성하므로 템플릿에서 이를 참조할 수 있습니다. 종속성이 변경될 때마다filteredList의 값이 변경됩니다. 여기서 변경하기 쉬운 종속성은 입력 값입니다. 🎜
最后,请注意,计算属性使我们可以创建一个变量,以在由一个或多个数据属性构建的模板中使用。一个常见的示例是fullName从用户的名字和姓氏创建一个,如下所示:
computed: { fullName() { return `${this.firstName} ${this.lastName}` } }
在模板中,您可以执行{{fullName}}。每当第一个或最后一个名称的值发生变化时,fullName的值就会发生变化。
观察者
当您希望对发生的更改(例如,对一个道具或数据属性)执行一个操作时,观察者非常有用。正如Vue文档所述,当您希望执行异步或昂贵的操作来响应数据更改时,这是最有用的。
在我们的搜索示例中,我们可以返回到方法示例,并为input
data属性设置一个监视程序。然后,我们可以对input
值的任何变化做出反应。
首先,让我们还原模板以利用languages
data属性:
<div id="app"> <h2 id="Language-nbsp-Search">Language Search</h2> <div class="form-group"> <input type="text" v-model="input" placeholder="Enter language" class="form-control" /> </div> <ul v-for="(item, index) in languages" class="list-group"> <li class="list-group-item" :key="item">{{ item }}</li> </ul> </div>
然后我们的Vue实例将如下所示:
new Vue({ el: "#app", data() { return { input: '', languages: [] } }, watch: { input: { handler() { this.languages = [ 'JavaScript', 'Ruby', 'Scala', 'Python', 'Java', 'Kotlin', 'Elixir' ].filter(item => item.toLowerCase().includes(this.input.toLowerCase())) }, immediate: true } }})
在这里,我已经将观察者作为对象(而不是函数)。这样,我可以指定一个immediate
属性,该属性将导致观察者在安装组件后立即触发。这具有填充列表的效果。然后,运行的函数在该handler
属性中。
结论
正如他们所说,强大的力量伴随着巨大的责任。Vue为您提供了构建出色应用程序所需的超能力。知道何时使用它们是建立用户喜爱的关键。方法、计算属性和观察者是您可以使用的超能力的一部分。展望未来,一定要好好利用它们!
相关推荐:
更多编程相关知识,请访问:编程入门!!
위 내용은 Vue의 계산된 속성, 메서드 및 Watch의 차이점의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Netflix는 React를 프론트 엔드 프레임 워크로 사용합니다. 1) React의 구성 요소화 된 개발 모델과 강력한 생태계가 Netflix가 선택한 주된 이유입니다. 2) 구성 요소화를 통해 Netflix는 복잡한 인터페이스를 비디오 플레이어, 권장 목록 및 사용자 댓글과 같은 관리 가능한 청크로 분할합니다. 3) React의 가상 DOM 및 구성 요소 수명주기는 렌더링 효율성 및 사용자 상호 작용 관리를 최적화합니다.

프론트 엔드 기술에서 Netflix의 선택은 주로 성능 최적화, 확장 성 및 사용자 경험의 세 가지 측면에 중점을 둡니다. 1. 성능 최적화 : Netflix는 React를 주요 프레임 워크로 선택하고 Speedcurve 및 Boomerang과 같은 도구를 개발하여 사용자 경험을 모니터링하고 최적화했습니다. 2. 확장 성 : 마이크로 프론트 엔드 아키텍처를 채택하여 응용 프로그램을 독립 모듈로 분할하여 개발 효율성 및 시스템 확장 성을 향상시킵니다. 3. 사용자 경험 : Netflix는 재료 -UI 구성 요소 라이브러리를 사용하여 A/B 테스트 및 사용자 피드백을 통해 인터페이스를 지속적으로 최적화하여 일관성과 미학을 보장합니다.

NetflixusesAcustomFrameworkCalled "Gibbon"BuiltonReact, NotreactorVuedirectly.1) TeamExperience : 2) ProjectComplexity : vueforsimplerProjects, 3) CustomizationNeeds : reactoffersmoreflex.4)

Netflix는 주로 프레임 워크 선택의 성능, 확장 성, 개발 효율성, 생태계, 기술 부채 및 유지 보수 비용을 고려합니다. 1. 성능 및 확장 성 : Java 및 SpringBoot는 대규모 데이터 및 높은 동시 요청을 효율적으로 처리하기 위해 선택됩니다. 2. 개발 효율성 및 생태계 : React를 사용하여 프론트 엔드 개발 효율성을 향상시키고 풍부한 생태계를 활용하십시오. 3. 기술 부채 및 유지 보수 비용 : Node.js를 선택하여 유지 보수 비용과 기술 부채를 줄이기 위해 마이크로 서비스를 구축하십시오.

Netflix는 주로 VUE가 특정 기능을 위해 보충하는 프론트 엔드 프레임 워크로 React를 사용합니다. 1) React의 구성 요소화 및 가상 DOM은 Netflix 애플리케이션의 성능 및 개발 효율을 향상시킵니다. 2) VUE는 Netflix의 내부 도구 및 소규모 프로젝트에 사용되며 유연성과 사용 편의성이 핵심입니다.

vue.js는 복잡한 사용자 인터페이스를 구축하는 데 적합한 점진적인 JavaScript 프레임 워크입니다. 1) 핵심 개념에는 반응 형 데이터, 구성 요소화 및 가상 DOM이 포함됩니다. 2) 실제 응용 분야에서는 TODO 응용 프로그램을 구축하고 Vuerouter를 통합하여 시연 할 수 있습니다. 3) 디버깅 할 때 VuedeVtools 및 Console.log를 사용하는 것이 좋습니다. 4) 성능 최적화는 V-IF/V- 쇼, 목록 렌더링 최적화, 구성 요소의 비동기로드 등을 통해 달성 할 수 있습니다.

vue.js는 중소형 프로젝트에 적합하지만 REACT는 크고 복잡한 응용 프로그램에 더 적합합니다. 1. Vue.js의 응답 형 시스템은 종속성 추적을 통해 DOM을 자동으로 업데이트하여 데이터 변경을 쉽게 관리 할 수 있습니다. 2. 반응은 단방향 데이터 흐름을 채택하고 데이터 흐름에서 하위 구성 요소로 데이터가 흐르고 명확한 데이터 흐름과 곤란하기 쉬운 구조를 제공합니다.

vue.js는 중소형 프로젝트 및 빠른 반복에 적합한 반면 React는 크고 복잡한 응용 프로그램에 적합합니다. 1) vue.js는 사용하기 쉽고 팀이 불충분하거나 프로젝트 규모가 작는 상황에 적합합니다. 2) React는 더 풍부한 생태계를 가지고 있으며 고성능 및 복잡한 기능적 요구가있는 프로젝트에 적합합니다.


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
