Browser fingerprinting library with the highest accuracy and stability.

Overview

FingerprintJS

Build status Current NPM version Monthly downloads from NPM Monthly downloads from jsDelivr

FingerprintJS is a browser fingerprinting library that queries browser attributes and computes a hashed visitor identifier from them. Unlike cookies and local storage, a fingerprint stays the same in incognito/private mode and even when browser data is purged.

View Our Demo.

Quick start

Install from CDN

<script>
  function initFingerprintJS() {
    FingerprintJS.load().then(fp => {
      // The FingerprintJS agent is ready.
      // Get a visitor identifier when you'd like to.
      fp.get().then(result => {
        // This is the visitor identifier:
        const visitorId = result.visitorId;
        console.log(visitorId);
      });
    });
  }
</script>
<script
  async
  src="//cdn.jsdelivr.net/npm/@fingerprintjs/fingerprintjs@3/dist/fp.min.js"
  onload="initFingerprintJS()"
></script>

Alternatively you can install from NPM to use with Webpack/Rollup/Browserify

npm i @fingerprintjs/fingerprintjs
# or
yarn add @fingerprintjs/fingerprintjs
import FingerprintJS from '@fingerprintjs/fingerprintjs';

(async () => {
  // We recommend to call `load` at application startup.
  const fp = await FingerprintJS.load();

  // The FingerprintJS agent is ready.
  // Get a visitor identifier when you'd like to.
  const result = await fp.get();

  // This is the visitor identifier:
  const visitorId = result.visitorId;
  console.log(visitorId);
})();

📕 Full documentation

Upgrade to Pro version to get 99.5% identification accuracy

FingerprintJS Pro is a professional visitor identification service that processes all information server-side and transmits it securely to your servers using server-to-server APIs. Pro combines browser fingerprinting with vast amounts of auxiliary data (IP addresses, time of visit patterns, URL changes and more) to be able to reliably deduplicate different users that have identical devices, resulting in 99.5% identification accuracy.

See our full product comparison for more information on the differences between open source and Pro.

Pro screenshot

Open Source version

Pro version

Identification accuracy 60% 99.5%
Incognito / Private mode detection
Geolocation
Security
Server API
Webhooks
Stable identifier between versions

Pro result example:

{
  "requestId": "HFMlljrzKEiZmhUNDx7Z",
  "visitorId": "kHqPGWS1Mj18sZFsP8Wl",
  "visitorFound": true,
  "incognito": false,
  "browserName": "Chrome",
  "browserVersion": "85.0.4183",
  "os": "Mac OS X",
  "osVersion": "10.15.6",
  "device": "Other",
  "ip": "192.65.67.131",
  "ipLocation": {
    "accuracyRadius": 100,
    "latitude": 37.409657,
    "longitude": -121.965467
    // ...
  }
}

🍿 Live demo

How to upgrade from Open Source to Pro in 30 seconds

📕 FingerprintJS Pro documentation

▶️ Video: use FingerprintJS Pro to prevent multiple signups

Open-source version reference

Installation

The library is shipped in various formats:

Global variable

<script>
  function initFingerprintJS() {
    // Start loading FingerprintJS here
  }
</script>
<script
  async
  src="//cdn.jsdelivr.net/npm/@fingerprintjs/fingerprintjs@3/dist/fp.min.js"
  onload="initFingerprintJS()"
></script>

UMD

require(
  ['//cdn.jsdelivr.net/npm/@fingerprintjs/fingerprintjs@3/dist/fp.umd.min.js'],
  (FingerprintJS) => {
    // Start loading FingerprintJS here
  }
);

ECMAScript module

# Install the package first:
npm i @fingerprintjs/fingerprintjs
# or
yarn add @fingerprintjs/fingerprintjs
import FingerprintJS from '@fingerprintjs/fingerprintjs';

// Start loading FingerprintJS here

CommonJS

# Install the package first:
npm i @fingerprintjs/fingerprintjs
# or
yarn add @fingerprintjs/fingerprintjs
const FingerprintJS = require('@fingerprintjs/fingerprintjs');

// Start loading FingerprintJS here

API

FingerprintJS.load({ delayFallback?: number }): Promise<Agent>

Builds an instance of Agent and waits a delay required for a proper operation. delayFallback is an optional parameter that sets duration (milliseconds) of the fallback for browsers that don't support requestIdleCallback; it has a good default value which we don't recommend to change.

agent.get({ debug?: boolean }): Promise<object>

Gets the visitor identifier. debug: true prints debug messages to the console. Result object fields:

  • visitorId The visitor identifier
  • components A dictionary of components that have formed the identifier. Each value is an object like { value: any, duration: number } in case of success and { error: object, duration: number } in case of an unexpected error during getting the component.
  • version The fingerprinting algorithm version which is equal to the library version. See the version policy section for more details.

See the extending guide to learn how to remove and add entropy components.

FingerprintJS.hashComponents(components: object): string

Converts a dictionary of components (described above) into a short hash string a.k.a. a visitor identifier. Designed for extending the library with your own components.

FingerprintJS.componentsToDebugString(components: object): string

Converts a dictionary of components (described above) into human-friendly format.

Migrating from v2

Version policy

The library tries to keep visitor identifiers the same within a minor version (i.e. when the first 2 numbers of the version don't change). Some visitor identifiers may change within a minor version due to stability fixes. To get identifiers that remain stable up to 1 year, please consider upgrading to pro.

Agent get() function returns the version together with the visitor identifier. You can use it to decide whether a couple of identifiers can be matched together. Example:

if (
  result1.version.split('.').slice(0, 2).join('.') ===
  result2.version.split('.').slice(0, 2).join('.')
) {
  return result1.visitorId === result2.visitorId ? 'same' : 'different';
} else {
  return 'unknown';
}

The documented JS API follows Semantic Versioning. Use undocumented features at your own risk.

Browser support

npx browserslist "cover 95% in us, not IE < 10"

See more details and learn how to run the library in old browsers in the documentation article.

Contributing

See the contributing guidelines to learn how to start a playground, test and build.

Comments
  • fingerprintjs2 helps to spy of users

    fingerprintjs2 helps to spy of users

    Hello. How do you feel about the fact that this library has become an instrument of unjust power over users?

    The Canvas-based identification method has been extended due to the emergence of the fingerprintjs2 library, which can also take into account for generating an identifier such parameters as screen resolution, specific HTTP headers, lists of installed plug-ins and fonts, the activity of certain Web API, and WebGL.

    You can read the detailed study done by Antoine Vastel https://antoinevastel.com/browser%20fingerprinting/2019/02/19/canvas-fingerprint-on-the-web.html

    opened by proninyaroslav 74
  • Errors and promise

    Errors and promise

    New Implementation

    There are Breaking changes

    Resistant by default

    The new implementation is resistant by default to errors

    Component

    A components is an object with at least key and getData keys, example:

    {key: 'user_agent', getData: UserAgent, pauseBefore: false}
    

    getData value is the components function.

    Component function

    A components function takes done as first argument, and options as an optional second argument. It must call done with a String exactly once. Or something that can be cast to a String ? It must wrap all unreachable code (setTimeout, requestAnimationFrame, etc) in its own try catch, it should use catch as an opportunity to give a unique String to done

    function (done, options) { done(navigator.userAgent) }

    Exclude

    The component key can be used to exclude the component

    var options = {excludes: ['userAgent']}
    

    Unknown values

    Not used everywhere yet

    not available'

    The browser does not give information

    'error'

    An error occured while retrieving this information Only use generic 'error' as a last resort: Errors generally contain additional information.

    'excluded'

    This option was condionally excluded from the options (example with excludeAudioIOS11)

    Removed undocumented customEntropyFunction

    allowed to add 1 component via options(it had to be sync)

    Other changes

    • merge key 'ie_plugins' and 'regular_plugins' into 'plugins'
    • audioTimeout is an option, default 1000
    • add pauseBefore: true options for components
    • Some tests are no longer applicable
    • rename 'js_fonts' into 'fonts'
    • rename 'user_agent' into 'userAgent'
    • replace options.customFunction with options.extraComponents It allows to extend with more than one function.
    • options.extraComponents should be an array with components (see above)
    • fingerprint2.js is smaller

    Upgrade Guide

    replace

    var options = {}
    var fp = new Fingerprint2(options)
    fp.get(function(result, components) {
    
    }
    

    with

    Fingerprint2.get(options, function (components) {
        var values = Object.values(components).map(function (value) {
         if (value && typeof value.join === 'function') {
            return value.join(';')
          }
          return value
        })
        var murmur = Fingerprint2.x64hash128(values.join('~~~'), 31)
        var results = murmur;
    })
    

    or

    Fingerprint2.getPromise(options).then(function (components) {
        var values = Object.values(components).map(function (value) {
         if (value && typeof value.join === 'function') {
            return value.join(';')
          }
          return value
        })
        var murmur = Fingerprint2.x64hash128(values.join('~~~'), 31)
        var results = murmur;
    })
    

    Replace individual excludes with an array of excludes:

    var options = {
        excludes: [
            'enumerateDevices',
            'pixelRatio',
            'doNotTrack',
            'fontsFlash'
        ]
    }
    

    See also https://github.com/Valve/fingerprintjs2/issues/384

    opened by GrosSacASac 32
  • The fonts component gives different results

    The fonts component gives different results

    hi, i test firefox fp on the demo website(https://valve.github.io/fingerprintjs2/), when i first get the fp, the value is "c47be56e91cdb14ae31367c66851e4f3", then i open another tab, the value changed to "9af57a294ebb17e521c91c8a8a61fa4c", i compared component and found some difference on the component of "js_fonts", the former was "js_fonts = Arial,Arial Black,Arial Narrow,Arial Rounded MT Bold,Arial Unicode MS,Book Antiqua,Bookman Old Style", and the latter was "js_fonts = Arial,Arial Rounded MT Bold,Arial Unicode MS,Book Antiqua,Bookman Old Style,Calibri,Cambria,Cambria ", i want to know how to exclude font detection completely? I tried "extendedJsFonts: true" but it did not worked. This just happened on firefox , other browser worked fine.

    bug needinfo 
    opened by LesterDong 26
  • 【IOS WeChat 】No return data!

    【IOS WeChat 】No return data!

    Scenario

    userAgent: Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.2(0x18000239) NetType/WIFI Language/zh_CN

    • use cdn last version sdk fingerprintjs@3
        <script>
          function initFingerprintJS() {
    
            // Initialize an agent at application startup.
            const fpPromise = FingerprintJS.load();
    
            // Get the visitor identifier when you need it.
            fpPromise
              .then((fp) => {
                 // Here can get  fp
                 return  fp.get()
               })
              .then((result) => {
                // No executed!! 
    
                // This is the visitor identifier:
                const visitorId = result.visitorId;
                alert(visitorId);
              });
          }
        </script>
        <script
          async
          src="//cdn.jsdelivr.net/npm/@fingerprintjs/fingerprintjs@3/dist/fp.min.js"
          onload="initFingerprintJS()"
        ></script>
    
    
    bug 
    opened by FeSeason 25
  • Same browser different fingerprint

    Same browser different fingerprint

    Hello there!

    I encountered a very specific fingerprint behaviour. So my js code resides on some different websites (directly) and I receive on the same chrome browser the same id. That's fine. But, if my code is exported to some other website in iframe or is pushed by another js then I get totally different Id. So the same browser get's different Ids if JS is direct to browser or through some intermediary.

    Is it a bug or normal behaviour?

    needinfo 
    opened by kolykhalov 24
  • enumerate_devices keep changing

    enumerate_devices keep changing

    Every time I open a new browser session the enumerate_devices completely change.

    ac6b79a27e86490542ccf7f580926218

    [{
    
    	"key": "user_agent",
    	"value": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36"
    }, {
    	"key": "language",
    	"value": "en-US"
    }, {
    	"key": "color_depth",
    	"value": 24
    }, {
    	"key": "device_memory",
    	"value": 8
    }, {
    	"key": "hardware_concurrency",
    	"value": 4
    }, {
    	"key": "resolution",
    	"value": [
    		1920,
    		1200
    	]
    }, {
    	"key": "available_resolution",
    	"value": [
    		1920,
    		1160
    	]
    }, {
    	"key": "timezone_offset",
    	"value": 300
    }, {
    	"key": "timezone",
    	"value": "America/Chicago"
    }, {
    	"key": "session_storage",
    	"value": 1
    }, {
    	"key": "local_storage",
    	"value": 1
    }, {
    	"key": "indexed_db",
    	"value": 1
    }, {
    	"key": "open_database",
    	"value": 1
    }, {
    	"key": "cpu_class",
    	"value": "unknown"
    }, {
    	"key": "navigator_platform",
    	"value": "Win32"
    }, {
    	"key": "regular_plugins",
    	"value": [
    		"Chrome PDF Plugin::Portable Document Format::application/x-google-chrome-pdf~pdf",
    		"Chrome PDF Viewer::::application/pdf~pdf",
    		"Native Client::::application/x-nacl~,application/x-pnacl~"
    	]
    }, {
    	"key": "canvas",
    	"value": "canvas winding:yes~canvas fp:"
    }, {
    	"key": "webgl",
    	"value": "~extensions:ANGLE_instanced_arrays;EXT_blend_minmax;EXT_color_buffer_half_float;EXT_frag_depth;EXT_shader_texture_lod;EXT_texture_filter_anisotropic;WEBKIT_EXT_texture_filter_anisotropic;EXT_sRGB;OES_element_index_uint;OES_standard_derivatives;OES_texture_float;OES_texture_float_linear;OES_texture_half_float;OES_texture_half_float_linear;OES_vertex_array_object;WEBGL_color_buffer_float;WEBGL_compressed_texture_s3tc;WEBKIT_WEBGL_compressed_texture_s3tc;WEBGL_compressed_texture_s3tc_srgb;WEBGL_debug_renderer_info;WEBGL_debug_shaders;WEBGL_depth_texture;WEBKIT_WEBGL_depth_texture;WEBGL_draw_buffers;WEBGL_lose_context;WEBKIT_WEBGL_lose_context~webgl aliased line width range:[1, 1]~webgl aliased point size range:[1, 1024]~webgl alpha bits:8~webgl antialiasing:yes~webgl blue bits:8~webgl depth bits:24~webgl green bits:8~webgl max anisotropy:16~webgl max combined texture image units:32~webgl max cube map texture size:16384~webgl max fragment uniform vectors:1024~webgl max render buffer size:16384~webgl max texture image units:16~webgl max texture size:16384~webgl max varying vectors:30~webgl max vertex attribs:16~webgl max vertex texture image units:16~webgl max vertex uniform vectors:4095~webgl max viewport dims:[16384, 16384]~webgl red bits:8~webgl renderer:WebKit WebGL~webgl shading language version:WebGL GLSL ES 1.0 (OpenGL ES GLSL ES 1.0 Chromium)~webgl stencil bits:0~webgl vendor:WebKit~webgl version:WebGL 1.0 (OpenGL ES 2.0 Chromium)~webgl unmasked vendor:Google Inc.~webgl unmasked renderer:ANGLE (NVIDIA GeForce GTX 660 Ti Direct3D11 vs_5_0 ps_5_0)~webgl vertex shader high float precision:23~webgl vertex shader high float precision rangeMin:127~webgl vertex shader high float precision rangeMax:127~webgl vertex shader medium float precision:23~webgl vertex shader medium float precision rangeMin:127~webgl vertex shader medium float precision rangeMax:127~webgl vertex shader low float precision:23~webgl vertex shader low float precision rangeMin:127~webgl vertex shader low float precision rangeMax:127~webgl fragment shader high float precision:23~webgl fragment shader high float precision rangeMin:127~webgl fragment shader high float precision rangeMax:127~webgl fragment shader medium float precision:23~webgl fragment shader medium float precision rangeMin:127~webgl fragment shader medium float precision rangeMax:127~webgl fragment shader low float precision:23~webgl fragment shader low float precision rangeMin:127~webgl fragment shader low float precision rangeMax:127~webgl vertex shader high int precision:0~webgl vertex shader high int precision rangeMin:31~webgl vertex shader high int precision rangeMax:30~webgl vertex shader medium int precision:0~webgl vertex shader medium int precision rangeMin:31~webgl vertex shader medium int precision rangeMax:30~webgl vertex shader low int precision:0~webgl vertex shader low int precision rangeMin:31~webgl vertex shader low int precision rangeMax:30~webgl fragment shader high int precision:0~webgl fragment shader high int precision rangeMin:31~webgl fragment shader high int precision rangeMax:30~webgl fragment shader medium int precision:0~webgl fragment shader medium int precision rangeMin:31~webgl fragment shader medium int precision rangeMax:30~webgl fragment shader low int precision:0~webgl fragment shader low int precision rangeMin:31~webgl fragment shader low int precision rangeMax:30"
    }, {
    	"key": "webgl_vendor",
    	"value": "Google Inc.~ANGLE (NVIDIA GeForce GTX 660 Ti Direct3D11 vs_5_0 ps_5_0)"
    }, {
    	"key": "adblock",
    	"value": false
    }, {
    	"key": "has_lied_languages",
    	"value": false
    }, {
    	"key": "has_lied_resolution",
    	"value": false
    }, {
    	"key": "has_lied_os",
    	"value": false
    }, {
    	"key": "has_lied_browser",
    	"value": false
    }, {
    	"key": "touch_support",
    	"value": [
    		0,
    		false,
    		false
    	]
    }, {
    	"key": "js_fonts",
    	"value": [
    		"Arial",
    		"Arial Black",
    		"Arial Narrow",
    		"Book Antiqua",
    		"Bookman Old Style",
    		"Calibri",
    		"Cambria",
    		"Cambria Math",
    		"Century",
    		"Century Gothic",
    		"Century Schoolbook",
    		"Comic Sans MS",
    		"Consolas",
    		"Courier",
    		"Courier New",
    		"Georgia",
    		"Helvetica",
    		"Impact",
    		"Lucida Bright",
    		"Lucida Calligraphy",
    		"Lucida Console",
    		"Lucida Fax",
    		"Lucida Handwriting",
    		"Lucida Sans",
    		"Lucida Sans Typewriter",
    		"Lucida Sans Unicode",
    		"Microsoft Sans Serif",
    		"Monotype Corsiva",
    		"MS Gothic",
    		"MS PGothic",
    		"MS Reference Sans Serif",
    		"MS Sans Serif",
    		"MS Serif",
    		"Palatino Linotype",
    		"Segoe Print",
    		"Segoe Script",
    		"Segoe UI",
    		"Segoe UI Light",
    		"Segoe UI Semibold",
    		"Segoe UI Symbol",
    		"Tahoma",
    		"Times",
    		"Times New Roman",
    		"Trebuchet MS",
    		"Verdana",
    		"Wingdings",
    		"Wingdings 2",
    		"Wingdings 3"
    	]
    }, {
    	"key": "audio_fp",
    	"value": "124.0434474653739"
    }, {
    	"key": "enumerate_devices",
    	"value": [
    		"id=default;gid=f82be04d8eb132c3dbdfa1211afca4cf136bfb1fb0220af50bf558ce938e997e;audioinput;",
    		"id=communications;gid=f82be04d8eb132c3dbdfa1211afca4cf136bfb1fb0220af50bf558ce938e997e;audioinput;",
    		"id=e7213bf5974f5fdbad6828fa4edef3f252f03dbb973600d02e70a53d5a8a3b5c;gid=f82be04d8eb132c3dbdfa1211afca4cf136bfb1fb0220af50bf558ce938e997e;audioinput;",
    		"id=default;gid=39f4ee48dcd5536e38f209b0a823e8e84828eb970d1b28732eb28b1914eb6449;audiooutput;",
    		"id=communications;gid=39f4ee48dcd5536e38f209b0a823e8e84828eb970d1b28732eb28b1914eb6449;audiooutput;",
    		"id=909340ed28126ab49541826aa66b05342bd4f802e54060f2693a97bf061847f5;gid=f82be04d8eb132c3dbdfa1211afca4cf136bfb1fb0220af50bf558ce938e997e;audiooutput;",
    		"id=33fea070a04d1555c3e5eb813510f67d568b1dfa5ce8c23f1c0a1b7c588a928e;gid=39f4ee48dcd5536e38f209b0a823e8e84828eb970d1b28732eb28b1914eb6449;audiooutput;",
    		"id=afa406ceddc40601174312fe3f0cf01f35ce9af037ddb67bebdff12e64acee7e;gid=6af833c10bbdf9b95e8333c73973b9b24d345b8db2cc73e1b503711a905eab12;audiooutput;",
    		"id=3282886083804c2657c47e41412b750f5a72673489a30d8b3332f6da20db0d20;gid=36816e053237ba34d9c881d2e52590d49a470a527925bade6a54eb4364cd9084;audiooutput;",
    		"id=ca674b030a9118c8cda10f1b359ace93ff9db5d1efb5c769fbd00864f056f42d;gid=b10682a546ac3bf5439f18e1f0bb8b456022a346f60b30203efbbd0c878e4c13;audiooutput;"
    	]
    }]
    

    28424362516318817b7ee8fe716dc955

    [{
    		"key": "user_agent",
    		"value": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36"
    	},
    	{
    		"key": "language",
    		"value": "en-US"
    	},
    	{
    		"key": "color_depth",
    		"value": 24
    	},
    	{
    		"key": "device_memory",
    		"value": 8
    	},
    	{
    		"key": "hardware_concurrency",
    		"value": 4
    	},
    	{
    		"key": "resolution",
    		"value": [
    			1920,
    			1200
    		]
    	},
    	{
    		"key": "available_resolution",
    		"value": [
    			1920,
    			1160
    		]
    	},
    	{
    		"key": "timezone_offset",
    		"value": 300
    	},
    	{
    		"key": "timezone",
    		"value": "America/Chicago"
    	},
    	{
    		"key": "session_storage",
    		"value": 1
    	},
    	{
    		"key": "local_storage",
    		"value": 1
    	},
    	{
    		"key": "indexed_db",
    		"value": 1
    	},
    	{
    		"key": "open_database",
    		"value": 1
    	},
    	{
    		"key": "cpu_class",
    		"value": "unknown"
    	},
    	{
    		"key": "navigator_platform",
    		"value": "Win32"
    	},
    	{
    		"key": "regular_plugins",
    		"value": [
    			"Chrome PDF Plugin::Portable Document Format::application/x-google-chrome-pdf~pdf",
    			"Chrome PDF Viewer::::application/pdf~pdf",
    			"Native Client::::application/x-nacl~,application/x-pnacl~"
    		]
    	},
    	{
    		"key": "canvas",
    		"value": "canvas winding:yes~canvas fp:"
    	},
    	{
    		"key": "webgl",
    		"value": "~extensions:ANGLE_instanced_arrays;EXT_blend_minmax;EXT_color_buffer_half_float;EXT_frag_depth;EXT_shader_texture_lod;EXT_texture_filter_anisotropic;WEBKIT_EXT_texture_filter_anisotropic;EXT_sRGB;OES_element_index_uint;OES_standard_derivatives;OES_texture_float;OES_texture_float_linear;OES_texture_half_float;OES_texture_half_float_linear;OES_vertex_array_object;WEBGL_color_buffer_float;WEBGL_compressed_texture_s3tc;WEBKIT_WEBGL_compressed_texture_s3tc;WEBGL_compressed_texture_s3tc_srgb;WEBGL_debug_renderer_info;WEBGL_debug_shaders;WEBGL_depth_texture;WEBKIT_WEBGL_depth_texture;WEBGL_draw_buffers;WEBGL_lose_context;WEBKIT_WEBGL_lose_context~webgl aliased line width range:[1, 1]~webgl aliased point size range:[1, 1024]~webgl alpha bits:8~webgl antialiasing:yes~webgl blue bits:8~webgl depth bits:24~webgl green bits:8~webgl max anisotropy:16~webgl max combined texture image units:32~webgl max cube map texture size:16384~webgl max fragment uniform vectors:1024~webgl max render buffer size:16384~webgl max texture image units:16~webgl max texture size:16384~webgl max varying vectors:30~webgl max vertex attribs:16~webgl max vertex texture image units:16~webgl max vertex uniform vectors:4095~webgl max viewport dims:[16384, 16384]~webgl red bits:8~webgl renderer:WebKit WebGL~webgl shading language version:WebGL GLSL ES 1.0 (OpenGL ES GLSL ES 1.0 Chromium)~webgl stencil bits:0~webgl vendor:WebKit~webgl version:WebGL 1.0 (OpenGL ES 2.0 Chromium)~webgl unmasked vendor:Google Inc.~webgl unmasked renderer:ANGLE (NVIDIA GeForce GTX 660 Ti Direct3D11 vs_5_0 ps_5_0)~webgl vertex shader high float precision:23~webgl vertex shader high float precision rangeMin:127~webgl vertex shader high float precision rangeMax:127~webgl vertex shader medium float precision:23~webgl vertex shader medium float precision rangeMin:127~webgl vertex shader medium float precision rangeMax:127~webgl vertex shader low float precision:23~webgl vertex shader low float precision rangeMin:127~webgl vertex shader low float precision rangeMax:127~webgl fragment shader high float precision:23~webgl fragment shader high float precision rangeMin:127~webgl fragment shader high float precision rangeMax:127~webgl fragment shader medium float precision:23~webgl fragment shader medium float precision rangeMin:127~webgl fragment shader medium float precision rangeMax:127~webgl fragment shader low float precision:23~webgl fragment shader low float precision rangeMin:127~webgl fragment shader low float precision rangeMax:127~webgl vertex shader high int precision:0~webgl vertex shader high int precision rangeMin:31~webgl vertex shader high int precision rangeMax:30~webgl vertex shader medium int precision:0~webgl vertex shader medium int precision rangeMin:31~webgl vertex shader medium int precision rangeMax:30~webgl vertex shader low int precision:0~webgl vertex shader low int precision rangeMin:31~webgl vertex shader low int precision rangeMax:30~webgl fragment shader high int precision:0~webgl fragment shader high int precision rangeMin:31~webgl fragment shader high int precision rangeMax:30~webgl fragment shader medium int precision:0~webgl fragment shader medium int precision rangeMin:31~webgl fragment shader medium int precision rangeMax:30~webgl fragment shader low int precision:0~webgl fragment shader low int precision rangeMin:31~webgl fragment shader low int precision rangeMax:30"
    	},
    	{
    		"key": "webgl_vendor",
    		"value": "Google Inc.~ANGLE (NVIDIA GeForce GTX 660 Ti Direct3D11 vs_5_0 ps_5_0)"
    	},
    	{
    		"key": "adblock",
    		"value": false
    	},
    	{
    		"key": "has_lied_languages",
    		"value": false
    	},
    	{
    		"key": "has_lied_resolution",
    		"value": false
    	},
    	{
    		"key": "has_lied_os",
    		"value": false
    	},
    	{
    		"key": "has_lied_browser",
    		"value": false
    	},
    	{
    		"key": "touch_support",
    		"value": [
    			0,
    			false,
    			false
    		]
    	},
    	{
    		"key": "js_fonts",
    		"value": [
    			"Arial",
    			"Arial Black",
    			"Arial Narrow",
    			"Book Antiqua",
    			"Bookman Old Style",
    			"Calibri",
    			"Cambria",
    			"Cambria Math",
    			"Century",
    			"Century Gothic",
    			"Century Schoolbook",
    			"Comic Sans MS",
    			"Consolas",
    			"Courier",
    			"Courier New",
    			"Georgia",
    			"Helvetica",
    			"Impact",
    			"Lucida Bright",
    			"Lucida Calligraphy",
    			"Lucida Console",
    			"Lucida Fax",
    			"Lucida Handwriting",
    			"Lucida Sans",
    			"Lucida Sans Typewriter",
    			"Lucida Sans Unicode",
    			"Microsoft Sans Serif",
    			"Monotype Corsiva",
    			"MS Gothic",
    			"MS PGothic",
    			"MS Reference Sans Serif",
    			"MS Sans Serif",
    			"MS Serif",
    			"Palatino Linotype",
    			"Segoe Print",
    			"Segoe Script",
    			"Segoe UI",
    			"Segoe UI Light",
    			"Segoe UI Semibold",
    			"Segoe UI Symbol",
    			"Tahoma",
    			"Times",
    			"Times New Roman",
    			"Trebuchet MS",
    			"Verdana",
    			"Wingdings",
    			"Wingdings 2",
    			"Wingdings 3"
    		]
    	},
    	{
    		"key": "audio_fp",
    		"value": "124.0434474653739"
    	},
    	{
    		"key": "enumerate_devices",
    		"value": [
    			"id=default;gid=eccafc7405b2c75ee94f00ce79fa8debcee30fa1ced593c2dc95fcc42444d7f2;audioinput;",
    			"id=communications;gid=eccafc7405b2c75ee94f00ce79fa8debcee30fa1ced593c2dc95fcc42444d7f2;audioinput;",
    			"id=e7213bf5974f5fdbad6828fa4edef3f252f03dbb973600d02e70a53d5a8a3b5c;gid=eccafc7405b2c75ee94f00ce79fa8debcee30fa1ced593c2dc95fcc42444d7f2;audioinput;",
    			"id=default;gid=6f14b30d9aea340330f460f22d636fe727b17d7efd7e5d9e66aaeaccbef91559;audiooutput;",
    			"id=communications;gid=6f14b30d9aea340330f460f22d636fe727b17d7efd7e5d9e66aaeaccbef91559;audiooutput;",
    			"id=909340ed28126ab49541826aa66b05342bd4f802e54060f2693a97bf061847f5;gid=eccafc7405b2c75ee94f00ce79fa8debcee30fa1ced593c2dc95fcc42444d7f2;audiooutput;",
    			"id=33fea070a04d1555c3e5eb813510f67d568b1dfa5ce8c23f1c0a1b7c588a928e;gid=6f14b30d9aea340330f460f22d636fe727b17d7efd7e5d9e66aaeaccbef91559;audiooutput;",
    			"id=afa406ceddc40601174312fe3f0cf01f35ce9af037ddb67bebdff12e64acee7e;gid=83f68f6880d29e8dc0f58b32ce711abf982646071fa01f5cfd7432c3867ddeb3;audiooutput;",
    			"id=3282886083804c2657c47e41412b750f5a72673489a30d8b3332f6da20db0d20;gid=4732261d95c26daf4bf14ee3dd7e2ce2c308ea09a9e1f7555634569cb9b23229;audiooutput;",
    			"id=ca674b030a9118c8cda10f1b359ace93ff9db5d1efb5c769fbd00864f056f42d;gid=691fcee7940916c24d2b8a85b694668c9dc93ef096da1275a6918b4eb16c5e67;audiooutput;"
    		]
    	}
    ]
    

    [X ] I can reproduce the bug in [fingerprintjs master]

    Minimal reproducing example

    [ X] I can reproduce the bug with this jsfiddle: https://jsfiddle.net/L2gLq4rg/ [ ] Alternatively, I have provided a jsfiddle that reproduces the bug here:

    help wanted needinfo 
    opened by mtstedman 23
  • Fingerprint changes due to switching between GPUs

    Fingerprint changes due to switching between GPUs

    Update: See https://github.com/Valve/fingerprintjs2/issues/226#issuecomment-336246243 for the probable cause

    Hi!

    Sometimes i do find website visitors who i identified using a cookie.

    In their Sessions, the do have identical Fingerprints, but the Hash-Value is not identical.

    Did anyone else notice this, and what might be an explaination for this?

    enhancement help wanted hard 
    opened by mhasenberg 23
  • Different WebGL values on devices

    Different WebGL values on devices

    I don't have with devices.

    1. different webgl bits User-Agent: Mozilla/5.0 (Linux; Android 4.4.2; ASUS_T00J Build/KVT49L) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.83 Mobile Safari/537.36

    "key":"webgl","value":" ... ~webgl alpha bits:8~webgl antialiasing:yes~webgl blue bits:8~webgl depth bits:16~webgl green bits:8~ ...

    "key":"webgl","value":" ... ~webgl alpha bits:0~webgl antialiasing:yes~webgl blue bits:0~webgl depth bits:0~webgl green bits:0~ ...

    1. different canvas User-Agent: Mozilla/5.0 (Linux; Android 5.0.1; GT-I9500 Build/LRX22C) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.76 Mobile Safari/537.36

    "key":"webgl","value":" ... "key":"webgl","value":" ...

    1. different canvas User-Agent: Mozilla/5.0 (Linux; Android 4.2.2; IdeaTab S6000-H Build/JDQ39) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.83 Safari/537.36
    opened by alexber220 23
  • Why does the same browser generate two fingerprint IDS?

    Why does the same browser generate two fingerprint IDS?

    image

    const fpPromise = import('./esm.min.js')
                .then(FingerprintJS => FingerprintJS.load());
              fpPromise
                .then(fp => fp.get())
                .then(result => {
                  const visitorId = result.visitorId
                  console.log(visitorId);
                  document.write(visitorId);
                })
                .catch(error => console.error(error))
    
    opened by cnwp007 21
  • Fingerprint UUID is different on initial page load (and when refreshing without cache)

    Fingerprint UUID is different on initial page load (and when refreshing without cache)

    (I couldn't find any previous issues regarding this) This is happening with all major browsers on both Windows 10 and macOS High Sierra.

    Upon the first page load, a particular fingerprint UUID is given. However, after every subsequent load, the fingerprint UUID is different (and will remain constant with each normal refresh).

    However - if you shift-reload the page, the UUID goes back to the original one that was first given on first load.

    Does this have something to do with items being cached? I can't get it to output a consistent UUID between first load and subsequent loads. (and obviously, the first load will generally be pretty important).

    opened by Hypermedia 20
  • Improve the available screen resolution component

    Improve the available screen resolution component

    Resolves #568

    • The component is disabled in browsers where it's unstable or gives no information. It's enabled in: Chrome ≤ 83 on Windows, Firefox on Windows, IE, pre-chromium Edge, Chrome 57–78 on macOS, Safari ≤11 on macOS. Approximate share of such users is 9.3% and it decreases. See raw research data at https://github.com/fingerprintjs/fingerprintjs/issues/568#issuecomment-722272726.
    • Top-left corner position of available screen is added.
    • The dimensions are rounded by 10 pixels to mitigate small random changes of the position (e.g. 1900x1440 → 1900x1439, the reason and steps to reproduce are unknown).

    This PR will change every visitor identifier.

    opened by Finesse 19
  • How is it used in Chrome Extensions with manifest V3?

    How is it used in Chrome Extensions with manifest V3?

    Scenario

    • We were using @fingerprintjs/fingerprintjs-pro in our chrome extension and didn't experience any issues with the chrome manifest V2. As of January 2023, chrome requires that manifest v3 be used and one of the restrictions is the impossibility of loading external JS files (as requested by fingerprint in the documentation). This impossibility is because in mv3, chrome limits the possible values of the content_security_policy: Chrome Documentation. Is it possible to use fingerprintjs without the need to import a JS dynamically? An important fact, our apiKey is dynamic.

    • Device: Browser - Chrome

    • Version: @fingerprintjs/fingerprintjs-pro 3.7.1

    Fingerprint data

    Visitor identifier: 4c92206b6c3bc6d96d2068fd3b615018 Time took to get the identifier: 366ms Confidence: {"score":0.5,"comment":"0.995 if upgrade to Pro: https://fpjs.dev/pro"} User agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36

    opened by nicolaswww 1
  • Amend the readme

    Amend the readme

    • Remove an unused image
    • Split the description from the accuracy note. I think it's important to have a simple answer to a "why may I need this" question. A single short paragraph is used for this.
    • Move a link to a React usage example from the Pro section to an OSS section. Also change the icon to an emoji resembling React logo.
    • Stick to the common file naming style
    • Add timestamps to the Pro response example
    • Hide a Pro response example under a spoiler, because it's bulky, and an example is already given on the Pro picture
    • Change "FingerprintJS Pro" to "Fingerprint Pro"
    opened by Finesse 1
  • Can I specify parameters to use when generating fingerprints with fingerprint.js?

    Can I specify parameters to use when generating fingerprints with fingerprint.js?

    Hello fingerprintsjs team. Let me ask you one question.

    Is it possible to specify parameters to use when generating fingerprints with fingerprint.js? For example, "do not use the language setting of the browser".

    opened by mule-engineer13 5
  • NotSupportError - The operation is not supported in Safari on IOS 16

    NotSupportError - The operation is not supported in Safari on IOS 16

    Scenario

    • It is happened DOM Exception: NotSupportError - The operation is not supported in Safari on IOS 16
    • Iphone with IOS 16 on Safari
    • FingerprintJS v3.3.6

    Fingerprint Data

    Mozilla/5.0 (iPhone; CPU iPhone OS 16_0_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.0 Mobile/15E148 Safari/604.1

    needinfo 
    opened by chuotnhat1985 3
  • Incognito tests with Selenium

    Incognito tests with Selenium

    Since you were not able to run tests in incognito/private mode with Karma at BrowserStack (https://github.com/fingerprintjs/fingerprintjs/issues/560) you might want to consider the following solution that depends on Selenium and BrowserStack. I'm not sure what a complete test runner you meant in https://github.com/fingerprintjs/fingerprintjs/issues/563#issuecomment-817458927 but I think that my solution could be a good starting point.

    opened by rafalku 0
  • Unstable 'hdr' entropy source in Safari

    Unstable 'hdr' entropy source in Safari

    Scenario

    • What causes the fingerprint to change?

    unstable 'hdr' entropy source

    • What device and browser are you using?

    iOS 15.6.1 with Safari

    Mozilla/5.0 (iPhone; CPU iPhone OS 15_6_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.6.1 Mobile/15E148 Safari/604.1
    
    • What version of FingerprintJS are you using?

    FingerprintJS v3.3.5

    Fingerprint data

    Seems like the hdr entropy source is not stable in Safari, after two days when I check the result.visitorId in my iPhone, it's changed, the diff is here: https://www.diffchecker.com/ts58uNPT

    bug 
    opened by tvvocold 1
Releases(v3.3.6)
  • v3.3.6(Sep 8, 2022)

  • v3.3.5(Aug 23, 2022)

    • Obfuscate the inappropriate selectors in the distributive code of the library (#803)

      Note: this change is for automated analyzers and beginner security researches. FingerprintJS doesn't put any ads, links or other content on your website. You can learn how we use advertisement selectors in a blog post.

    Source code(tar.gz)
    Source code(zip)
  • v3.3.4(Jul 29, 2022)

  • v3.3.3(Feb 24, 2022)

  • v3.3.2(Dec 22, 2021)

  • v3.3.1(Dec 8, 2021)

    Important:

    • Add an AJAX request that collects installation statistics. The request is performed only by version installed from NPM. See the documentation is you want to turn it off. (#709)

    Miscellaneous:

    • Move some top level declarations to improve tree-shaking (#700)
    • Actualize the environment detection functions (#701)
    • Actualize the list of supported browsers (#713)
    • fix: An indefinite setTimeout loop in Firefox (#717)
    • Actualize the list of DOM blockers (#719)
    Source code(tar.gz)
    Source code(zip)
  • v3.3.0(Jul 29, 2021)

    • Add a new result field: confidence score (#689). The confidence score field tells how much the agent is sure about the visitor identifier. See the API reference for more details.
    • Actualize the list of DOM blockers
    • Fix an error that occurs in Firefox Add-ons (#684)
    • Handle missing iframe.contentWindow.document, for example in JSDOM (#686)

    The visitor identifiers are compatible with version 3.2.0.

    Source code(tar.gz)
    Source code(zip)
  • v3.2.0(Jun 23, 2021)

    • Make the entropy sources start running in load function (#678). It will make get run much faster when some time passes between calling load() and get(). See an example in the quick start guide.

    The visitor identifiers are compatible with version 3.1.0.

    Source code(tar.gz)
    Source code(zip)
  • v3.1.3(Jun 14, 2021)

  • v3.1.2(May 11, 2021)

  • v3.1.1(Apr 28, 2021)

  • v3.1.0(Apr 13, 2021)

    • Make the entropy sources run in parallel (#622)
    • Update the set of entropy sources. It will change fingerprint for all visitors. The documented JS API stays the same.
      • Replace the availableScreenResolution entropy source with screenFrame that is more stable (#585)
      • Combine the timezone and timezoneOffset sources into a single source because timezoneOffset gives no entropy when timezone is available
      • Stabilize the canvas entropy source (#574)
      • Split the canvas image into 2 images (https://github.com/fingerprintjs/fingerprintjs/issues/583#issuecomment-792758292, https://github.com/fingerprintjs/fingerprintjs/issues/103#issuecomment-809881647)
      • Distinguish cases where hardware concurrency is unavailable and where it's known to equal 1
      • Enable the plugins entropy source in IE
      • Remove the following entropy sources because they give no entropy in combination to other sources: pluginsSupport, productSub, emptyEvalLength and errorFF
      • Fix the incorrect platform value when desktop mode is requested in an iOS browser (#609)
      • Replace the chrome source with the vendorFlavors source that checks many vendor-specific variables (#621)
      • Add a DOM blockers entropy source (387eb8384c10c180d54a7f9cc58df4630c71becb)
      • Add a set of CSS media query entropy sources (d1c3ccf0b29f8753c9c9e71b487567c14b66f9c8)
      • Add a math entropy source (8e3a6a8d6ddfc431279b2652dde064ce5894b118)
      • Add a font preferences entropy source (5306b58842ec9534acf65ac0746a6b5d361d5239)
    Source code(tar.gz)
    Source code(zip)
  • v3.0.7(Apr 2, 2021)

    • fix: Canvas fingerprint depends on the script encoding (#588)
    • Improve the audio entropy source performance (3201a7d61bb4df2816c226d8364cc98bb4235e59)
    • Encapsulate the fonts entropy source so that it doesn't affect and isn't affected by the page style (#635)
    • Return the version together with the visitor identifier (db55bedfde7cfd50a0ad756bbeef7b2d831505c9)
    Source code(tar.gz)
    Source code(zip)
  • v2.1.5(Apr 2, 2021)

  • v3.0.6(Feb 9, 2021)

    • Actualize the productSub component TypeScript type (the component value is undefined in IE)
    • Make FingerprintJS work in server side rendering environments like Next.js and Gatsby (#610)
    Source code(tar.gz)
    Source code(zip)
  • v3.0.5(Jan 8, 2021)

  • v3.0.4(Dec 18, 2020)

  • v3.0.3(Nov 11, 2020)

  • v3.0.1(Nov 2, 2020)

    • Support elder browsers like IE 11, Chrome 42 and Firefox 48 (a Promise polyfill is required, see the browser support guide to learn more) (#577)
    • Handle cases where new Date().getTimezoneOffset() returns a string (#577)
    • fix: The timezoneOffset component changes due to DST shifts (#577)
    Source code(tar.gz)
    Source code(zip)
  • v3.0.0(Oct 16, 2020)

    The library has been rewritten in TypeScript from scratch, has got a modular code structure and various shipping formats.

    • See the readme to get familiar with the new installation methods and the new API.
    • See the migration guide to learn how to migrate to from version 2 to version 3.
    • The wiki has moved to the v2 branch.
    Source code(tar.gz)
    Source code(zip)
  • 2.1.4(Sep 17, 2020)

    • #376 Use a more reliable addBehavior check implementation (#544)
    • #481 Fix the undefined timezone component result in IE11 (#546). It will change fingerprint in IE11.
    • Drop the IE 9 and older support officially (the library didn't work there anyway)
    • #405 Exclude the adBlock component in the default options
    • #438 Fix fingerprint difference between normal and private modes in IE and Edge. It will change fingerprint in IE and Edge.
    Source code(tar.gz)
    Source code(zip)
  • 2.1.2(Sep 7, 2020)

    • #176 Fix console error on too many active WEBGL contexts (#484)
    • #485 IE8 compatibility
    • Various changes dealing with false positives on hasLiedOs() and hasLiedBrowser() (#499)
    Source code(tar.gz)
    Source code(zip)
  • 2.1.1(Sep 7, 2020)

  • 2.1.0(May 18, 2019)

    Note: This version's fingerprints may be different from the previous version's fingerprints.

    • Add navigator.webdriver component (https://github.com/Valve/fingerprintjs2/pull/433)
    • Fixes
    Source code(tar.gz)
    Source code(zip)
  • 2.0.0(Oct 9, 2018)

    Note: This version's fingerprints may be different from the previous version's fingerprints.

    Breaking changes to usage! See https://github.com/Valve/fingerprintjs2#upgrade-guide-from-182-to-200 for details.

    Other changes:

    • Add enumerateDevices support (#350)
    • Exclude audio fingerprint on iOS 11 by default (#342)
    • Add timezone component (#364)
    • Exclude enumerateDevices component by default (unreliable on Windows)
    Source code(tar.gz)
    Source code(zip)
  • 1.8.0(Apr 9, 2018)

    Note: This version's fingerprints may be different from the previous version's fingerprints.

    • Fix #311 Different fingerprint on zoom: Exclude devicePixelRatio from fingerprinting by default.
    • Fix #312 Typo in CSS property name
    Source code(tar.gz)
    Source code(zip)
  • 1.7.0(Mar 21, 2018)

    Note: This version's fingerprints may be different from the previous version's fingerprints.

    • Improve font detection: #300, #284
    • Improve incognito mode fingerprinting: Disable Do Not Track component by default (cf412ddc5bade2269de6fae25c5f575e0194b62f)
    • Fix bug: #301
    Source code(tar.gz)
    Source code(zip)
  • 1.6.1(Jan 23, 2018)

    Note: This version's fingerprints may be different from the previous version's fingerprints.

    • Add preprocessor option
    • Add webglVendorAndRenderer component
    • Add navigator.deviceMemory support
    • Add Google closure compiler support
    • Handle anti-canvas fingerprinting extensions
    • Fix loads of bugs
    Source code(tar.gz)
    Source code(zip)
  • 1.5.0(Feb 8, 2017)

Owner
FingerprintJS
Fraud detection API for the Internet
FingerprintJS
SiJago - GraphQL Client for Browser and Node.js

SiJago is GraphQL Client for Browser and Node.js, You can write request GraphQL schema using JavaScript Object Style, Why i create this tools, Because for reducing typo when writing GraphQL schema using HTTP client like Axios, Fetch or GraphQL client using Apollo and also to simplify calling the GraphQL schema easy to understand for human.

Restu Wahyu Saputra 7 Mar 13, 2022
🌳 Tiny & elegant JavaScript HTTP client based on the browser Fetch API

Huge thanks to for sponsoring me! Ky is a tiny and elegant HTTP client based on the browser Fetch API Ky targets modern browsers and Deno. For older b

Sindre Sorhus 8.5k Jan 2, 2023
a browser detector

Bowser A small, fast and rich-API browser/platform/engine detector for both browser and node. Small. Use plain ES5-version which is ~4.8kB gzipped. Op

Denis Demchenko 5.2k Jan 2, 2023
A Featureful File Browser for Cockpit

Cockpit Navigator A Featureful File System Browser for Cockpit - remotely browse, manage, edit, upload, and download files on your server through your

45Drives 226 Dec 27, 2022
The perfect library for adding search, sort, filters and flexibility to tables, lists and various HTML elements. Built to be invisible and work on existing HTML.

List.js Perfect library for adding search, sort, filters and flexibility to tables, lists and various HTML elements. Built to be invisible and work on

Jonny Strömberg 10.9k Jan 1, 2023
Drag and drop library for two-dimensional, resizable and responsive lists

GridList Drag and drop library for a two-dimensional resizable and responsive list of items Demo: http://hootsuite.github.io/grid/ The GridList librar

Hootsuite 3.6k Dec 14, 2022
A high-performance, dependency-free library for animated filtering, sorting, insertion, removal and more

MixItUp 3 MixItUp is a high-performance, dependency-free library for animated DOM manipulation, giving you the power to filter, sort, add and remove D

Patrick Kunka 4.5k Dec 24, 2022
JavaScript Survey and Form Library

SurveyJS is a JavaScript Survey and Form Library. SurveyJS is a modern way to add surveys and forms to your website. It has versions for Angular, jQue

SurveyJS 3.5k Jan 1, 2023
Extensive math expression evaluator library for JavaScript and Node.js

?? Homepage Fcaljs is an extensive math expression evaluator library for JavaScript and Node.js. Using fcal, you can perform basic arithmetic, percent

Santhosh Kumar 93 Dec 19, 2022
autoNumeric is a standalone library that provides live as-you-type formatting for international numbers and currencies.

What is autoNumeric? autoNumeric is a standalone Javascript library that provides live as-you-type formatting for international numbers and currencies

AutoNumeric 1.7k Dec 16, 2022
A platform detection library.

Platform.js v1.3.6 A platform detection library that works on nearly all JavaScript platforms. Disclaimer Platform.js is for informational purposes on

BestieJS Modules 3.1k Dec 31, 2022
A benchmarking library. As used on jsPerf.com.

Benchmark.js v2.1.4 A robust benchmarking library that supports high-resolution timers & returns statistically significant results. As seen on jsPerf.

BestieJS Modules 5.3k Dec 28, 2022
A wrapper library for Jitsi Meet that adds audio spatialization, to be able to create virtual meeting rooms.

A wrapper library for Jitsi Meet that adds audio spatialization, to be able to create virtual meeting rooms.

Sean T. McBeth 1.1k Dec 27, 2022
Solid.js library adding signaling to built-in non-primitives

This package provides signaled versions of Javascript's built-in objects. Thanks to it, all theirs properties will be automatically tracked while using standard API.

Maciej Kwaśniak 40 Dec 29, 2022
This library was designed to be used in SPA framework wrappers for the FingerprintJS Pro Javascript Agent

Framework-agnostic SPA service wrapper. Use it to build a FingerprintJS Pro wrapper for your favorite framework.

FingerprintJS 12 Sep 3, 2022
ChelseaJS - a Javascript library for creative, generative Coding

ChelseaJS is a Javascript library for creative, generative Coding. It's simple and intuitive syntax makes it easy for everyone (including non-coders)

Prakrisht Dahiya 26 Oct 6, 2022
Estrela - a JavaScript library for building reactive web components inspired by lit

Estrela ⭐ Full Reactive Web Components Estrela is a JavaScript library for building reactive web components inspired by lit. Just like Lit, Estrela is

null 50 Oct 31, 2022
📝 Algorithms and data structures implemented in JavaScript with explanations and links to further readings

JavaScript Algorithms and Data Structures This repository contains JavaScript based examples of many popular algorithms and data structures. Each algo

Oleksii Trekhleb 158k Dec 31, 2022
A lightweight jQuery plugin for collapsing and expanding long blocks of text with "Read more" and "Close" links.

Readmore.js V3 alpha I am deprecating the 2.x version of Readmore.js. A new version is coming soon! Check it out and help me test it! Readmore.js A sm

Jed Foster 1.5k Nov 30, 2022