Sometimes you want to send a different path to GoatCounter than what appears in the browser’s URL bar; removing one or more query parameters are a common scenario.
The easiest way to ensure that /path
always shows up as /path
is to add a
canonical URL in the <head>
:
<link rel="canonical" href="https://example.com/path">
The href
can also be relative (e.g. /path
).
This will only work if the canonical URL is on the same domain (with allowance
for the www
subdomain); for example setting the canonical URL to:
<link rel="canonical" href="https://my-other-site.com/path">
And then loading this page as https://example.com/path
will mean GoatCounter
just ignore this value. This is because some people publish things on multiple
sites and then point at one as “canonical”. This can be good for SEO, but not
good for tracking things in GoatCounter.
Be sure to understand the potential SEO effects before adding a canonical URL; if you use query parameters for navigation then you probably don’t want to do this.
You can use data-goatcounter-settings
on the script tag to set the path; this
must be valid JSON:
<script data-goatcounter="https://stats.196000.xyz/count"
data-goatcounter-settings='{"path": "/hello"}'
async src="//zgo.at/count.js"></script>
You can also set the title
, referrer
, and event
in here.
Alternatively you can send a custom path
by setting window.goatcounter
before the count.js
script loads:
<script>
window.goatcounter = {
path: location.pathname || '/',
}
</script>
<script data-goatcounter="https://stats.196000.xyz/count"
async src="//stats.196000.xyz/count.js"></script>
This is useful if you want some more complex logic, for example to add some
individual query parameters with goatcounter.get_query()
:
<script>
window.goatcounter = {
path: function() {
return location.pathname + '?page=' + (goatcounter.get_query('page')) || '/'),
},
}
</script>
<script data-goatcounter="https://stats.196000.xyz/count"
async src="//stats.196000.xyz/count.js"></script>
Note this example uses a callback, since goatcouner.get_query()
won’t be
defined yet if we just used an object.
See the JavaScript API page for more details JS API.
Feel free to get in touch if you’ve got any questions or having any problems; a lot of times they can be resolved without too much problems.
Ways to contact me: show