[acf_views name="Name of View" view-id="651d5d75bfdf2"]
Note: Displays the View, chosen meta fields should be filled at the same object where the shortcode is pasted (post/page), replace view-id="651d5d75bfdf2" with the ID of your View.
<?php
// a) using do_shortcode
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2"]');
// b) using the special plugin class
use Org\Wplake\Advanced_Views\Bridge\Advanced_Views;
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->render();
By default, View shortcodes contain two arguments: "name" and "view-id". The "name" is used for clarification purposes only and doesn't play any functional role. The "view-id" argument is the most important as it allows Advanced Views to associate the shortcode with a specific View.
This argument allows to define a source, from which the View fields will be loaded. By default, the object-id argument is skipped, and Advanced Views automatically picks up ID of the currently displayed object (current post/page/taxonomy). If you need to change the default behavior, see the details below.
By ID: [acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="ANOTHER_POST_ID"]
By Slug: [acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="post" post-slug="my-slug"]
<?php
// 1. using do_shortcode
// 1.1) using do_shortcode by ID
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="ANOTHER_POST_ID"]');
// 1.2) using do_shortcode by Slug
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="post" post-slug="my-slug"]');
// 2. using the special plugin class
use Org\Wplake\Advanced_Views\Bridge\Advanced_Views;
// 2.1) using the special plugin class by ID
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->set_object_id('ANOTHER_POST_ID')
->render();
// 2.2) using the special plugin class by Slug
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->set_object_id('post')
->set_post_slug('my-slug')
->render();
Loading by ID is the default approach. However, loading by slug is preferred if you have multiple environments (e.g., Localhost and Live) where IDs may differ, especially if synchronization is not performed regularly.
<?php
// a) using do_shortcode
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="ANOTHER_POST_ID"]');
// b) using the special plugin class
use Org\Wplake\Advanced_Views\Bridge\Advanced_Views;
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->set_object_id('options')
->render();
[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="user" user-id="YOUR_USER_ID_HERE"]
The second argument, user-id is optional. If you skip it, Advanced Views will automatically get the id of the current user during rendering and load fields from it.
Note: "current user" doesn't mean the user who has made the View, or pasted the shortcode, but the specific user, who is visiting the page.
<?php
// a) using do_shortcode
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="user" user-id="YOUR_USER_ID_HERE"]');
// b) using the special plugin class
use Org\Wplake\Advanced_Views\Bridge\Advanced_Views;
use Org\Wplake\Advanced_Views\Bridge\Interfaces\Shortcodes\View_Shortcode_Interface;
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->set_object_id(View_Shortcode_Interface::OBJECT_OPTIONS)
->set_user_id(1) // your user id here
->render();
<?php
// a) using do_shortcode
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="term" term-id="YOUR_TERM_ID_HERE"]');
// b) using the special plugin class
use Org\Wplake\Advanced_Views\Bridge\Advanced_Views;
use Org\Wplake\Advanced_Views\Bridge\Interfaces\Shortcodes\View_Shortcode_Interface;
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->set_object_id(View_Shortcode_Interface::OBJECT_TERM)
->set_term_id(1) // your term id here
->render();
<?php
// a) using do_shortcode
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="comment" comment-id="YOUR_COMMENT_ID_HERE"]');
// b) using the special plugin class
use Org\Wplake\Advanced_Views\Bridge\Advanced_Views;
use Org\Wplake\Advanced_Views\Bridge\Interfaces\Shortcodes\View_Shortcode_Interface;
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->set_object_id(View_Shortcode_Interface::OBJECT_COMMENT)
->set_comment_id(1) // your comment id here
->render();
<?php
// a) using do_shortcode
echo do_shortcode('[acf_views name="Name of View" view-id="651d5d75bfdf2" object-id="menu" menu-slug="YOUR_MENU_SLUG_HERE"]');
// b) using the special plugin class
use Org\Wplake\Advanced_Views\Bridge\Advanced_Views;
use Org\Wplake\Advanced_Views\Bridge\Interfaces\Shortcodes\View_Shortcode_Interface;
echo Advanced_Views::view_shortcode('651d5d75bfdf2', 'name')
->set_object_id(View_Shortcode_Interface::OBJECT_MENU)
->set_menu_slug('main-menu') // your menu slug here
->render();
7. Loading fields from a menu item
In WordPress, every menu item is a Post. So you can load a View from the Menu item by passing its ID into the object-id argument, like in the first "Loading fields from a specific post/CPT item" case.
FAQs
Shortcode shows (internal use only)
In the Pro version of the plugin, use "Parent Group" if you plan to select Fields from the same Field Group. If you make use of the "Parent Group" and "Parent field" then the shortcode will show (internal use only).
That's because its reserved for Internal Views that are used for the nested setup of the group, repeater or flexible field types.
See the Nested Repeater guide here.