URLPattern: test() method
        
        
          
                Baseline
                
                  2025
                
                
              
        
        Newly available
        
          
                
              
                
              
                
              
        
        
      
      Since September 2025, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
Note: This feature is available in Web Workers.
The test() method of the URLPattern interface takes a URL string or object of URL parts, and returns a boolean indicating if the given input matches the current pattern.
Syntax
test(input)
test(url)
test(url, baseURL)
Parameters
- input
- 
An object providing the individual URL parts. The object members can be any of protocol,username,password,hostname,port,pathname,search,hash, orbaseURL.
- url
- 
A string defining an absolute or relative URL. If a relative URL, then baseURLmust also be provided and together they must resolve to an absolute URL. If the input cannot be parsed, or a relative URL without a base URL is provided, the method will returnfalse.
- baseURLOptional
- 
A string representing the base URL to use in cases where urlis a relative URL. If not specified, it defaults toundefined. If provided but the base URL cannot be parsed, the method will returnfalse.
URL parts that are not specified in the url/input may be inherited from a base URL in some circumstances.
Omitted parts are treated as empty strings.
Return value
A boolean.
Exceptions
Description
The method is called on a URLPattern, specifying an input url as a string with an optional base URL, or as object with properties for each URL-part.
The method returns true if all components of the test URL/input match all components of the pattern, and false if any component don't match.
The method also returns false if a relative url is passed but baseURL is not specified (an absolute test URL cannot be resolved).
Note that when passing an input object, input.baseURL is always optional.
Inheritance from a BaseURL
URL-parts that are more specific than the least-specific part defined in the url can be inherited from baseURL (or from input.baseURL for input).
Intuitively this means that if the pathname part is specified in the input, the parts to its left in a URL may be inherited from the base URL (protocol, hostname and port), while the parts to its right may not (search and hash).
The username and password are never inherited from a base URL.
For more information see Inheritance from a BaseURL in the API overview.
Examples
The examples shows how to use the test() method to match a URL against a pattern.
In each case the result of the test() is printed to the console.
Testing an absolute URL
First we define the pattern to use for matching URLs.
This pattern matches against URLs that have either http or https protocol, are subdomains of .example.com and have a path that is /books/ followed by any value.
const pattern = new URLPattern("http{s}?://*.example.com/books/:id");
Next we match against two absolute URL strings.
The first matches but the second doesn't, because the test URL is not a subdomain of example.com.
console.log(pattern.test("https://store.example.com/books/123")); // true
console.log(pattern.test("https://example.com/books/123")); // false
Testing a relative URL
This example uses the same pattern as before to test against a number of relative URLs.
const pattern = new URLPattern("http{s}?://*.example.com/books/:id");
Next we match against some relative URLs.
The case matches as the resolved URL is https://store.example.com/books/123, while the second does note because the resolved URL is not a subdomain of example.com.
console.log(pattern.test("/books/123", "http://store.example.com")); // true
console.log(pattern.test("/books/123", "http://example.com")); // false
This test does not match because the provided URL is relative and no baseURL is provided. Note that you can define a test that matches against just a pathname, but you need to use the object input.
console.log(pattern.test("/books/123")); // false
This test does not match because the base URL is not a valid URL, and together with the /books/123 does not resolve to an absolute URL.
console.log(pattern.test("/books/123", "data:text/plain,hello world!")); // false
Testing an URL object
This example uses the same pattern as before to test against a number of URLs defined as structured objects.
const pattern = new URLPattern("http{s}?://*.example.com/books/:id");
The first case matches because it defines a match exactly against each part of the pattern:
console.log(
  pattern.test({
    protocol: "https",
    hostname: "store.example.com",
    pathname: "/books/123",
  }),
); // true
In this code the pathname is present and the missing parts are supplied in the baseURL.
The result is the same as the previous code.
console.log(
  pattern.test({
    pathname: "/books/123",
    baseURL: "http://store.example.com",
  }),
); // true
This structured URL does not match the pattern, because the protocol is file (not https or http).
console.log(
  pattern.test({
    protocol: "file",
    hostname: "store.example.com",
    pathname: "/books/123",
  }),
); // false
Specifications
| Specification | 
|---|
| URL Pattern> # dom-urlpattern-test> | 
Browser compatibility
Loading…
See also
- A polyfill of URLPatternis available on GitHub