[Userscript] Giới thiệu User script và cách sử dụng

  Bài viết hay nhất1

Userscript là gì?


Userscript (hoặc User script) là các script dùng trong trình duyệt, hướng tới việc đọc thông tin của trang web hoặc thay đổi chúng.

[Userscript] Giới thiệu User script và cách sử dụng Unlock10
Anti Social Locker

Về cơ bản, Userscript là JavaScript, được bổ sung một số API mạnh mẽ mà thông thường không được phép.
Userscript thường không được phép cài trực tiếp vào trình duyệt, mà phải chạy thông qua một tiện ích (extension) quản lý, nếu không trình duyệt sẽ xem nó như một tệp JavaScript thông thường. Các trình duyệt nhân Chromium cho phép nó chạy như một tiện ích, tuy nhiên có nhiều hạn chế.
Tùy thuộc vào tiện ích quản lý mà Userscript có đuôi mở rộng khác nhau như .tamper.js, .grease.js, .ieuser.js, ... Tuy nhiên, phổ biến nhất vẫn là .user.js, hầu hết các tiện ích quản lý đều hỗ trợ đuôi này.
Từ Userscript, bạn có thể nâng cấp nó thành tiện ích trình duyệt với các API dành cho Content script.

[Userscript] Giới thiệu User script và cách sử dụng Youtub10
Download YouTube Videos as MP4

Mặc dù những gì Userscript làm được thì các Extension cũng làm được và còn hơn nữa, nhưng Userscript vẫn tồn tại. Đó là vì, muốn tạo ra Extension cho trình duyệt thì còn phải theo sự kiểm soát của chủ quản trình duyệt đó, còn Userscript là anh chàng Libero linh hoạt hơn nhiều. Như trong ảnh minh họa trên, Extension download video từ Youtube bị cấm trên Google Chrome, nhưng với Userscript bạn vẫn sẽ có được chức năng đó.

Cách sử dụng


Cài tiện ích quản lý


Tùy vào trình duyệt bạn sử dụng mà tải tiện ích quản lý Userscript phù hợp.

  • Firefox: Greasemonkey hoặc Tampermonkey
  • Chrome: Tampermonkey hoặc Violentmonkey
  • Opera: Tampermonkey hoặc Violentmonkey
  • Safari: Tampermonkey
  • Microsoft Edge: Tampermonkey
  • Maxthon: Violentmonkey
  • Dolphin: Tampermonkey
  • UC: Tampermonkey
  • Qupzilla: Greasemonkey (Có sẵn, bật trong Edit > Preferences > Extensions)

Với các trình duyệt mà mình gợi ý hai tiện ích nổi bật, bạn nên dùng tiện ích đầu. Có thể còn tiện ích khác nhưng chậm cập nhật hoặc không hoạt động nên mình không đưa vào.
Bạn có thể thấy được sự phổ biến của tiện ích Tampermonkey, tuy nhiên nếu bạn có ý định viết Userscript một lần rồi chạy ở tất cả trình duyệt sẽ rất nhanh thất vọng. Vì tùy vào trình duyệt và phiên bản, mức độ hỗ trợ API của tiện ích này cũng không giống nhau.

Cài Userscript


Sau khi cài tiện ích quản lý, bạn có thể vào trang chia sẻ như OpenUserjs, GreasyFork để tìm một Userscript phù hợp và nhấn Cài đặt (Install).
Đây là hai cộng đồng sử dụng và phát triển Userscript lớn nhất hiện nay. OpenUserJs có giao diện đẹp và quản lý dễ dãi hơn, còn GreasyFork có cộng đồng đông đảo và chức năng quản lý tốt hơn.

Ngoài ra, bạn cũng có thể cài đặt Userscript từ nguồn không chính thống khác như Github Gist.
Hoặc dùng chức năng tạo Userscript mới (New Userscript...) trên tiện ích quản lý, và sử dụng mã nguồn được chia sẻ.

Cảnh báo


Trang Userscripts mirror là một bản sao của Userscripts.org, đã bị đóng cửa bởi chủ quản, với lý do chứa nhiều mã độc, không thể kiểm soát.
Các Userscript trong này đã không còn được cập nhật. Nếu bạn là nhà phát triển, có thể ghé qua lấy ý tưởng, tham khảo. Còn nếu bạn là người dùng thông thường, thì không nên sử dụng trang này.

Userscript có thể chèn mã độc, đánh cắp thông tin, gây tổn hại đến người dùng. Vì thế, không nên sử dụng từ nguồn không đáng tin cậy, tránh dùng các Userscript bị nén, bị mã hóa.

Cách viết Userscript


Userscript luôn chứa một Metadata Block, được đặt ở phần đầu mã nguồn. Đây là nơi khai báo các thông tin như tên, phiên bản, giới hạn sử dụng...

Định dạng chuẩn của một Metadata Block.
Code:
// ==UserScript==
// @key1  value1
// @key2  value2
// @keyN  valueN
// ==/UserScript==

Việc hỗ trợ khóa (key) Metadata cũng khác nhau tùy tiện ích quản lý, nên mình chỉ giới thiệu các khóa phổ biến, dựa trên Greasemonkey, và một số khóa quan trọng trong các tiện ích quản lý thông dụng.

Các khóa Metadata


@name


Tên của Userscript, bạn nên sử dụng tiếng Anh hoặc viết không dấu, và không ký tự đặc biệt, vì nó cũng được dùng làm tên tệp. Ví dụ:
Code:
// @name  anti social locker

@namespace


Tên bổ sung, nó được kết hợp với @name để tạo thành cặp khóa định danh cho Userscript đó, nếu bạn tạo ra một Userscript mới mà cặp khóa này trùng nhau, tiện ích quản lý sẽ xem nó như một bản cập nhật và thay thế nó. Vì @namespace không có nghĩa nên tác giả thường dùng để đăng URL website, một số tiện ích quản lý cũng dùng khóa này để xác định Trang chủ của Userscript. Ví dụ:
Code:
// @namespace  http://baivong.github.io/

@description


Giới thiệu thông tin sơ lược. Ví dụ:
Code:
// @description  Anti social locker plugin required user like or share before viewing content. If script doesn't work, please refresh the page to rebuild the cache and try again.

@version


Phiên bản hiện tại. Giá trị này được tiện ích quản lý sử dụng để cập nhật Userscript. Xem thêm quy chuẩn Semantic Versioning để hiểu cách viết phiên bản. Ví dụ:
Code:
// @version  1.0.0

@icon


URL icon, ảnh đại diện cho Userscript. Ví dụ:
Code:
// @icon  http://i.imgur.com/nOuUrIW.png

@author


Tên tác giả. Ví dụ:
Code:
// @author  Zzbaivong

@license


Tên hoặc URL đến giấy phép sử dụng Userscript. Truy cập Choose a License để biết thêm thông tin và cách lựa chọn. Ví dụ:
Code:
// @license  MIT

@include


Giới hạn địa chỉ trang web mà Userscript sẽ chạy, có thể dùng biểu thức chính quy (Regular Expressions). Khóa này có thể dùng nhiều lần. Ví dụ:
Code:
// @include  /^https?://*/*.js$/
// @include  /^https?://*/*.css$/

@match


Chức năng tương tự @include nhưng được đặt quy tắc nghiêm ngặt hơn trong cách sử dụng dấu *, không được dùng biểu thức chính quy. Xem chi tiết về Match Patterns. Ví dụ:
Code:
// @match  http://*/*.js
// @match  https://*/*.js
// @match  http://*/*.css
// @match  https://*/*.css

@exclude


Cách dùng tương tự @include nhưng có vai trò ngược lại, nó loại trừ địa chỉ trang web mà Userscript sẽ chạy. Ví dụ:
Code:
// @exclude  /^https?://*/*.json$/
// @exclude  /^https?://*/*.less$/

@downloadURL


URL để cập nhật Userscript. Nếu không dùng khóa này, tiện ích quản lý sẽ dùng URL lúc bạn tải về để làm URL cập nhật. Ví dụ:
Code:
// @downloadURL  https://openuserjs.org/install/baivong/anti_social_locker.user.js

@updateURL


URL để kiểm tra thông tin phiên bản, có đuôi .meta.js, thông thường chỉ chứa Metadata Block (tối thiểu phải có 3 khóa @version, @name,
Code:
@namespace
). Nếu thông tin @version trong này mới hơn thì tiện ích quản lý sẽ tiến hành cập nhật Userscript. Nếu không dùng khóa này, tiện ích quản lý sẽ dùng URL lúc bạn tải về, hoặc khóa @downloadURL để làm kiểm tra thông tin phiên bản. Ví dụ:
Code:
// @updateURL  https://openuserjs.org/install/baivong/anti_social_locker.meta.js

@supportURL


URL dẫn đến trang hỗ trợ, báo lỗi. Ví dụ:
Code:
// @supportURL  https://github.com/baivong/Userscript/issues

@require


URL của thư viện JavaScript cần sử dụng. Khóa này có thể dùng nhiều lần. Ví dụ:
Code:
// @require  https://code.jquery.com/jquery-2.2.4.min.js
// @require  https://greasyfork.org/scripts/19855-jszip/code/jszip.js
// @require  https://greasyfork.org/scripts/18532-filesaver/code/FileSaver.js

@resource


Bổ sung thêm tài nguyên để sử dụng, chúng sẽ được tải về máy người dùng nên sẽ nhanh và ổn định hơn dùng URL trực tuyến. Bạn có thể truy cập thông qua API GM_getResourceText hoặc GM_getResourceURL. Khóa này có thể dùng nhiều lần. Ví dụ:
Code:
// @resource  devsLogo https://baivong.github.io/css/images/logo-header.png
// @resource  lightTheme https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.11.0/styles/github-gist.min.css
// @resource  darkTheme https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.11.0/styles/monokai-sublime.min.css

@run-at


Thời điểm chạy Userscript so với trang web. Bao gồm 3 giá trị document-start, document-end document-idle. Ví dụ:
Code:
// @run-at document-idle

@noframes


Ngăn không cho Userscript chạy trong thẻ nhúng như iframe. Nó không có đối số, chỉ là dùng hoặc không dùng. Nên sử dụng khóa này để tránh lỗi hiệu suất, nhất là với các trang có quảng cáo nhúng. Ví dụ:
Code:
// @noframes

@grant


Yêu cầu cấp quyền sử dụng API đặc biệt với tiện ích quản lý, không có nó, tiện ích quản lý có thể đưa ra thông tin sai, gây lỗi. Các quyền này có thể khiến Userscript của bạn bị cách ly (sandbox) với các script trong trang. Nếu bạn không yêu cầu quyền API đặc biệt hãy đặt giá trị none. Khóa này có thể dùng nhiều lần. Ví dụ:
Code:
// @grant GM_addStyle
// @grant GM_getResourceText

@connect


Đây là khóa bổ sung khi yêu cầu API GM_xmlhttpRequest, nó xác định tên miền chứa dữ liệu cần lấy. Bao gồm các giá trị: domain (cũng sẽ bao gồm toàn bộ sub-domain), sub-domain, IP address, localhost, self (trang mà Userscript đang chạy), * (tất cả). Khóa này có thể dùng nhiều lần. Ví dụ:
Code:
// @connect baivong.github.io
// @connect self

Chú ý


Một Metadata Block tối thiểu phải có 3 khóa @name, @namespace, @grant (có tiện ích quản lý yêu cầu thêm @match, @id).
Tài nguyên từ @require@resource chỉ được tải về một lần vào máy người dùng, đến khi có bản cập nhật thì nó mới tải lại.

Sau khi tạo Metadata Block, bạn đã có thể bắt đầu viết code cho nó bằng JavaScript ở bên dưới, sử dụng thêm API nếu cần thiết. Tuy nhiên, mức độ hỗ trợ API của mỗi tiện ích quản lý đều có vài điểm khác biệt, trong bài này mình chỉ hướng dẫn cách tạo Userscript cơ bản với Javascript. Nếu bạn muốn viết nâng cao hơn thì nên tìm xem các tài liệu API của tiện ích quản lý mà bạn sử dụng. Ví dụ:
Code:
// ==UserScript==
// @name reverse
// @namespace Zzbaivong
// @grant none
// ==/UserScript==

document.body.style.transform = "rotate(180deg)";

Bạn có thể cài trực tiếp Userscript vào trình duyệt nhân Chromium, tuy nhiên nó chỉ cho phép các khóa @name, @namespace, @description, @version, @match, @include, @exclude và một số API (không bắt buộc dùng @grant) GM_log, GM_openInTab, GM_addStyle, GM_xmlhttpRequest (chỉ trong cùng nguồn, tương đương @connect self). Ví dụ:
Code:
// ==UserScript==
// @match http://github.com/*
// ==/UserScript==

GM_openInTab("https://github.com/baivong/Userscript");

Tags: #userscript #extension #tutorial #browser
  Bài viết hay nhất2
Sau khi đọc bài hướng dẫn của anh thì cũng hiểu sơ sơ, nhưng mà phải đặt cái userscripts ở đâu zậy anh, anh có thể chỉ cụ thể = hình ãnh dc ko, đọc chữ em hơi cảm thấy mơ hồ anh ạ *gãi đầu*
  Bài viết hay nhất3
Đặt trong trình duyệt, khi nào em viết script thì mới cần đọc bài này.
  Bài viết hay nhất4
Trong temp vs Java vs HTML phải không, còn chỗ nào nữa ko
  Bài viết hay nhất5

Mr.Bean wrote:Trong temp vs Java vs HTML phải không, còn chỗ nào nữa ko
Không hiểu bạn nói gì?
  Bài viết hay nhất6
userscript và extension khác nhau thế nào hả anh? hay chỉ là userscript thì dùng được cho mọi trình duyệt còn extension thì phải viết riêng?!
mà viết bằng jquery được ko ạ? có cần thêm thư viện jquery vào trước ko ạ?
  Bài viết hay nhất7

miamor wrote:Userscript và extension khác nhau thế nào hả anh? hay chỉ là userscript thì dùng được cho mọi trình duyệt còn extension thì phải viết riêng?!
mà viết bằng jquery được ko ạ? có cần thêm thư viện jquery vào trước ko ạ?

Userscript hay Extension đều viết bằng jQuery được, chỉ cần thêm cái thư viện jQuery vào xong, nếu trang có sẵn jQuery và code không chạy Sandbox thì khỏi cần thêm cũng được.

Về điểm khác nhau thì anh chỉ nói 3 trình duyệt Chrome, Firefox, Opera thôi nhé, mấy cái khác chưa động vào.

UserscriptExtension
Khai báoGiống nhau: Không có nhiều khác biệt về metadata chính.Khác nhau: Firefox dùng package.json, Chrome và Opera dùng manifest.json.
Định dạngTuy có mỗi trình quản lý đều có định dạng riêng, nhưng đều cho phép dùng *.user.jsFirefox: *.xpi, Chrome: *.cxr, Opera: *.nex, *.cxr
Truy cập APICác API web content, chịu ảnh hưởng của trình duyệt khi truy cập API cấp cao như blob, URL, ...Ngoài các API web content còn có thể truy cập các API trình duyệt như tab, context-menu, widget, ... (Firefox thì các API cấp cao không có sẵn trong SDK).
Kiểm duyệtHầu như không cần kiểm duyệt, chỉ một vài cộng đồng Userscript lớn như Greasy Fork mới có quy định chặt chẽ về nội dung và tài nguyên.Chrome: Xét duyệt tốn 5$ (chỉ tốn lần đầu). Opera: Thời gian xét duyệt 5 ngày, đạt yêu cầu mới được đăng. Firefox: Cho xuất bản ngay, nhưng thời gian duyệt chính thức là 10 ngày.
  Bài viết hay nhất8
Cập nhật: Bổ sung các khóa Metadata

  1. @id: Khóa bắt buộc trong Scriptish.
  2. @author: Được nhiều tiện ích quản lý sử dụng.
  3. @connect: Quan trọng, khi yêu cầu @grant GM_xmlhttpRequest trên Tampermonkey.
  4. @supportURL: Được hỗ trợ bởi Tampermonkey, Scriptish và trang chia sẻ như OpenUserjs, GreasyFork.

Ghi chú thêm về cách cài trực tiếp Userscript vào trình duyệt nhân Chromium.
  Bài viết hay nhất9
Cập nhật

  1. Bỏ khóa @id do Scriptish đã ngừng cập nhật.
  2. Thay thế các ví dụ rõ ràng hơn.
  3. Cập nhật danh sách tiện ích quản lý.
  4. Sửa một số lỗi trình bày.
  Bài viết hay nhất10
You cannot reply to topics in this forum