- vừa được xem lúc

Bài 6: Sử dụng watcher trong VueJS

0 0 16

Người đăng: Mai Trung Đức

Theo Viblo Asia

Chào mừng các bạn quay trở lại series học VueJS với Laravel của mình. Ở bài trước mình đã hướng dẫn các bạn về Computed. Ở bài này chúng ta sẽ chuyển qua tìm hiểu về watcher, một các rất hữu hiệu để quan sát và xử lý khi có một thay đổi trên dữ liệu.

Giới thiệu và cách sử dụng

Cùng với computed có thể xử lý việc chỉ tính toán lại khi có sự thay đổi trên dữ liệu, giúp tiết kiệm được nhiều chi phí thì Vue cung cấp cho chúng ta một cách tổng quan hơn để xử lý những dữ liệu bị thay đổi

Với việc sử dụng watch có thể giúp chúng ta theo dõi sự thay đổi và sau đó thực hiện những tính toán phức tạp.

Chúng ta sẽ cùng làm một vài ví dụ để hiểu hơn về watch nhé. Quay trở lại với ví dụ ở các bài trước.

<template> <div class="my-component"> <div>{{ message }}</div> <div><button @click="changeMessage">Click me</button></div> </div>
</template> <script> export default { data() { return { message: 'This is my first component using binding data' } }, methods: { changeMessage() { this.message = 'this is new message' } } }
</script> <style lang="scss" scoped> .my-component { color: red; }
</style>

Ở đây khi chúng ta click vào button thì giá trị của message sẽ bị thay đổi. Chúng ta sẽ thêm watcher cho message để mỗi lần giá trị của nó thay đổi thì ta sẽ in ra cửa sổ console một thông báo nhé. Ta sửa lại code như sau

<template> <div class="my-component"> <div>{{ message }}</div> <div><button @click="changeMessage">Click me</button></div> </div>
</template> <script> export default { data() { return { message: 'This is my first component using binding data' } }, methods: { changeMessage() { this.message = 'this is new message' } }, watch: { message() { console.log('message changed') } } }
</script> <style lang="scss" scoped> .my-component { color: red; }
</style>

Các bạn mở ứng dụng lên, click vào button và xem kết quả nhé:

Các bạn có thể thấy khi message thay đổi thì trên cửa sổ console đã xuất hiện thông báo. Vì computed cũng sử dụng giống như những property trong data nên chúng ta cũng có thể watch computed, cùng xem thử đoạn code sau:

<template> <div class="my-component"> <div>{{ reverseMessage }}</div> <div><button @click="changeMessage">Click me</button></div> </div>
</template> <script> export default { data() { return { message: '' } }, methods: { changeMessage() { this.message = 'this is new message' } }, computed: { reverseMessage() { return this.message.split('').reverse().join('') } }, watch: { reverseMessage() { console.log('Computed changed') } } }
</script> <style lang="scss" scoped> .my-component { color: red; }
</style>

Ở đây khi click vào button thì message thay đổi dẫn đến computed thay đổi theo, khi watcher sẽ nhận biết và làm các công việc cần thiết.

Tiếp theo, một trường hợp khá phổ biến là khi các bạn muốn watch khi có sự thay đổi của các thuộc tính bên trong một object. Cùng xem ví dụ sau.

<template> <div class="my-component"> <div>{{ message.text }}</div> <div><button @click="changeMessage">Click me</button></div> </div>
</template> <script> export default { data() { return { message: { type: 'greeting', text: 'How are you?' } } }, methods: { changeMessage() { this.message.text = 'this is new message' } }, watch: { message: { handler: function () { console.log('something changed') }, deep: true } } }
</script> <style lang="scss" scoped> .my-component { color: red; }
</style>

Ở trên chúng ta có đối tượng message với 2 thuộc tính và giá trị tương ứng. Khi muốn watch sự thay đổi của bất kì dữ liệu nào bên trong message thì chúng ta cần sử dụng đến deep watch. Các bạn thử load lại trình duyệt và test kết quả nhé.

Vậy có bạn sẽ thắc mắc: "thế muốn chỉ watch với một thuộc tính cụ thể thì làm thế nào, chẳng hạn muốn watch với chỉ type hoặc text thì sao?". Khi đó chúng ta sử dụng một chút thủ thuật sau nhé, cùng xem qua code nào các bạn:

<template> <div class="my-component"> <div>Message type: {{ message.type }}</div> <div>Message text: {{ message.text }}</div> <div><button @click="changeType">Change type</button></div> <div><button @click="changeText">Change text</button></div> </div>
</template> <script> export default { data() { return { message: { type: 'greeting', text: 'How are you?' } } }, methods: { changeType() { this.message.type = 'this is new type' }, changeText() { this.message.text = 'this is new text' } }, computed: { getType() { return this.message.type }, getText() { return this.message.text } }, watch: { getType() { console.log('type changed') }, getText() { console.log('text changed') } } }
</script> <style lang="scss" scoped> .my-component { color: red; }
</style>

Chúng ta tạo ra computed với giá trị trả về là thuộc tính mong muốn watch của đối tượng. sau đó ở watch chúng ta áp dụng lên các computed đó.

Các bạn thử load lại trình duyệt và xem kết quả xem thế nào ?.

Kết luận

Qua bài này hi vọng rằng các bạn đã hiểu được phần nào đó những tác dụng bằng cách sử dụng watcher để có thể theo dõi sự biến đổi của dữ liệu, từ đó áp dụng vào công việc thực tế của chính mình.

Bài tiếp theo chúng ta sẽ cùng tìm hiểu về Conditional Rendering (giống như các toán từ điều kiện if, else, mà chúng ta thường dùng).

Cám ơn các bạn đã theo dõi, có gì thắc mắc các bạn comment bên dưới nhé ^^!

Bình luận

Bài viết tương tự

- vừa được xem lúc

Giới thiệu Typescript - Sự khác nhau giữa Typescript và Javascript

Typescript là gì. TypeScript là một ngôn ngữ giúp cung cấp quy mô lớn hơn so với JavaScript.

0 0 528

- vừa được xem lúc

Cài đặt WSL / WSL2 trên Windows 10 để code như trên Ubuntu

Sau vài ba năm mình chuyển qua code trên Ubuntu thì thật không thể phủ nhận rằng mình đã yêu em nó. Cá nhân mình sử dụng Ubuntu để code web thì thật là tuyệt vời.

0 0 425

- vừa được xem lúc

Đặt tên commit message sao cho "tình nghĩa anh em chắc chắn bền lâu"????

. Lời mở đầu. .

1 1 796

- vừa được xem lúc

Tìm hiểu về Resource Controller trong Laravel

Giới thiệu. Trong laravel, việc sử dụng các route post, get, group để gọi đến 1 action của Controller đã là quá quen đối với các bạn sử dụng framework này.

0 0 387

- vừa được xem lúc

Phân quyền đơn giản với package Laravel permission

Như các bạn đã biết, phân quyền trong một ứng dụng là một phần không thể thiếu trong việc phát triển phần mềm, dù đó là ứng dụng web hay là mobile. Vậy nên, hôm nay mình sẽ giới thiệu một package có thể giúp các bạn phân quyền nhanh và đơn giản trong một website được viết bằng PHP với framework là L

0 0 477

- vừa được xem lúc

Bạn đã biết các tips này khi làm việc với chuỗi trong JavaScript chưa ?

Hi xin chào các bạn, tiếp tục chuỗi chủ đề về cái thằng JavaScript này, hôm nay mình sẽ giới thiệu cho các bạn một số thủ thuật hay ho khi làm việc với chuỗi trong JavaScript có thể bạn đã hoặc chưa từng dùng. Cụ thể như nào thì hãy cùng mình tìm hiểu trong bài viết này nhé (go).

0 0 437