• Trang chủ
  • WordPress
    • Thủ thuật WordPress
    • WordPress Plugins
    • WordPress Themes
  • Hosting và Domain
  • Kiếm tiền online
  • Đánh giá
  • Khuyến mãi
  • Thông báo
wpcb-logo

WP Căn bản

Kiến thức căn bản cho người dùng WordPress

paradise-child-theme-wordpress-theme-tot-nhat
  • Dịch vụ WordPress Hosting
  • Dịch vụ tối ưu WordPress
  • Dịch vụ quét mã độc WordPress
  • Mua Paradise child theme
Trang chủ » WordPress » Thủ thuật WordPress » Làm thế nào để tạo Shortcodes trong WordPress?
hosting-tot-nhat-danh-cho-wordpress

Làm thế nào để tạo Shortcodes trong WordPress?

Cập nhật: 19/06/2022 Trung Hiếu 7 Bình luận

Làm thế nào để tạo Shortcodes trong WordPress?

shortcodes-thumb

WordPress đã giới thiệu các shortcode API cách đây 6 năm với việc phát hành của WordPress 2.5. Hiện tại, Shortcodes được sử dụng bởi một số lượng lớn WordPress plugins, cho phép người dùng chèn thêm nội dung vào các bài viết và trang của họ.

Shortcode API cho phép bạn tạo shortcodes của riêng mình bằng cách thêm chức năng vào file functions.php của theme bạn đang dùng (file này nằm trong đường dẫn: www.yourwebsite.com/wp-content/themes/yourtheme/).

Ngoài việc tạo ra shortcodes của riêng bạn, WordPress cũng bao gồm 5 shortcodes mặc định, được tích hợp vào WordPress Core:

  • audio – Cho phép bạn nhúng các file âm thanh.
  • caption – Cho phép bạn thêm nội dung chú thích. Nó thường được sử dụng với hình ảnh.
  • embed – Cho phép bạn nhúng một loạt các nội dung như video, âm thanh và tweet.
  • gallery – Cho phép bạn chèn các gallery hình ảnh.
  • video – Cho phép bạn nhúng các file video.

Mặc dù WordPress shortcodes mặc định được sử dụng rất nhiều, nhưng ít người dùng WordPress biết tận dụng lợi thế của các shortcode API để thiết kế những shortcode “độc nhất vô nhị” cho trang web của họ. Trong bài viết này, tôi sẽ chỉ cho các bạn cách tăng cường sức mạnh của trang web với các shortcode tùy chỉnh.

Hãy chắc chắn rằng bạn đã tạo một bản backup của file functions.php và tất cả tập tin có liên quan khác, trước khi tiến hành chỉnh sửa.

Tạo một shortcode – Ví dụ cơ bản

Để cung cấp cho bạn những hiểu biết tốt nhất về cách WordPress shortcode API hoạt động, chúng ta hãy bắt đầu với một chức năng shortcode cơ bản.

shortcodes-2

Hãy nhớ rằng, shortcodes phải được tạo ra cho các nội dung và chức năng mà bạn sử dụng thường xuyên. Ưu điểm của việc sử dụng shortcodes là tiết kiệm thời gian. Nếu bạn chỉ sử dụng cái gì đó một lần, bạn không cần tạo ra một shortcode cho riêng nó.

Tôi viết khoảng một chục bài viết mỗi tuần. Giả sử, điều tôi thường xuyên làm là khuyến khích khách truy cập subscribe blog của tôi. Việc này lặp đi lặp lại khiến tôi mất khá nhiều thời gian, tuy nhiên, tôi có thể tiết kiệm thời gian cho bản thân bằng cách tạo ra một shortcode dành cho văn bản.

Để làm điều này, tôi có thể thêm một chức năng như sau vào file functions.php của theme tôi đang sử dụng:

// Function to add subscribe text to posts and pages
function subscribe_link_shortcode() {
return 'Nếu bạn thích bài viết này, tôi khuyên bạn nên <a href="http://feeds.feedburner.com/wpcanban" title="Subscribe blog của tôi">subscribe WP Căn bản thông qua RSS</a>.';
}
add_shortcode('subscribe', 'subscribe_link_shortcode');

Những người không có kinh nghiệm về coding có thể sẽ thấy đoạn code trên khá là rắc rối, tuy nhiên nó rất dễ hiểu khi bạn phân tích code theo từng dòng.

Điều đầu tiên tôi làm là thêm một phần chú thích vào bên trên chức năng (function). Điều này sẽ giúp tôi nhanh chóng biết function này có tác dụng gì.

// Function to add subscribe text to posts and pages

Sau đó, tôi xác định chức năng của shortcode. Tôi thích sử dụng những cái tên có khả năng tự giải thích, vì vậy tôi đã gọi function là “subscribe_link_shortcode“.

function subscribe_link_shortcode() {

Tiếp theo, tôi sẽ định nghĩa thông điệp mà tôi muốn đề cập. Câu lệnh return sẽ hiển thị thông báo của tôi khi nó được gọi. Nó cũng lưu các tin nhắn (như trái ngược với echo, chỉ hiển thị mà không lưu nó).

return 'Nếu bạn thích bài viết này, tôi khuyên bạn nên <a href="http://feeds.feedburner.com/wpcanban" title="Subscribe blog của tôi">subscribe WP Căn bản thông qua RSS</a>.';

Function sau đó sẽ được đóng lại.

}

Sau đó, tôi xác định shortcode bằng cách sử dụng chức năng add_shortcode. Biến đầu tiên giúp xác định shortcode được sử dụng và biến thứ hai dùng để gọi chức năng của chúng tôi.

add_shortcode('subscribe', 'subscribe_link_shortcode');

Sau khi lưu file functions.php, chúng ta có thể gọi nó bất cứ khi nào muốn sử dụng shortcode subscribe bằng cú pháp:

[subscribe]

Sử dụng subscription shortcode trong bài viết hoặc trang, bạn sẽ nhận được thông báo có dạng như sau:

Nếu bạn thích bài viết này, tôi khuyên bạn nên subscribe WP Căn bản thông qua RSS.

Tôi đã sử dụng một thông điệp đơn giản trong ví dụ của tôi, tuy nhiên bạn có thể sửa đổi nó để hiển thị nhiều thứ khác. Ví dụ, bạn có thể tạo ra một shortcode để hiển thị quảng cáo Adsense hoặc một subscription form cho bản tin từ blog của bạn và sau đó chèn chúng vào bất cứ nơi nào bạn muốn hiển thị trong bài viết.

Tạo một shortcode với các thuộc tính

Thuộc tính (attributes) có thể mở rộng chức năng của shortcodes bằng cách cho phép bạn truyền dữ liệu thông qua shortcodes.

shortcodes-1

Trong ví dụ dưới đây, tôi sẽ chỉ cho các bạn cách sử dụng các thuộc tính để mở rộng chức năng mà chúng ta đã tạo ra trước đó. Như bạn thấy, có rất nhiều code vẫn được giữ nguyên.

// Extended subscription function with subscription type variable
function subscribe_multilink_shortcode( $atts ) {
extract( shortcode_atts( array(
'subtype' => 'RSS',
'subtypeurl' => 'http://feeds.feedburner.com/wpcanban',
), $atts, 'multilink' ) );</p>
<p>return sprtinf( 'Hãy đăng ký theo dõi WP Căn bản để cập nhật các bài viết mới trong tương lai <a href='%1$s'>thông qua %2$s</a>.',
esc_url( $subtypeurl ),
esc_html( $subtype )
);
}
add_shortcode( 'subscribe', 'subscribe_multilink_shortcode' );

$atts là tên của mảng thuộc tính của tôi. Sau đó, tôi sử dụng extract function để import (nhập) biến từ mảng của tôi (thông qua shortcode_atts WordPress function).

Hai thuộc tính này được xác định là: subtype và ubtypeurl. Chúng đại diện cho các loại subscription và subscription URL. Những thuộc tính này sau đó được gọi trong tin nhắn của tôi.

Loại subscription mặc định của tôi là RSS và URL đăng ký mặc định của tôi là http://feeds.feedburner.com/wpcanban.

Thông tin này sẽ được hiển thị khi không có thuộc tính nào được định nghĩa. Vì vậy, khi bạn thêm shortcode sau vào một bài viết:

[subscribe]

Chúng ta sẽ thấy thông báo như sau:

Hãy đăng ký theo dõi WP Căn bản để cập nhật các bài viết mới trong tương lai thông qua RSS.

Nếu chúng ta định nghĩa thuộc tính, kết quả cho ra sẽ khác nhau. Ví dụ sử dụng đoạn code sau đây:

[subscribe]
[subscribe subtype=&amp;quot;Twitter&amp;quot; subtypeurl=&amp;quot;http://www.twitter.com/ItachiUchihaSu/&amp;quot;]
[subscribe subtype=&amp;quot;Facebook&amp;quot; subtypeurl=&amp;quot;http://www.facebook.com/wpcanban/&amp;quot;]
[subscribe subtype=&amp;quot;Google&amp;quot; subtypeurl=&amp;quot;http://plus.google.com/+TrungHiếuBùi93/&amp;quot;]

Bạn sẽ nhận được kết quả:

Hãy đăng ký theo dõi WP Căn bản để cập nhật các bài viết mới trong tương lai thông qua RSS.

Hãy đăng ký theo dõi WP Căn bản để cập nhật các bài viết mới trong tương lai thông qua Twitter.

Hãy đăng ký theo dõi WP Căn bản để cập nhật các bài viết mới trong tương lai thông qua Facebook.

Hãy đăng ký theo dõi WP Căn bản để cập nhật các bài viết mới trong tương lai thông qua Google.

Mặc dù đây chỉ là một ví dụ cơ bản về cách thức hoạt động của các thuộc tính, tuy nhiên, dựa vào nó, bạn có thể dễ dàng để xem cách các nhà phát triển plugin sử dụng shortcode API để thêm các chức năng phức tạp hơn, thân thiện với người dùng hơn.

Mọi thắc mắc vui lòng gửi vào khung bình luận bên dưới. Như thường lệ, nếu bạn thích bài viết này, hãy subscribe blog của tôi để thường xuyên cập nhật những bài viết hay nhất, mới nhất qua email nhé. Cảm ơn rất nhiều. :)

Đang tải đánh giá...
  • Chia sẻ lên Facebook
  • Chia sẻ lên Twitter
  • Chia sẻ lên LinkedIn

Bài viết liên quan

Khắc phục lỗi temp-write-test trong WordPress
Khắc phục lỗi temp-write-test trong WordPress
Hiển thị đánh giá 5 sao trên Google một cách đơn giản
Hiển thị đánh giá 5 sao trên Google một cách đơn giản
Tích hợp mã QR ngân hàng cho WooCommerce
Tích hợp mã QR ngân hàng cho WooCommerce

Chuyên mục: Thủ thuật WordPress

wpcanban-com-facebook-group

Nói về Trung Hiếu

Một người con của xứ Nghệ, hiện đang sinh sống tại Hà Nội. Tôi là người sáng lập và đứng sau mọi hoạt động của WP Căn bản. Tìm hiểu thêm về tôi tại đây.

Bài viết trước « Làm thế nào để quản lý WordPress multisite một cách hiệu quả?
Bài viết sau Top 20 Widgets hữu ích dành cho blog WordPress »

Reader Interactions

Bình luận

    Để lại một bình luận Hủy

    Tất cả các bình luận đều sẽ được kiểm duyệt nghiêm ngặt. Mọi bình luận trái quy định sử dụng sẽ bị gỡ bỏ link hoặc xóa bỏ hoàn toàn. Vui lòng đọc kỹ quy định trước khi bình luận. Xin cảm ơn!

  1. Thịnh Phạm 2 bình luậnviết

    21/05/2023 lúc 12:27

    TRÍCH ĐOẠN HƯỚNG DẪN GOOGLE
    “Ví dụ: Nếu bạn muốn Google không cho thấy hình ảnh dogs.jpg có trên trang web của bạn tại yoursite.example.com/images/dogs.jpg, hãy thêm thông tin sau vào tệp robots.txt:

    User-agent: Googlebot-Image
    Disallow: /images/dogs.jpg
    Vào lần thu thập dữ liệu tiếp theo trên trang web của bạn, Google sẽ thấy lệnh này và xoá hình ảnh của bạn khỏi kết quả tìm kiếm.

    Bạn có thể đưa các ký tự đặc biệt vào quy tắc để tăng tính linh hoạt và mức độ kiểm soát. Ký tự * khớp với chuỗi ký tự bất kỳ và các mẫu có thể kết thúc bằng $ để thể hiện phần cuối của một đường dẫn.

    Để xoá nhiều hình ảnh trên trang web của bạn khỏi chỉ mục của chúng tôi, hãy thêm một quy tắc disallow cho mỗi hình ảnh, hoặc nếu hình ảnh có chung một mẫu (chẳng hạn như hậu tố trong tên tệp), hãy sử dụng ký tự * trong tên tệp. Ví dụ:

    User-agent: Googlebot-Image
    # Repeated ‘disallow’ rules for each image:
    Disallow: /images/dogs.jpg
    Disallow: /images/cats.jpg
    Disallow: /images/llamas.jpg

    # Wildcard character in the filename for
    # images that share a common suffix:
    Disallow: /images/animal-picture-*.jpg ”
    THEO hướng dẫn này thì câu lệnh như thế này đúng không ạ:
    Disallow: /images/abcd-*.jpg
    Với abcd là ký tự mình đặt tên cho những ảnh mình muốn noindex.
    Mình dùng wordpress thì link ảnh sẽ:
    domain/wp-content/uploads/2023/05/pic-name.jpg
    Khác so với google hướng dẫn:
    domain/images/pic-name.jpg
    Vậy cấu trúc vẫn là :
    Disallow: /images/animal-picture-*.jpg phải không anh.
    Mong anh chỉ giúp. Cảm ơn anh

    Bình luận
    • Trung Hiếu Quản lýviết

      21/05/2023 lúc 14:51

      Disallow: /images/abcd-*.jpg
      Với abcd là ký tự mình đặt tên cho những ảnh mình muốn noindex.

      Đúng rồi bạn nhé. Đối với WordPress, bạn có thể thử sửa thành:

      Disallow: /wp-content/uploads/*/abcd-*.jpg

      Bình luận
  2. Thịnh Phạm 2 bình luậnviết

    21/05/2023 lúc 10:15

    Bài viết mình chứa nhiều hình ảnh, mình muốn tùy chọn một số hình ảnh để noindex chứ không phải toàn bộ thì có cách nào? Mình dùng shortcode ảnh và noindex shortcode đó có được không? Hay dùng cách nào khác. Mong anh chỉ giúp, Cảm ơn anh nhiều!

    Bình luận
    • Trung Hiếu Quản lýviết

      21/05/2023 lúc 11:30

      Bạn thử tham khảo hướng dẫn này của Google xem sao nhé.

      Bình luận
  3. muongnguyen 1 bình luậnviết

    08/03/2017 lúc 11:09

    mình muốn chèn shortcode của social share and lock vào bài viết 1 cách ngắn gọn thì làm ntn vậy AD ví dụ [share] noi dung [/share]
    thay vì nó cho 1 mới shortcode ntnay ạ:
    code php nó cho :
    <?php echo do_shortcode("[indeed-social-locker sm_list='fb,tw,go1' sm_template='ism_template_2' sm_list_align='horizontal' sm_display_counts='false' sm_display_full_name='true' locker_template=3 sm_d_text='Nội dung bạn xem bị khoá! Nhằm bảo vệ nội dung & thành phần phá hoại nên mình khoá lại, để xem nội dung bạn hãy nhấn chia sẻ để xem nhé..cảm ơn!’ ism_overlock=’default’ ]   [/indeed-social-locker]”);?>
    cảm ơn ad

    Bình luận
  4. Trung Lùn 9 bình luậnviết

    27/05/2015 lúc 15:48

    Bác cho cái vídụ về vụ chèn adsense vào trực tiếp trong code sử dụng shortcode đi ợ!

    Bình luận
    • Trung Hiếu Quản lýviết

      28/05/2015 lúc 06:55

      Nếu bạn muốn chèn Adsense bằng shortcode thì thử plugin https://wordpress.org/plugins/adsense-inserter/ sẽ nhanh và đơn giản hơn đấy. :D

      Bình luận

Sidebar chính

Người sáng lập

avatar-tac-gia
Blogger - Developer - Freelancer

Tôi tên là Bùi Trung Hiếu, sinh ra ở một làng quê nghèo thuộc tỉnh Nghệ An. Hiện tại, tôi đang sinh sống và làm việc tại Hà Nội. Với niềm đam mê công nghệ thông tin mãnh liệt, đặc biệt là WordPress, tôi đã tự tìm tòi, nghiên cứu về chúng trong suốt nhiều năm qua.

Xem thêm về tôi

Theo dõi qua mạng xã hội

Dịch vụ tối ưu WordPress miễn phí

dich-vu-toi-uu-wordpress-mien-phi

Plugin độc quyền miễn phí

  • WPCB Secure Shield
  • WPCB Hybrid Cache Manager
  • WPCB AI Optimization
  • WPCB Simple Ratings
  • WPCB Simple AntiSpam
  • WPCB Social Share Buttons
  • WPCB Comment Notifications
  • WPCB Comment User Badge
  • WPCB Top Commenters
  • WPCB Simple SMTP
  • WPCB Simple Contact Form
  • WPCB Permalinks Manager
  • WPCB Syntax Highlighter
  • WPCB Content Protector
  • WPCB Auto Images Alt-Text
  • WPCB Snowfall
  • WPCB Ultimate Search
  • WPCB 404 Auto Redirect
  • WPCB Disable Blog
  • WPCB Simple Lightbox
  • WPCB Auto Expired Transients Cleaner

Dịch vụ quét mã độc miễn phí

dich-vu-quet-ma-doc-wordpress-mien-phi

Bài viết mới nhất

  • Tối ưu website WordPress cho AI một cách đơn giản 24/03/2026
  • Hướng dẫn nâng cấp PHP 8.5 cho website WordPress 09/03/2026
  • Sửa lỗi trắng trang cho XML Sitemaps của Rank Math SEO 02/03/2026
  • Sửa lỗi 404 cho XML Sitemaps của Rank Math SEO 01/02/2026
  • Plugin chống spam siêu nhẹ dành cho WordPress 07/01/2026
  • Plugin siêu nhẹ tạo hiệu ứng tuyết rơi cho WordPress 12/12/2025

Footer

Bình luận mới nhất

  • Trung Hiếu trong Plugin bảo mật WPCB Secure Shield độc quyền
  • Blog Công Chứng trong Plugin bảo mật WPCB Secure Shield độc quyền
  • Trung Hiếu trong Hướng dẫn nâng cấp PHP 8.5 cho website WordPress
  • Tuấn Digi trong Hướng dẫn nâng cấp PHP 8.5 cho website WordPress
  • Trung Hiếu trong Hướng dẫn nâng cấp PHP 8.5 cho website WordPress

Bình luận nhiều nhất

  1. Tịnh Nguyễn Blog (16)
  2. Ngọc Blue (6)
  3. Tuấn Lê (3)
  4. HN (1)
  5. Tuấn Digi (1)
  6. Blog Công Chứng (1)

Liên kết hữu ích

  • Giới thiệu bản thân
  • Quy định sử dụng
  • Bản quyền nội dung
  • Chính sách bảo mật
  • Liên hệ hỗ trợ

Thống kê WP Căn bản

9 Chuyên mục - 1.019 Bài viết - 35.700 Bình luận

Bản quyền © 2014 - 2026 · WP Căn bản (tiền thân là ebooksvn.com) · Sử dụng Paradise child theme và dịch vụ WordPress Hosting