This feature is not Baseline because it does not work in some of the most widely-used browsers.
Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
The XRAnchor interface creates anchors which keep track of the pose that is fixed relative to the real world. With anchors, you can specify poses in the world that need to be updated to correctly reflect the evolving understanding of the world, such that the poses remain aligned with the same place in the physical world. That helps to build an illusion that the placed objects are really present in the user's environment.
XRAnchor.anchorSpace Read only Experimental
Returns an XRSpace object to locate the anchor relative to other XRSpace objects.
XRAnchor.delete() Experimental
Removes the anchor.
navigator.xr.requestSession("immersive-ar", {
requireFeatures: ["anchors"],
});
You can use XRFrame.createAnchor() to create an anchor.
frame.createAnchor(anchorPose, referenceSpace).then(
(anchor) => {
// Do stuff with the anchor (assign objects that will be relative to this anchor)
},
(error) => {
console.error(`Could not create anchor: ${error}`);
},
);
| Specification |
|---|
| WebXR Anchors Module> # xr-anchor> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
XRAnchor |
85 | 85 | No | 71 | No | 85 | No | 60 | No | 14.0 | No | No |
anchorSpace |
85 | 85 | No | 71 | No | 85 | No | 60 | No | 14.0 | No | No |
delete |
85 | 85 | No | 71 | No | 85 | No | 60 | No | 14.0 | No | No |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/XRAnchor