• Kiến thức
  • Network
  • Security
  • Software
  • Thủ thuật
  • Tin học văn phòng
  • Tin tức
  • Mail ảo tạm thời miễn phí
  • Tools tra cứu thông tin
  • Công cụ đổi số thành chữ
AnonyViet
  • Tin tức
  • Network
    • Mạng cơ bản
    • Hyper-V
    • Linux
    • Windown Server 2012
  • Security
    • Basic Hacking
    • Deface
    • Kali Linux / Parrot
    • SQL Injection
  • Thủ thuật
    • Khóa Học Miễn Phí
    • Code
    • Mẹo Vặt Máy Tính
    • Facebook
    • Windows 7/8/10/11
    • Đồ Họa
    • Video
  • Software
    • Phần mềm máy tính
    • Phần mềm điện thoại
  • Tin học văn phòng
  • Kiến thức
  • MMO
    • Advertisers – Publishers
    • Affiliate Program
    • Kiếm tiền bằng điện thoại
    • Pay Per Click – PPC
No Result
View All Result
  • Tin tức
  • Network
    • Mạng cơ bản
    • Hyper-V
    • Linux
    • Windown Server 2012
  • Security
    • Basic Hacking
    • Deface
    • Kali Linux / Parrot
    • SQL Injection
  • Thủ thuật
    • Khóa Học Miễn Phí
    • Code
    • Mẹo Vặt Máy Tính
    • Facebook
    • Windows 7/8/10/11
    • Đồ Họa
    • Video
  • Software
    • Phần mềm máy tính
    • Phần mềm điện thoại
  • Tin học văn phòng
  • Kiến thức
  • MMO
    • Advertisers – Publishers
    • Affiliate Program
    • Kiếm tiền bằng điện thoại
    • Pay Per Click – PPC
No Result
View All Result
AnonyViet
No Result
View All Result

Hướng dẫn tự tạo Extension Chrome bằng Scratch

Ellyx13 by Ellyx13
27/03/2021 - Updated on 24/07/2025
in Code
A A
0

Mục lục bài viết

  1. Yêu cầu
  2. Cách tạo Extension Chrome bằng Scratch
    1. Bước 1: Tạo giao diện – Template
    2. Bước 2: Code Extension
      1. manifest.json
      2. src\browser_action
      3. Code ban đầu của template
      4. Thiết kế giao diện cho cửa sổ popup
      5. Code logic cho popup
    3. Bước 3: Demo extension
  3. Đăng Extension lên Chrome Store
  4. Kết luận
  5. Câu hỏi thường gặp
    1. Tôi cần những kỹ năng gì để tạo Extension Chrome?
    2. Tôi có thể sử dụng công cụ nào để tạo template Extension?
    3. Tôi cần trả phí để phát hành Extension của mình không?

Bạn có từng thắc mắc làm sao để tạo Extension trên Chrome? Làm như thế nào để viết một Extension cho riêng mình? Extension hay còn gọi là tiện ích mở rộng được viết bằng javascript, sau đó được đăng tải lên Chrome Store để chia sẻ cho mọi người. Mặc dù bạn có thể tải extension từ Chrome Web Store, nhưng đôi khi bạn lại cần một tính năng mà không có bất kỳ extension nào có thì sao? Hay chỉ là muốn tự tạo extension cho chính mình sử dụng để không lo lắng về vấn đề thông tin riêng tư bị các extension độc hại khai thác.

Tham gia kênh Telegram của AnonyViet 👉 Link 👈

Bạn có thể tự tạo extension của riêng mình để thêm và sửa đổi các chức năng cần thiết hoặc tạo các tiện ích mở rộng mới cho Google Chrome, sau đó phát hành extension này cho nhiều người sử dụng thông qua Chome Web Store.

Các bài viết liên quan

2 cách đơn giản fix lỗi Chrome bị chặn bởi Family Safety 5

2 cách đơn giản fix lỗi Chrome bị chặn bởi Family Safety

25/08/2025
Cách tự động xóa lịch sử web sau khi thoát để bảo mật tuyệt đối 6

Cách tự động xóa lịch sử web sau khi thoát để bảo mật tuyệt đối

22/08/2025
Cách xóa mật khẩu đã lưu trên Chrome trước khi quá muộn 7

Cách xóa mật khẩu đã lưu trên Chrome trước khi quá muộn

05/08/2025
Cách Active Key Sublime Text 4 - Tải Sublime Text 4 Full Key 8

Cách Active Key Sublime Text 4 – Tải Sublime Text 4 Full Key

23/05/2025 - Updated on 25/07/2025

Hướng dẫn tự tạo Extension Chrome bằng Scratch

Trong bài viết này, mình sẽ hướng dẫn các bạn cách tạo extension dễ nhất bằng Scratch. Nếu bạn có một số kiến ​​thức về code web (HTML, CSS và JS), bạn sẽ cảm thấy thoải mái với các kiến thức mà mình chuẩn bị nói. Còn nếu bạn chưa có kiến thức về front-end, thì có thể đọc bài viết này để tìm ra các nguồn học phù hợp nhé.

Yêu cầu

Bạn cần hoàn thành các yêu cầu sau trước khi đọc tiếp bài viết này (thật ra là cũng không bắt buộc lắm đâu, vậy nên đọc tiếp đi nhé):

  1. Bạn phải quen thuộc với HTML, CSS và JavaScript
  2. Một chiếc editor xịn xò để viết extension (mình khuyên nên dùng VScode hoặc SublimeText3 nhé)
  3. (Tùy chọn) Nếu bạn muốn phát hành extension của mình cho những người dùng khác, bạn cần phải có tài khoản nhà phát triển tại Chrome Web Store, nếu không có thì tự cài thủ công.

Lưu ý: Google sẽ yêu cầu bạn trả một khoản phí nhỏ để tạo tài khoản nhà phát triển tại Chrome Web Store.

Cách tạo Extension Chrome bằng Scratch

Mình sẽ hướng dẫn cho các bạn quy trình để tạo ra một extension trên Google Chrome. Chúng ta sẽ tạo ra một extension to-do-app – nhắc việc đơn giản giống như hình bên dưới.

tự viết Extension Chrome bằng Scratch

Bước 1: Tạo giao diện – Template

Google Chrome, giống như bất kỳ nền tảng nào khác, đều yêu cầu các tiện ích mở rộng phải theo cấu trúc quy định, cái này hơi phức tạp với người mới. Đó là lý do tại sao bạn nên có một template mẫu cho extension cung cấp các tiêu chuẩn cần thiết.

Extensionizr là trình tạo template tốt nhất cho các tiện ích chrome. Nó cho phép bạn chọn một trong các loại tiện ích nhất định – browser action (tính năng ảnh hưởng đến tất cả các trang hoặc trình duyệt), page action (tính năng chỉ ảnh hưởng đến trang hiện tại) hoặc hidden extension (tính năng chạy nền thường được ẩn ở phía sau giao diện).

Tạo giao diện - Template cho extension

Hơn nữa, nó cung cấp các tùy chọn tinh chỉnh khác nhau để thêm hoặc loại trừ các tiện ích bổ sung, quyền cần thiết,… Bạn cần chọn “Browser action” làm loại tiện ích mở rộng và “No background” để làm background cho hướng dẫn này.

Xem thêm:  Hướng dẫn tự thay đổi biểu tượng cảm xúc trên Facebook

Khi bạn đã chọn xong các tùy chọn để tạo template extension của mình, hãy nhấp vào nút “Download it!” trong Extensionizr. Sau đó, giải nén file vừa mới tải xuống và mở trình viết code của bạn lên để viết extension.

Bước 2: Code Extension

Sau khi tải xuống và giải nén template, bạn sẽ thấy cấu trúc thư mục của một extension được quy định như hình dưới. Template được sắp xếp gọn gàng và bạn phải biết rằng tệp quan trọng nhất là “manifest.json”.

Code Extension

Hãy cùng tìm hiểu các tệp và thư mục trong extension:

  1. _locales: Nó được sử dụng để lưu trữ dữ liệu ngôn ngữ cho ứng dụng đa ngôn ngữ.
  2. css: có chức năng lưu trữ các thư viện front-end của bên thứ ba như Bootstrap.
  3. icons: được thiết kế để hiển thị cho các kích thước khác nhau của Extension.
  4. js: dùng để lưu các thư viện back-end của bên thứ ba như jQuery.
  5. src: lưu trữ code thực tế mà bạn sẽ viết cho tiện ích của mình.

manifest.json

Chứa dữ liệu cơ bản về ứng dụng của bạn, xác định thông tin chi tiết về ứng dụng của bạn cho trình duyệt. Bạn có thể chỉnh sửa nó để đặt tên, mô tả, website, icons,… cho extension cùng với các cài đặt cụ thể như browser actions và permissions của trình duyệt.

Ví dụ: trong đoạn code dưới đây, bạn sẽ thấy rằng mình đã thay đổi tên, mô tả và url cùng với default_title trong browser_action. Hơn nữa, mình đã thêm quyền “storage” vì chúng ta cần lưu trữ dữ liệu trong tiện ích mở rộng của mình.

{
 "name": "To-Do App Anonyviet",
 "version": "0.0.1",
 "manifest_version": 2,
 "description": "Ung dung nhac viec don gian",
 "homepage_url": "https://anonyviet.com",
 "icons": {
  "16": "icons/icon16.png",
  "48": "icons/icon48.png",
  "128": "icons/icon128.png"
 },
 "default_locale": "en",
 "browser_action": {
  "default_icon": "icons/icon19.png",
  "default_title": "To-Do App Anonyviet",
  "default_popup": "src/browser_action/browser_action.html"
 },
 "permissions": [
  "storage"
 ]
}

src\browser_action

Thư mục này sẽ chứa code cho browser_action của trình duyệt. Trong ví dụ này, mình sẽ code cửa sổ bật lên (popup) khi nhấp vào biểu tượng của extension trong trình duyệt. Tiện ích của mình sẽ cho phép người dùng thêm và xem các mục việc cần làm trong cửa sổ popup.

Code ban đầu của template

Mặc dù thư mục này chỉ có một tệp HTML chứa tất cả code, nhưng mình đã quyết định chia nó thành ba tệp riêng biệt để rõ ràng hơn. Vậy nên, tệp HTML có tên “browser_action.html” sẽ có code sau:

<!doctype html>
<html>
<head>
<link rel="stylesheet" href="./browser_action.css"/>
</head>
<body>
<div id="mainPopup">
</div>
<script type="text/javascript" src="./browser_action.js"></script>
</body>
</html>
Hơn nữa, tệp có tên “browser_action.css” sẽ có nội dung giống bên dưới trong khi tệp JavaScript có tên “browser_action.js” hiện đang trống.
#mainPopup {
padding: 10px;
height: 200px;
width: 400px;
font-family: Helvetica, Ubuntu, Arial, sans-serif;
}
h1 {
font-size: 2em;
}

Thiết kế giao diện cho cửa sổ popup

Sau khi hoàn tất các bước cài đặt ban đầu, tiếp theo chúng ta cần thiết kế giao diện cho cửa sổ popup. Mình đã thiết kế giao diện với cách tiếp cận tối giản, có tên ở trên cùng, chỗ thêm các mục việc cần làm và một khu vực bên dưới để xem các mục đã thêm. Giao diện được lấy cảm hứng từ “Form Style 5“.

Thiết kế giao diện cho cửa sổ popup Extension

Trong đoạn code bên dưới, mình đã thêm hai thẻ div – một để hiển thị form thêm việc cần làm và một để hiển thị danh sách các việc cần làm đã được thêm vào. Vậy nên, code mới của file “browser_action.html” sẽ như sau:

<!doctype html>
<html>
<head>
 <link rel="stylesheet" href="./browser_action.css"/>
</head>
<body>
 <div id="mainPopup">
  <!-- To-do item form -->
  <div class="form-style-5" id="form">
   <h1>Anonyviet</h1>
   <form>
    <fieldset>
     <input type="text" name="todo" placeholder="What to do?" id="txt">
     <input type="button" value="Add" id="btn" />
    </fieldset>
   </form>
  </div>
  <!-- To-do item list -->
  <div class="form-style-5">
   <ul id="list">
   </ul>
  </div>
 </div>
 <script type="text/javascript" src="./browser_action.js"></script>
</body>
</html>
Và code “browser_action.css” sẽ có nội dung như sau:
@import url("./form_style_5.css");
#mainPopup {
 height: 200px;
 width: 300px;
 font-family: Helvetica, Ubuntu, Arial, sans-serif;
}
/* To-do item form */
.form-style-5 {
 margin: auto;
 padding: 0px 20px;
}
.form-style-5:first-child {
 background: none;
}
.form-style-5 h1 {
 color: #308ce3;
 font-size: 20px;
 text-align: center;
}
.form-style-5 input[type="text"] {
 width: auto;
 float: left;
 margin-bottom: unset;
}
.form-style-5 input[type="button"] {
 background: #308ce3;
 width: auto;
 float: right;
 padding: 7px;
 border: none;
 border-radius: 4px;
 font-size: 14px;
}
.form-style-5 input[type="button"]:hover {
 background: #3868d5;
}
/* To-do item list */
.form-style-5:last-child {
 height: inherit;
 margin-bottom: 5px;
}
.form-style-5 ul {
 padding: 20px;
}
.form-style-5 ul li {
 font-size: 14px;
}
Cuối cùng, tệp “form_style_5.css” sẽ có nội dung như bên dưới. Code này chỉ đơn giản là lấy cảm hứng thiết kế từ trang gốc để sử dụng cho extension.
/* Form Style 5 by Sanwebe.com */
/* https://www.sanwebe.com/2014/08/css-html-forms-designs */
.form-style-5{
 max-width: 500px;
 padding: 10px 20px;
 background: #f4f7f8;
 margin: 10px auto;
 padding: 20px;
 background: #f4f7f8;
 border-radius: 8px;
 font-family: Georgia, "Times New Roman", Times, serif;
}
.form-style-5 fieldset{
 border: none;
}
.form-style-5 legend {
 font-size: 1.4em;
 margin-bottom: 10px;
}
.form-style-5 label {
 display: block;
 margin-bottom: 8px;
}
.form-style-5 input[type="text"],
.form-style-5 input[type="date"],
.form-style-5 input[type="datetime"],
.form-style-5 input[type="email"],
.form-style-5 input[type="number"],
.form-style-5 input[type="search"],
.form-style-5 input[type="time"],
.form-style-5 input[type="url"],
.form-style-5 textarea,
.form-style-5 select {
 font-family: Georgia, "Times New Roman", Times, serif;
 background: rgba(255,255,255,.1);
 border: none;
 border-radius: 4px;
 font-size: 16px;
 margin: 0;
 outline: 0;
 padding: 7px;
 width: 100%;
 box-sizing: border-box;
 -webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 background-color: #e8eeef;
 color:#8a97a0;
 -webkit-box-shadow: 0 1px 0 rgba(0,0,0,0.03) inset;
 box-shadow: 0 1px 0 rgba(0,0,0,0.03) inset;
 margin-bottom: 30px;
}
.form-style-5 input[type="text"]:focus,
.form-style-5 input[type="date"]:focus,
.form-style-5 input[type="datetime"]:focus,
.form-style-5 input[type="email"]:focus,
.form-style-5 input[type="number"]:focus,
.form-style-5 input[type="search"]:focus,
.form-style-5 input[type="time"]:focus,
.form-style-5 input[type="url"]:focus,
.form-style-5 textarea:focus,
.form-style-5 select:focus{
 background: #d2d9dd;
}
.form-style-5 select{
 -webkit-appearance: menulist-button;
 height:35px;
}
.form-style-5 .number {
 background: #1abc9c;
 color: #fff;
 height: 30px;
 width: 30px;
 display: inline-block;
 font-size: 0.8em;
 margin-right: 4px;
 line-height: 30px;
 text-align: center;
 text-shadow: 0 1px 0 rgba(255,255,255,0.2);
 border-radius: 15px 15px 15px 0px;
}
.form-style-5 input[type="submit"],
.form-style-5 input[type="button"]
{
 position: relative;
 display: block;
 padding: 19px 39px 18px 39px;
 color: #FFF;
 margin: 0 auto;
 background: #1abc9c;
 font-size: 18px;
 text-align: center;
 font-style: normal;
 width: 100%;
 border: 1px solid #16a085;
 border-width: 1px 1px 3px;
 margin-bottom: 10px;
}
.form-style-5 input[type="submit"]:hover,
.form-style-5 input[type="button"]:hover
{
 background: #109177;
}

Code logic cho popup

Sau khi hoàn thành xong giao diện của extension, công việc tiếp theo của chúng ta viết logic cho extension. Extension sẽ thực hiện 2 công việc sau: thêm việc cần làm và hiển thị chúng. Vì vậy, chúng ta cần code tính năng thêm việc và hiển thị chúng trên extension.

Xem thêm:  Extention Friend Ranking - Tạo bảng xếp hạng tương tác bạn bè trên Facebook

Trong đoạn code dưới đây, mình sẽ sử dụng hai hàm là sync.get() và sync.set(), là các hàm của “chrome.storage”. Hàm sync.set() lưu các việc cần làm vào bộ nhớ và sync.get() dùng để truy suất và hiển thị những việc cần làm. Mình có commnet vào từng tính năng của code cho các bạn tiện theo dõi nhé.

function loadItems() {
 /* First get() the data from the storage */
 chrome.storage.sync.get(['todo'], function(result) {
  var todo = []

  if (result && result.todo && result.todo.trim() !== '') {
   /* Parse and get the array as it is saved as a string */
   todo = JSON.parse(result.todo)
  }

  console.log('todo.length = ' + todo.length)

  for (var i = 0; i < todo.length; i++) {
   item = todo[i]

   if (item && item.trim() !== '') {
    /* Append the items in the #list for showing them */
    var list = document.getElementById('list')
    var entry = document.createElement('li')
    var text = document.createTextNode(item)

    entry.appendChild(text)
    list.appendChild(entry)
   }
  }
 })
}

/* Load the to-do items upon popup load */
document.addEventListener('DOMContentLoaded', function(){
 console.log('Inside doc.loaded()')

 loadItems()
})

/* Save the to-do item upon button click */
document.getElementById('btn').addEventListener('click', function (ev) {
 console.log('Inside btn.click()')

 text = document.getElementById('txt').value

 if (text && text.trim() !== '') {

  /* First get() old data as calling set() will replace it */
  chrome.storage.sync.get(['todo'], function(result) {
   var todo = []

   if (result && result.todo && result.todo.trim() !== '') {
    /* Parse and get the array as it is saved as a string */
    todo = JSON.parse(result.todo)
   }

   todo.push(text)

   chrome.storage.sync.set({'todo': JSON.stringify(todo)}, function() {
    /* Data is saved now */

    var list = document.getElementById('list')

    while (list.firstChild) {
     list.removeChild(list.firstChild)
    }

    loadItems()
   })
  })
 }
})

Bước 3: Demo extension

Sau khi bạn viết xong tiện ích mở rộng của mình, bạn cần phải kiểm tra xem extension đã hoạt động đúng hay chưa bằng cách thêm extension vào Chrome. Đầu tiên, bạn phải bật chế độ developer mode trong Chrome: nhấp vào nút Options > More tools > Extensions, sau đó bật “Developer mode”.

Xem thêm:  Hướng dẫn dùng Sketch2Code để chuyển bản vẽ tay thành file HTML

Demo extension

Tiếp theo nhấp vào nút “Load unpacked”. Nếu bạn sửa code, Chrome sẽ tự động load lại extension cho bạn, một tính năng “hot reload” rất hữu dụng.

Load unpacked

Giờ đây, bạn có thể sử dụng tiện ích do mình tự viết ra để ghi lại các việc cần làm trên Chrome rồi đó.

Cách tạo Extension Chrome bằng Scratch

Đăng Extension lên Chrome Store

Mặc dù phát hành tiện ích mở rộng lên Chrome Web Store trực tuyến khá dễ, nhưng quá trình này lại hơi phức tạp. Nói tóm lại, bạn phải tạo tài khoản nhà phát triển, đóng gói tiện ích mở rộng của mình và sau đó gửi nó cùng với các thành phần khác của extension (như tên, biểu tượng, ảnh chụp màn hình,…); như được liệt kê trong bài viết này.

Kết luận

Như đã nói ở đầu bài viết, đây không phải là một bài viết chi tiết hướng dẫn bạn làm extension. Vậy nên, nếu bạn muốn đi theo hướng extension thì dưới đây là một số nguồn khá hay mà bạn có thể tham khảo:

  1. Tất cả các abilities, components, và tính năng của extensions.
  2. Các extension mẫu của nhóm phát triển Google Chrome.

Bạn cũng có thể phát triển thêm các tính năng của extension vừa làm như:

  1. Thêm tùy chọn xóa các việc cần làm.
  2. Tính năng thông báo các việc cần làm.

Vậy nên, nếu bạn nghiêm túc trên con đường này thì mình chúc bạn may mắn nhé.

Câu hỏi thường gặp

Tôi cần những kỹ năng gì để tạo Extension Chrome?

Bạn nên quen thuộc với HTML, CSS và JavaScript. Tuy nhiên, bài viết hướng dẫn sử dụng template giúp bạn dễ dàng bắt đầu ngay cả khi chưa có nhiều kinh nghiệm.

Tôi có thể sử dụng công cụ nào để tạo template Extension?

Extensionizr là một công cụ tạo template tốt, giúp bạn tạo nhanh chóng các template tuỳ chỉnh với nhiều lựa chọn khác nhau như browser action, page action, v.v.

Tôi cần trả phí để phát hành Extension của mình không?

Nếu bạn muốn phát hành extension lên Chrome Web Store, bạn cần một tài khoản nhà phát triển và Google sẽ yêu cầu một khoản phí nhỏ.

Tags: chromecodeExtensionScratchtiện ích mở rộng
Ellyx13

Ellyx13

DevOps với hơn 7 năm kinh nghiệm trong lĩnh vực hạ tầng, tự động hóa CI/CD và triển khai hệ thống phân tán trên các nền tảng như AWS, Azure và Kubernetes. - AWS Certified DevOps Engineer – Professional - Certified Kubernetes Administrator (CKA) - HashiCorp Certified: Terraform Associate - Docker Certified Associate (DCA) Có người không dám bước vì sợ gãy chân, nhưng sợ gãy chân mà không dám bước đi thì khác nào chân đã gãy.

Related Posts

Opal: Tạo ứng dụng AI không cần viết code 9
Code

Opal: Tạo ứng dụng AI không cần viết code

03/08/2025
xoa spam comment wordpress
Code

Cách xóa nhanh tất cả Bình luận rác trên WordPress

14/07/2025 - Updated on 25/07/2025
Code pháo hoa trang trí cho Website dịp tết 10
Code

Code pháo hoa trang trí cho Website dịp tết

25/01/2025 - Updated on 25/07/2025
Code Hiệu Ứng Pháo Hoa Theo Chuột - Trang Trí Website Tết 11
Code

Code Hiệu Ứng Pháo Hoa Theo Chuột – Trang Trí Website Tết

24/12/2024 - Updated on 24/07/2025
chuyen giao dien website sang trang den
Code

Code chuyển giao diện Website sang nền trắng đen để tưởng nhớ hoặc để Quốc tang

20/07/2024 - Updated on 24/07/2025
Hướng dẫn Active Wordfence Security Premium miễn phí 12
Code

Hướng dẫn Active Wordfence Security Premium miễn phí

07/06/2024 - Updated on 24/07/2025
guest

guest

This site uses Akismet to reduce spam. Learn how your comment data is processed.

0 Comments
oldest
newest
Inline Feedbacks
View all comments

Liên hệ Quảng Cáo

Lien he AnonyViet

Bài viết mới

Hướng dẫn sửa ảnh trên Google Photos bằng giọng nói 15

Hướng dẫn sửa ảnh trên Google Photos bằng giọng nói

by Thanh Kim
23/11/2025
0

Hướng dẫn gửi tín hiệu cầu cứu bằng Zalo khi mắc kẹt trong vùng lũ 16

Hướng dẫn gửi tín hiệu cầu cứu bằng Zalo khi mắc kẹt trong vùng lũ

by Thanh Kim
22/11/2025
0

Cách khắc phục SSD biến mất do bản cập nhật mới của Windows 11 17

Cách khắc phục SSD biến mất do bản cập nhật mới của Windows 11

by Thanh Kim
22/11/2025
0

Cách sử dụng Nano Banana Pro tạo poster, infographic bằng tiếng Việt 18

Cách sử dụng Nano Banana Pro tạo poster, infographic bằng tiếng Việt

by Thanh Kim
21/11/2025
0

Giới thiệu

AnonyViet

AnonyViet

Nơi chia sẻ những kiến thức mà bạn chưa từng được học trên ghế nhà trường!

Chúng tôi sẵn sàng đón những ý kiến đóng góp, cũng như bài viết của các bạn gửi đến AnonyViet.

Hãy cùng AnonyViet xây dựng một cộng đồng CNTT lớn mạnh nhất!

Giới thiệu

AnonyViet là Website chia sẻ miễn phí tất cả các kiến thức về công nghệ thông tin. AnonyViet cung cấp mọi giải pháp về mạng máy tính, phần mềm, đồ họa và MMO.

Liên hệ

Email: support[@]anonyviet.com

1409 Hill Street #01-01A
Old Hill Street Police Station
Singapore 179369

 

DMCA.com Protection Status

Bình luận gần đây

  • minh trong Share key Driver Booster v13 Pro miễn phí 6 tháng
  • Thành Mạnh trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • Tùng trong Share key Driver Booster v13 Pro miễn phí 6 tháng
  • thien trong Share key Driver Booster v13 Pro miễn phí 6 tháng
  • Leo trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • Bạn Kiên2014 đẹp trai trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • AnonyViet trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • 45555 trong Cách tạo ứng dụng sửa ảnh bằng Google AI Studio không cần code
  • tung trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • AnonyViet trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • Thư trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • AnonyViet trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • Minh trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • 45555 trong Cách tạo ứng dụng sửa ảnh bằng Google AI Studio không cần code
  • AnonyViet trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • Duy trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • John T. Samuel trong Hướng dẫn cách nhận 1 năm ChatGPT Go miễn phí
  • ggfgf trong Cách Auto kiếm điểm Microsoft Rewards để nhận quà
  • lam trong Share key Driver Booster v13 Pro miễn phí 6 tháng
  • Khánh trong Học Online cùng bạn bè trên khắp thế giới với Bindr

©2025 AnonyViet - Chúng tôi mang đến cho bạ những kiến thức bổ ích về CNTT Công nghệ kết quả xổ số hôm nay xoilac 8xbet https://fun88.social 33win Ae888 kubet kubet 8kbet 99ok xin88 good88 xn88 kubet cakhiatv f8bet https://qq883a.com/ XX88 mu88 casino fm88 xin88 https://918xxy.com/ kubet thailand vip66 xoso66 https://tp88fun.com/ hello88 qq88 GK88 PG88 Xoso66 Vip66 hitclub bong99 XOSO66 new882.info Hi88 8day Thabet 33win Bk8 fun88 789win w88 nhà cái uy tín Go88 sunwin sunwin jun88 rikvip hitclub sunwin go88 s666 sv388 12bet v9bet betvisa betvisa vin777 vin777 ee88 bet88 abc8 c54 i9bet ok365 ae888 https://keonhacai.fund/ sunwin https://ok9393.com/ cakhiatv socolive QQ88 TP88 Xoso66 zx88 79king 88vv https://mm88.today/ mu88 com 8kbet https://qq88pro.vip/ fun88.supply king88 sv388 v9bet s666 https://max88rl.com/ https://ok365rl.com/ EE88 FB88 TYPHU88 https://da88.design/ Kkwin 79king xin88 XX88 https://mb66co.com/ https://fun88.supply/ thapcamtv thapcamtv https://rr88.navy/ gem88 F8BET80 sa88 https://q23win.com/ 32win 789WIN https://lc88.jpn.com/ 68win BET88 luongsontv luongsontv https://nohutm.com SODO fun88 sunwin u888 https://nohumo.com 8xbet W88 link cola tv colatv trực tiếp bóng dá colatv trực tiếp bóng dá colatv colatv truc tiep bong da colatv colatv bóng dá trực tiếp 58win https://s68win.com/ 58WIN NOHU90 https://hm8805.com/ GK88 188bet ax88 8KBET 69VN 33WIN 32win Kuwin https://bbet88b.com/ OK9 SHBET https://xx88.center/ vswin 789PCOM NHÀ CÁI MMOO bắn cá TT88COM GO 99 https://k8cc.wiki/ RR88 RR88 ee88 kèo nhà cái 5 789f 188bet w88 Gem88 Thabet jun88 kclub vip79 dv88 Gi8 For88 Rikbet 8kbet 6ff Kkwin HZ88 tv88 ABC8 https://ww88.me/ https://nowgoal.ws/ https://tylekeonhacai.me/ https://keonhacai.org.vc/ https://xx88.ac/ xx88.me.uk gem88 king88 ae888 bj88 good88 https://xx88.today/ PG88 XX88 NH88 XN88 NH88 ST666 xn88 https://pg666.baby/ 88xx 98win 69VN 888NEW TV88 XN88 NN88 MV88 MV66 XN88 NOHU90 TV88 68WIN GO99 AF88 HM88 HZ88 https://xx88.asia/ 789f NOHU HITCLUB Sunwin 58WIN MV88 tv88 888NEW AZ888 https://rr88.pizza/ GO8 789win PG99 nn88 https://1mm88.info/ https://u888wl.com/ mv66 789F Rik88 x88 x88 HZ88 x88 nohu90 SHBET cakhia TD88 SODO66 SODO CASINO https://kjcgaming.com/ bet88 8kbet SODO66 x88 https://uu-88.net/ KUBET11 fb68 88vv 23win RS88 RR99 ok9 OK9 VankhanhTV 12bet v9bet betvisa betvisa vin777 vin777 ee88 bet88 abc8 c54 888New QQ88 tải X8 nhà cái HD88 Casino ww88 HD88 cobet X88 chemchep COBET zx88 kingfun https://lc88.bio/ OK9 789Win 79king https://pg999.baby/ SODO66 zx88 MM88 NOHU90 SH BET 789win Mv66 KUBET88 EE88 Thapcam TV Vebo TV pagcor W88 PG88 xx88.promo hm88 Kubet Sodo66 8KBET https://f8bet.luxury/ SODO CASINO https://mm88pi.com 888new VIP66 188v vn23 11uu bec88 KUWIN https://pg99.icu/ ev88 LC88.COM KJC https://uu88.company/ mv66 https://c168.info/ 555WIN 789F sh bet k8cc KJC Thabet Casino HM88 f8bet https://hubetad.com/ 7m 566 HZ88 https://22vip.news/ 11UU abc8 13win 13win hz88 RR99 KJC https://xx88.space/ 888B win678 88i tài xỉu online uy tín Game bài đổi thưởng uy tín sunwin 566 566 HZ88 HZ88 89bet XN88 NH88 999slot 68win win678 AF88 GO99 8kbet 8kbet x88 mk8th.net vip66 xoso66 78winbiz.com mn88 f168biz.com mk8.ac F168 bet88 https://rr88.africa/ 888slot 888slot XOSO66 mb66-t.com UU88 WIN678 AX88 MM88 789F 7mcn Nhà cái MB66 VB88 LC88 GO99 HUBET 28bet hm88 NH88 sodo casino Sunwin Nổ hũ au88 F168 f168 keo nha cai https://88go.center/ Exness ログイン 789 club https://7m.net.vc/ nhà cái 789bet SODO Casino Go8 https://79kingg.me/ s8 kkwin F168 BL555 xoso66 ae888 ax88 28BET 58Win 789F 99ok LC88 98WIN TD88 Mig8 C54 Vin777 SV388 DA88 9BET kjc F168 LC88 9win 789F 789F FR8896 wm9378 Exness login 33win trang chủ QQ88 HM88 SONCLUB S8 https://daga.rocks https://x88.ru.com/ xoso66 sv368pro nhà cái bj88 s8.com SODO colatv truc tiep bong da gavangtv gavangtv trực tiếp bóng rổ đánh đề online 789F S8 8kbet https://23wincasino.com/ https://nohu90.surf/ Bj66 XX88 3king win55 http://cm88.uk.net/ f168 Wvip 88CLB

No Result
View All Result
  • ANONYVIET CẦN CÁC BẠN GIÚP SỨC
  • Chính sách
  • Mini Game AnonyViet và FShare Mừng xuân 2021
  • Privacy
  • Quảng cáo
  • Search
  • Search Results
  • Share Acc Nhaccuatui VIP 2020
  • Thành Viên VIP
    • Danh Sách Đặc Quyền Thành Viên VIP
  • Tiếp tục đi đến trang mới là tính năng gì
  • Trang chủ
  • Đang lấy thông tin dữ liệu
  • Đang đến địa chỉ đích
  • Đổi số thành chữ, đổi tiền ra chữ Online

©2025 AnonyViet - Chúng tôi mang đến cho bạ những kiến thức bổ ích về CNTT Công nghệ kết quả xổ số hôm nay xoilac 8xbet https://fun88.social 33win Ae888 kubet kubet 8kbet 99ok xin88 good88 xn88 kubet cakhiatv f8bet https://qq883a.com/ XX88 mu88 casino fm88 xin88 https://918xxy.com/ kubet thailand vip66 xoso66 https://tp88fun.com/ hello88 qq88 GK88 PG88 Xoso66 Vip66 hitclub bong99 XOSO66 new882.info Hi88 8day Thabet 33win Bk8 fun88 789win w88 nhà cái uy tín Go88 sunwin sunwin jun88 rikvip hitclub sunwin go88 s666 sv388 12bet v9bet betvisa betvisa vin777 vin777 ee88 bet88 abc8 c54 i9bet ok365 ae888 https://keonhacai.fund/ sunwin https://ok9393.com/ cakhiatv socolive QQ88 TP88 Xoso66 zx88 79king 88vv https://mm88.today/ mu88 com 8kbet https://qq88pro.vip/ fun88.supply king88 sv388 v9bet s666 https://max88rl.com/ https://ok365rl.com/ EE88 FB88 TYPHU88 https://da88.design/ Kkwin 79king xin88 XX88 https://mb66co.com/ https://fun88.supply/ thapcamtv thapcamtv https://rr88.navy/ gem88 F8BET80 sa88 https://q23win.com/ 32win 789WIN https://lc88.jpn.com/ 68win BET88 luongsontv luongsontv https://nohutm.com SODO fun88 sunwin u888 https://nohumo.com 8xbet W88 link cola tv colatv trực tiếp bóng dá colatv trực tiếp bóng dá colatv colatv truc tiep bong da colatv colatv bóng dá trực tiếp 58win https://s68win.com/ 58WIN NOHU90 https://hm8805.com/ GK88 188bet ax88 8KBET 69VN 33WIN 32win Kuwin https://bbet88b.com/ OK9 SHBET https://xx88.center/ vswin 789PCOM NHÀ CÁI MMOO bắn cá TT88COM GO 99 https://k8cc.wiki/ RR88 RR88 ee88 kèo nhà cái 5 789f 188bet w88 Gem88 Thabet jun88 kclub vip79 dv88 Gi8 For88 Rikbet 8kbet 6ff Kkwin HZ88 tv88 ABC8 https://ww88.me/ https://nowgoal.ws/ https://tylekeonhacai.me/ https://keonhacai.org.vc/ https://xx88.ac/ xx88.me.uk gem88 king88 ae888 bj88 good88 https://xx88.today/ PG88 XX88 NH88 XN88 NH88 ST666 xn88 https://pg666.baby/ 88xx 98win 69VN 888NEW TV88 XN88 NN88 MV88 MV66 XN88 NOHU90 TV88 68WIN GO99 AF88 HM88 HZ88 https://xx88.asia/ 789f NOHU HITCLUB Sunwin 58WIN MV88 tv88 888NEW AZ888 https://rr88.pizza/ GO8 789win PG99 nn88 https://1mm88.info/ https://u888wl.com/ mv66 789F Rik88 x88 x88 HZ88 x88 nohu90 SHBET cakhia TD88 SODO66 SODO CASINO https://kjcgaming.com/ bet88 8kbet SODO66 x88 https://uu-88.net/ KUBET11 fb68 88vv 23win RS88 RR99 ok9 OK9 VankhanhTV 12bet v9bet betvisa betvisa vin777 vin777 ee88 bet88 abc8 c54 888New QQ88 tải X8 nhà cái HD88 Casino ww88 HD88 cobet X88 chemchep COBET zx88 kingfun https://lc88.bio/ OK9 789Win 79king https://pg999.baby/ SODO66 zx88 MM88 NOHU90 SH BET 789win Mv66 KUBET88 EE88 Thapcam TV Vebo TV pagcor W88 PG88 xx88.promo hm88 Kubet Sodo66 8KBET https://f8bet.luxury/ SODO CASINO https://mm88pi.com 888new VIP66 188v vn23 11uu bec88 KUWIN https://pg99.icu/ ev88 LC88.COM KJC https://uu88.company/ mv66 https://c168.info/ 555WIN 789F sh bet k8cc KJC Thabet Casino HM88 f8bet https://hubetad.com/ 7m 566 HZ88 https://22vip.news/ 11UU abc8 13win 13win hz88 RR99 KJC https://xx88.space/ 888B win678 88i tài xỉu online uy tín Game bài đổi thưởng uy tín sunwin 566 566 HZ88 HZ88 89bet XN88 NH88 999slot 68win win678 AF88 GO99 8kbet 8kbet x88 mk8th.net vip66 xoso66 78winbiz.com mn88 f168biz.com mk8.ac F168 bet88 https://rr88.africa/ 888slot 888slot XOSO66 mb66-t.com UU88 WIN678 AX88 MM88 789F 7mcn Nhà cái MB66 VB88 LC88 GO99 HUBET 28bet hm88 NH88 sodo casino Sunwin Nổ hũ au88 F168 f168 keo nha cai https://88go.center/ Exness ログイン 789 club https://7m.net.vc/ nhà cái 789bet SODO Casino Go8 https://79kingg.me/ s8 kkwin F168 BL555 xoso66 ae888 ax88 28BET 58Win 789F 99ok LC88 98WIN TD88 Mig8 C54 Vin777 SV388 DA88 9BET kjc F168 LC88 9win 789F 789F FR8896 wm9378 Exness login 33win trang chủ QQ88 HM88 SONCLUB S8 https://daga.rocks https://x88.ru.com/ xoso66 sv368pro nhà cái bj88 s8.com SODO colatv truc tiep bong da gavangtv gavangtv trực tiếp bóng rổ đánh đề online 789F S8 8kbet https://23wincasino.com/ https://nohu90.surf/ Bj66 XX88 3king win55 http://cm88.uk.net/ f168 Wvip 88CLB

wpDiscuz