
Trong bài đăng này, ban sẽ tìm hiểu cách thay thế tất cả các lần xuất hiện chuỗi trong JavaScript bằng cách tách và nối một chuỗi, string.replace() kết hợp với biểu thức chính quy toàn cực và string.replaceAll().
Tách và nối một mảng
Nếu google cách thay thế tất cả các lần xuất hiện chuỗi trong JavaScript, cách tiếp cận đầu tiền bạn có thể tìm thấy là sử dụng một mảng trung gian:
Đây là cách hoạt động
1.Chia string
thành pieces
chuỗi search
:
2.Sau đó nối các mảnh đặt replace
chuỗi ở giữa:
Ví dụ: hãy thay thế tất cả khoảng trắng ' '
bằng dấu gạch nối '-'
trong 'duck duck go'
chuỗi:
'duck duck go'.split(' ')
chia chuỗi thành nhiều phần: ['duck', 'duck', 'go']
.
Sau đó, các mảnh ['duck', 'duck', 'go'].join('-')
được nối lại bằng cách chèn '-'
vào giữa chúng, tạo ra chuỗi 'duck-duck-go'
.
Đây là một hàm trợ giúp tổng quát sử dụng phương pháp chia tách và nối:
JS Mở bản demo.
Cách tiếp cận này yêu cầu chuyển đổi chuỗi thành một mảng và sau đó quay lại thành chuỗi. Hãy tiếp tục tìm kiếm những lựa chọn thay thế tốt hơn.
Thay thế () bằng biểu tượng thức chính quy toàn cục
Phương thức chuỗi string.replace(regExpSearch, replaceWith)
tìmkiếm và thay thế các lần xuất hiện của biểu thức chính quy regExpSearch
bằng replaceWith
chuỗi.
Để làm cho phương thức replace()
thay thế tất cả các lần xuất hiện của mẫu - bạn phải bật cờ chung trên biểu thức chính quy:
- Nối
g
vào cuối biểu thức chính quy theo nghĩa đen:/search/g
- Hoặc khi sử dụng hàm tạo biểu thức chính quy, hãy thêm
'g'
vào đối số thứ hai:new RegExp('search', 'g')
Hãy thay thế tất cả các lần xuất hiện của ' '
bằng '-'
:
Biểu thức chính quy /\s/g
(lưu ý g
cờ chung) khớp với khoảng trắng ' '
.
'duck duck go'.replace(/\s/g, '-')
thay thế tất cả các kết quả khớp /\s/g
bằng '-'
, dẫn đến 'duck-duck-go'
.
Bạn có thể dễ dàng thực hiện thay thế không phân biệt chữ hoa chữ thường bằng cách thêm i
cờ vào biểu thức chính quy:
Biểu thức chính quy /\s/g
(lưu ý g
cờ chung) khớp với khoảng trắng ' '
.
'duck duck go'.replace(/\s/g, '-')
thay thế tất cả các kết quả khớp /\s/g
bằng '-'
, dẫn đến 'duck-duck-go'
.
Bạn có thể dễ dàng thực hiện thay thế không phân biệt chữ hoa chữ thường bằng cách thêm i
cờ vào biểu thức chính quy:
Biểu thức chính quy /duck/gi
thực hiện tìm kiếm không phân biệt chữ hoa chữ thường (ghi chú i
và g
cờ). /duck/gi
trận đấu 'DUCK'
, cũng như 'Duck'
.
Việc gọi 'DUCK Duck go'.replace(/duck/gi, 'goose')
sẽ thay thế tất cả kết quả khớp của /duck/gi
chuỗi con bằng 'goose'
.
Biểu thức chính quy từ một chuỗi
Khi biểu thức chính quy được tạo từ một chuỗi, bạn phải thoát khỏi các ký tự - [ ] / { } ( ) * + ? . \ ^ $ |
vì chúng có ý nghĩa đặc biệt trong biểu thức chính quy.
Vì vậy, các ký tự đặc biệt là một vấn đề khi bạn muốn thực hiện thay thế mọi thao tác. Đây là một ví dụ:
Đoạn mã trên cố gắng chuyển chuỗi tìm kiếm '+'
thành một biểu thức chính quy. Nhưng '+'
là một biểu thức chính quy không hợp lệ nên sẽ SyntaxError: Invalid regular expression: /+/
bị loại bỏ.
Thoát khỏi nhân vật '\\+'
sẽ giải quyết được vấn đề. JS thử bản demo cố định
Thay thế() bằng một chuỗi
Nếu đối số đầu tiên search
của string.replace(search, replaceWith)
là một chuỗi thì phương thức này chỉ thay thế lần xuất hiện đầu tiên của search
:
'duck duck go'.replace(' ', '-')
chỉ thay thế sự xuất hiện đầu tiên của một khoảng trắng.
Phương thức thay thếAll()
Cuối cùng, phương thức này string.replaceAll(search, replaceWith)
thay thế tất cả sự xuất hiện của search
chuỗi bằng replaceWith
.
Hãy thay thế tất cả các lần xuất hiện của ' '
bằng '-'
:
'duck duck go'.replaceAll(' ', '-')
thay thế tất cả các lần xuất hiện của ' '
chuỗi bằng '-'
.
string.replaceAll(search, replaceWith)
là cách tốt nhất để thay thế tất cả các lần xuất hiện chuỗi trong một chuỗi
Lưu ý rằng trình duyệt hỗ trợ phương pháp này hiện bị hạn chế và bạn có thể yêu cầu polyfill .
Sự khác biệt giữa thay thếAll() và thay thế()
Các phương thức chuỗi replaceAll(search, replaceWith)
và replace(search, replaceWith)
cách hoạt động đều giống nhau, ngoại trừ 2 điều:
- Nếu
search
đối số là một chuỗi,replaceAll()
thay thế tất cả các lần xuất hiệnsearch
bằng ,replaceWith
trong khi chỉreplace()
thay thế lần xuất hiện đầu tiên - Nếu
search
đối số là một biểu thức chính quy không toàn cục thì sẽreplaceAll()
đưa ra mộtTypeError
ngoại lệ.

Devwork là Nền tảng TUYỂN DỤNG IT CẤP TỐC với mô hình kết nối Nhà tuyển dụng với mạng lưới hơn 30.000 headhunter tuyển dụng ở khắp mọi nơi.Với hơn 1800 doanh nghiệp IT tin dùng Devwork để :
Tag Cloud:
Tác giả: quyenntt
Việc làm tại Devwork
Bài viết liên quan

Lỗi 502 Bad Gateway là gì? Cách nhận biết và sửa lỗi nhanh nhất
Khi truy cập website, bạn đôi khi gặp phải màn hình thông báo lỗi 502 Bad Gateway đầy khó chịu. Vậy lỗi 502 Bad Gateway là gì? Bài viết này sẽ cung cấp cho bạn thông tin đầy đủ về lỗi này cùng các phương pháp khắc phục hiệu quả, nhanh chóng nhất....
Endpoint là gì? 7 nguyên tắc thiết kế Endpoint hoàn hảo
Endpoint là gì và tại sao lại quan trọng trong phát triển phần mềm hiện đại? Bài viết từ Devwork sẽ giúp bạn hiểu rõ về khái niệm này, cách thiết kế endpoint hiệu quả và tránh những lỗi phổ biến khi làm việc với API. Cùng khám phá những nguyên tắc thiết kế endpoint giúp hệ thống của bạn vận hành mượt mà.

Mô hình OKRs là gì? Sự khác biệt giữa mô hình OKR và KPI
Một trong những phương pháp quản lý mục tiêu hiệu quả nhất hiện nay chính là OKR. Vậy OKRs là gì? Mô hình OKR là gì? Và tại sao nó lại ngày càng phổ biến? Hãy cùng Devwork tìm hiểu chi tiết trong bài viết này.

File XML là gì? Tìm hiểu tất tần tật về file XML từ A-Z
File XML là một ngôn ngữ đánh dấu linh hoạt, đã trở thành một phần không thể thiếu trong nhiều ứng dụng khác nhau. Vậy XML là gì? File XML là gì? File có đuôi xml là gì? Hãy cùng Devwork khám phá tất tần tật về XML trong bài viết này.


Mạng CDN là gì? Hiểu đúng bản chất và cách hoạt động chi tiết
Mạng CDN (Content Delivery Network) đóng vai trò then chốt trong việc tối ưu hóa hiệu suất website và ứng dụng trong thời đại số hiện nay. Bài viết này sẽ giúp bạn hiểu sâu về bản chất, cơ chế hoạt động và những lợi ích mà mạng CDN mang lại cho cá nhân và doanh nghiệp trong kỷ nguyên dữ liệu số.

Kubernetes là gì? Cách hoạt động, thành phần và ứng dụng thực tế
Kubernetes là gì và vì sao nó trở thành công nghệ không thể thiếu cho doanh nghiệp? Devwork hướng dẫn bạn khám phá nền tảng quản lý container mạnh mẽ này, giúp các doanh nghiệp tối ưu hóa quy trình vận hành và phát triển phần mềm hiệu quả trong môi trường đám mây.
