NEW AI Studio is now available Try it now
E-Commerce

Ulta Beauty Scraper

Extract beauty product listings, brand info, pricing, and reward point values from Ulta Beauty store. Powered by spider-browser .

Get Started Documentation
ulta.com target
99.5% success rate
~4ms latency
Quick Start

Extract data in minutes

ulta-beauty-scraper.ts
import { SpiderBrowser } from "spider-browser";

const spider = new SpiderBrowser({
  apiKey: process.env.SPIDER_API_KEY!,
  stealth: 2,
});

await spider.connect();
const page = spider.page!;
await page.goto("https://www.ulta.com/shop/makeup/face/foundation");
await page.content();

const data = await page.evaluate(`(() => {
  const items = [];
  document.querySelectorAll("[data-testid='ProductCard']").forEach(el => {
    const brand = el.querySelector("[data-testid='ProductCard-brand']")?.textContent?.trim();
    const name = el.querySelector("[data-testid='ProductCard-name']")?.textContent?.trim();
    const price = el.querySelector("[data-testid='ProductCard-price']")?.textContent?.trim();
    const rating = el.querySelector("[data-testid='ProductCard-rating']")?.getAttribute("aria-label");
    if (name) items.push({ brand, name, price, rating });
  });
  return JSON.stringify({ total: items.length, items: items.slice(0, 10) });
})()`);

console.log(JSON.parse(data));
await spider.close();
✓ ready to run | spider-browser | TypeScript
Fetch API

Structured data endpoint

Extract structured JSON from ulta.com with a single POST request. AI-configured selectors, cached for fast repeat calls.

POST /fetch/ulta.com/
Product nameBrandPriceRatingReview countSize
curl
curl -X POST https://api.spider.cloud/fetch/ulta.com/ \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"return_format": "json"}'
Python
import requests

resp = requests.post(
    "https://api.spider.cloud/fetch/ulta.com/",
    headers={
        "Authorization": "Bearer YOUR_API_KEY",
        "Content-Type": "application/json",
    },
    json={"return_format": "json"},
)
print(resp.json())
Node.js
const resp = await fetch("https://api.spider.cloud/fetch/ulta.com/", {
  method: "POST",
  headers: {
    "Authorization": "Bearer YOUR_API_KEY",
    "Content-Type": "application/json",
  },
  body: JSON.stringify({ return_format: "json" }),
});
const data = await resp.json();
console.log(data);
Extraction

Data you can extract

Product nameBrandPriceRatingReview countSizeCategoryRewards points
Pricing

Real-time price data

Monitor product prices, discounts, and availability changes on ulta.com.

Anti-Bot

Protection bypass

Automated CAPTCHA solving and fingerprint rotation to access product pages reliably.

Scale

Bulk extraction

Process thousands of product pages concurrently with smart retry and browser switching.

Related

More E-Commerce scrapers

Start scraping ulta.com

Get your API key and start extracting data in minutes.