• /
  • EnglishEspañol日本語한국어Português
  • Log inStart now

addPageAction

Syntax

newrelic.addPageAction(string $name[, JSON object $attributes])

Reports a browser PageAction event along with a name and optional attributes.

Requirements

Description

This API call sends a browser PageAction event with your user-defined name and optional attributes to dashboards, along with several default attributes. This is useful to track any event that is not already tracked automatically by the browser agent, such as clicking a Subscribe button or accessing a tutorial.

  • PageAction events are sent every 30 seconds.
  • If 1,000 events are observed, the agent will harvest the buffered events immediately, bypassing the harvest cycle interval.

Important

In earlier agent versions, events were dropped after 120 were observed. The event limit was increased from 120 to 1,000 in version 1.264.0 and are no longer dropped.

Parameters

Parameter

Description

$name

string

Required. Name or category of the action. Reported as the actionName attribute.

Avoid using reserved NRQL words when you name the attribute or value.

$attributes

JSON object

Optional. JSON object with one or more key/value pairs. For example: {key:"value"}. The key is reported as its own PageAction attribute with the specified values.

Avoid using reserved NRQL words when you name the attribute/value.

Examples

This example records a PageAction event whenever a user selects the Try Me link. The event is recorded with an actionName of clickedTryMe:

<a href="/demo" id="try-me">Try Me!</a>
<script>
document.getElementById('try-me').addEventListener('click', function (e) {
newrelic.addPageAction('clickedTryMe');
});
</script>

You can then query the number of times the Try Me button was clicked with the following NRQL query:

SELECT count(*) FROM PageAction WHERE actionName = 'clickedTryMe' SINCE 1 hour ago

This example sends a PageAction event when a user clicks on an element with the class copy-text. The actionName is copy-text-button and the value is reported as another attribute called Result that corresponds to methods named success and error that handle the outcome.

$('.copy-text').click(function() {
var clipboard = new Clipboard('.copy-text');
clipboard.on('success', function(event) {
// Do stuff
// Report data to New Relic
if (typeof newrelic == 'object') {
newrelic.addPageAction('copy-text-button', { result: 'success' });
}
});
clipboard.on('error', function(event) {
// Do stuff
// Report data to New Relic
if (typeof newrelic == 'object') {
newrelic.addPageAction('copy-text-button', { result: 'error' });
}
});
});

Then in the query builder, you can create a pie chart to see the breakdown of how many button clicks resulted in success versus error over the past 30 days:

SELECT count(*) AS 'Clicks' FROM PageAction WHERE actionName = 'copy-text-button' FACET result SINCE 30 days ago

Or you can create a query to see what pages have the most copy button clicks in the last 30 days:

SELECT count(*) AS 'Clicks' FROM PageAction WHERE actionName = 'copy-text-button' FACET currentUrl SINCE 30 days ago

Capture form input

This example captures user input (email addresses) from a form called Signup. The event is recorded with an actionName of userSignup:

<form action="/signup" id="myform">
<input id="email" name="email" />
<input type="submit" value="Signup" />
</form>
<script type="text/javascript">
document.getElementById('myform').addEventListener('submit', function (e) {
var email = e.target.elements['email'].value;
newrelic.addPageAction('userSignup', { email: email });
});
</script>

You can then see the emails that you gathered with the following NRQL query:

SELECT uniques(email) FROM PageAction WHERE actionName = 'userSignup' SINCE 1 hour ago
Copyright © 2025 New Relic Inc.

This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.