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

NodeJS Bài 4: Query Parameters

0 0 32

Người đăng: Đức Phúc

Theo Viblo Asia

Series NodeJS căn bản cho người mới bắt đầu

Xem bài viết mới - ReactJS -Những câu hỏi phỏng vấn thường gặp - Phần 1

1. Query parameters là gì?

Hôm nay chúng ta sẽ tìm hiểu về query parameters trong NodeJS. Vậy nó là gì?

Query parameters là một chuỗi truy vấn được client gửi lên server. Server sẽ nhận các thông tin này để xử lý và trả về một kết quả phù hợp với truy vấn được gửi lên

2. Query trong URL

Các chuỗi truy vấn có thể được đính kèm trong một URL. Trong URL, các truy vấn sẽ bắt đầu từ sau dấu ? , mỗi truy vấn là một cặp {key:value}, các cặp ngăn cách nhau bởi kí tự & tạo thành một object gọi là param và được gửi lên server. Ví dụ:

Với URL: http://example.com/users?name=viblo&age=20 sẽ được chuyển thành object là:

{ name: "viblo", age: "20"
}

3. Xây dựng chức năng tìm kiếm

3.1. Xây dựng chức năng tìm kiếm user theo tên

Đầu tiên, ta sẽ tạo một route để có thể tìm kiếm user, ở đây mình sẽ tạo một route tại /users/search. Chức năng này để lấy các user phù hợp với truy vấn, nên ta sẽ dùng method là get .

app.get('/users/search', (req,res) => { // search and return here
})

Ở trên mình đã viết hàm theo chuẩn ES6, các bạn có thể tìm hiểu thêm nhé, hoặc viết như các bài học trước cũng được

Tạo một form HTML để search, mình sẽ tạo tại trang index của users

form.seach-form(action="/users/search") input(name="name", type="text", placeholder="name") input(type="submit")

Nhắc lại một chút kiến thức cũ về HTML

  • Thuộc tính action quy định đường dẫn mà dữ liệu của form sẽ được gửi đến
  • Với mỗi thẻ input, thuộc tính name sẽ tương ứng với key, giá trị của mỗi trường input tương ứng value trong mỗi cặp query

Hãy thử nhập một cái tên nào đó, ví dụ "User1", Inspect trang web và chọn tab Network, bạn sẽ thấy một request được gửi lên

Bây giờ, ta sẽ xem server đã nhận được request này chưa nhé!!! Đối tượng req cung cấp cho ta một thuộc tính query để lấy được query mà client gửi lên. Hãy thử in nó ra nhé!!!

app.get('/users/search', (req,res) => { console.log(req.query);
})

Tại của sổ cmd, bạn sẽ thấy kết quả như sau:

{name: 'User1'}

Như vậy là server đã nhận được yêu cầu từ client, Bây giờ ta sẽ thực hiện tìm kiếm user. Ở bài trước, mình đã khai báo một mảng array gồm các user trong route '/users'. Để các route khác có thể sử dụng, ta sẽ đưa array này ra ngoài. Mã nguồn file app.js bây giờ sẽ như sau:

const express = require('express'); // Require module express vào project
const app = express(); // Tạo một app mới
const port = 8080; // Định nghĩa cổng để chạy ứng dụng NodeJS của bạn trên server app.set('views', './views'); // Thư mục views nằm cùng cấp với file app.js
app.set('view engine', 'pug'); // Sử dụng pug làm view engine var users = [ {name: "User1", email: "_@.com"}, {name: "User2", email: "_@.com"}
]; app.get('/', function(req, res){ res.send("<h2>This is my first app</h2>");
}) app.get('/users', function(req, res){ res.render('users/index',{ users: users });
}) app.get('/users/search', (req,res) => { console.log(req.query);
}) app.listen(port, function(){ console.log('Your app running on port '+ port);
})

Tiếp tục, ta sẽ xử lý việc tìm kiếm. Việc này bây giờ trở nên đơn giản, vì các bạn đã học JavaScript, và đã biết cách tìm "một chuỗi con trong chuỗi cha" rồi. Nên mình sẽ không giải thích chi tiết nữa nhé!!! Phần này các bạn có thể tìm hiểu một cách dễ dàng

app.get('/users/search', (req,res) => { var name_search = req.query.name // lấy giá trị của key name trong query parameters gửi lên var result = users.filter( (user) => { // tìm kiếm chuỗi name_search trong user name.  // Lưu ý: Chuyển tên về cùng in thường hoặc cùng in hoa để không phân biệt hoa, thường khi tìm kiếm return user.name.toLowerCase().indexOf(name_search.toLowerCase()) !== -1 }) res.render('users/index', { users: result // render lại trang users/index với biến users bây giờ chỉ bao gồm các kết quả phù hợp });
})

Như vậy là hoàn thành việc tìm kiếm và trả về kết quả. Ta sẽ hiệu chỉnh lại mã HTML một chút ứng với 2 trường hợp

  • Nếu biến users có length > 0, tức là tồn tại user, thì hiển thị các user đó
  • Ngược lại, hiển thị "No user to display"
form.seach-form(action="/users/search") input(name="name", type="text", placeholder="name") input(type="submit") .users h2 All users if users.length > 0 table thead tr th Name th Email tbody each user in users tr td= user.name td= user.email else p No user to display

Xong!!! Các bạn hãy thử test chức năng này nhé

3.2 Xây dựng chức năng tìm kiếm user theo tên và theo tuổi

Ta sẽ thêm một trường tuổi vào array users

var users = [ {name: "User1", email: "_@.com", age: 31}, {name: "User2", email: "_@.com", age: 20}, {name: "User1", email: "_@.com", age: 25}
];

Ta sẽ thấy có 2 user cùng có name là "User1", nhưng tuổi (age) khác nhau. Trường email là trường khóa chính, để phân biệt giữa các user

Hiệu chỉnh lại mã HTML để hiển thị tuổi, cũng như thêm input age để tìm kiếm

form.seach-form(action="/users/search") input(name="name", type="text", placeholder="name") input(name="age", type="text", placeholder="age") input(type="submit") .users h2 All users if users.length > 0 table thead tr th Name th Email th Age tbody each user in users tr td= user.name td= user.email td= user.age else p No user to display

Chỉnh lại chức năng tìm kiếm (thêm điều kiện theo tuổi)

app.get('/users/search', (req,res) => { var name_search = req.query.name // lấy giá trị của key name trong query parameters gửi lên var age_search = req.query.age // lấy giá trị của key age trong query parameters gửi lên var result = users.filter( (user) => { // tìm kiếm chuỗi name_search trong user name.  // Lưu ý: Chuyển tên về cùng in thường hoặc cùng in hoa để không phân biệt hoa, thường khi tìm kiếm return user.name.toLowerCase().indexOf(name_search.toLowerCase()) !== -1 && user.age === parseInt(age_search) }) res.render('users/index', { users: result // render lại trang users/index với biến users bây giờ chỉ bao gồm các kết quả phù hợp });
})

Hãy thử gửi một request mới lên nhé. Nó sẽ bao gồm cả name và age cần tìm kiếm

Cuối cùng, chúng ta đã làm được chức năng tìm kiếm. Các bạn có thể tự sáng tạo và nâng cấp chức năng này để hoàn thiện hơn. Thông qua bài này, ta đã học thêm được về req.query cũng như biết thêm về cú pháp if...else trong pug

Hẹn gặp lại các bạn trong các bài viết tiếp theo !!!

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 500

- 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 374

- 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 701

- 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 335

- 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 421

- 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 414