What is MIME type "text/x-component"?

A MIME type is a string that tells browsers and other tools how to handle a particular kind of file.

text/x-component designates files that store HTML components. These files are used to add custom behavior to web pages. The primary file type is an HTC file. They were mostly used in older versions of Internet Explorer.

Such files let developers embed reusable scripts and markup that can enhance interactivity on a page. They act as a bridge between markup and behavior.

External reference: Microsoft Docs

Associated file extensions

Usage Examples

HTTP Header

When serving content with this MIME type, set the Content-Type header:


    Content-Type: text/x-component    
  

HTML

In HTML, you can specify the MIME type in various elements:


    <a href="file.dat" type="text/x-component">Download file</a>    
  

Server-side (Node.js)

Setting the Content-Type header in Node.js:


    const http = require('http');    
    
    http.createServer((req, res) => {    
      res.setHeader('Content-Type', 'text/x-component');    
      res.end('Content here');    
    }).listen(3000);    
  

Associated file extensions

FAQs

Which file extension is associated with text/x-component?

The primary file extension for this MIME type is .htc (HTML Components). These files were historically used by Internet Explorer to attach dynamic behaviors to HTML elements via CSS.

How do I configure Apache to serve .htc files correctly?

To ensure browsers interpret the file correctly, add the following line to your .htaccess file or httpd.conf: AddType text/x-component .htc. If the server sends the wrong content type (like text/plain), the behavior may fail to load.

Does text/x-component work in modern browsers like Chrome or Firefox?

No, this MIME type and the underlying HTC technology are proprietary to older versions of Internet Explorer. Modern browsers ignore these files; developers should use standard JavaScript or CSS3 for similar effects.

How do I add the text/x-component MIME type in IIS?

Open IIS Manager, select your site, and double-click the MIME Types feature. Click Add... in the Actions pane, set the file name extension to .htc, and the MIME type to text/x-component.

Why do I get 'Access Denied' errors with .htc files?

HTML Components require the .htc file to be on the same domain as the page calling it. Cross-domain requests for text/x-component files are typically blocked by browser security policies unless specific headers are configured.

How do I configure Nginx to support text/x-component?

Edit your mime.types file (usually located in /etc/nginx/) and ensure the following line exists: text/x-component htc;. Reload Nginx to apply the changes.

What should I use instead of text/x-component today?

For modern web development, replace .htc files with Web Components, CSS3 animations, or standard JavaScript modules. These alternatives provide better performance and are supported by all major browsers.

General FAQ

What is a MIME type?

A MIME (Multipurpose Internet Mail Extensions) type is a standard that indicates the nature and format of a document, file, or assortment of bytes. MIME types are defined and standardized in IETF's RFC 6838.

MIME types are important because they help browsers and servers understand how to process a file. When a browser receives a file from a server, it uses the MIME type to determine how to display or handle the content, whether it's an image to display, a PDF to open in a viewer, or a video to play.

MIME types consist of a type and a subtype, separated by a slash (e.g., text/html, image/jpeg, application/pdf). Some MIME types also include optional parameters.

How do I find the MIME type for a file?

You can check the file extension or use a file identification tool such as file --mime-type on the command line. Many programming languages also provide libraries to detect MIME types.

Why are multiple MIME types listed for one extension?

Different applications and historical conventions may use alternative MIME identifiers for the same kind of file. Showing them all helps ensure compatibility across systems.