#object #nodejs #global #web #documentation #mozilla #developer

no-std js-sys

Bindings for all JS global objects and functions in all JS environments like Node.js and browsers, built on #[wasm_bindgen] using the wasm-bindgen crate

87 releases

new 0.3.77 Jan 12, 2025
0.3.76 Dec 7, 2024
0.3.74 Nov 30, 2024
0.3.69 Mar 4, 2024
0.2.0 Jul 26, 2018

#6 in WebAssembly

Download history 1233831/week @ 2024-09-27 1310091/week @ 2024-10-04 1291626/week @ 2024-10-11 1333474/week @ 2024-10-18 1331281/week @ 2024-10-25 1264822/week @ 2024-11-01 1257955/week @ 2024-11-08 1283254/week @ 2024-11-15 1149279/week @ 2024-11-22 1235094/week @ 2024-11-29 1363543/week @ 2024-12-06 1309155/week @ 2024-12-13 716214/week @ 2024-12-20 705545/week @ 2024-12-27 1217216/week @ 2025-01-03 1338087/week @ 2025-01-10

4,201,791 downloads per month
Used in 38,613 crates (1,223 directly)

MIT/Apache

500KB
6K SLoC

js-sys

API documentation

Raw bindings to JS global APIs for projects using wasm-bindgen. This crate is handwritten and intended to work in all JS environments like browsers and Node.js.


lib.rs:

Bindings to JavaScript's standard, built-in objects, including their methods and properties.

This does not include any Web, Node, or any other JS environment APIs. Only the things that are guaranteed to exist in the global scope by the ECMAScript standard.

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects

A Note About camelCase, snake_case, and Naming Conventions

JavaScript's global objects use camelCase naming conventions for functions and methods, but Rust style is to use snake_case. These bindings expose the Rust style snake_case name. Additionally, acronyms within a method name are all lower case, where as in JavaScript they are all upper case. For example, decodeURI in JavaScript is exposed as decode_uri in these bindings.

Dependencies

~0.6–1.2MB
~24K SLoC