PagesVersions::getPageVersions() method

Get all versions for given page

Example

$page = $pages->get(1234);
$versions = $pagesVersions->getPageVersions($page);
foreach($versions as $p) {
  echo $p->get('_version')->version; // i.e. 2, 3, 4, etc.
}

Usage

// basic usage
$pageVersionInfo = $pagesVersions->getPageVersions(Page $page);

// usage with all arguments
$pageVersionInfo = $pagesVersions->getPageVersions(Page $page, array $options = []);

Arguments

NameType(s)Description
pagePage
options (optional)array
  • getInfo (bool): Specify true to instead get PageVersionInfo objects (default=false)
  • sort (string): Sort by property, one of: 'created', '-created', 'version', '-version' (default='-created')
  • version (array): Limit to this version number, for internal use (default=0)

Return value

PageVersionInfo

[]|Page[]

  • Returns Array of Page objects or array of PageVersionInfo objects if getInfo requested.
  • When returning pages, version info is in $page->_version value of each page, which is a PageVersionInfo object.

Exceptions

Method can throw exceptions on error:

  • WireException


$pagesVersions methods and properties

API reference based on ProcessWire core version 3.0.236

Latest news

  • ProcessWire Weekly #555
    In the 555th issue of ProcessWire Weekly we're going to check out the latest core updates, introduce a new third party module that adds the ability to automatically convert email messages to pages, and more. Read on!
    Weekly.pw / 28 December 2024
  • Custom Fields Module
    This week we look at a new ProFields module named Custom Fields. This module provides a way to rapidly build out ProcessWire fields that contain any number of subfields/properties within them.
    Blog / 30 August 2024
  • Subscribe to weekly ProcessWire news

“ProcessWire is like a breath of fresh air. So powerful yet simple to build with and customise, and web editors love it too.” —Margaret Chatwin, Web developer