(using_from_javascript)= # Using Pyodide from Javascript This document describes using Pyodide directly from Javascript. ## Startup To include Pyodide in your project you can use the following CDN URL, https://cdn.jsdelivr.net/pyodide/v0.17.0a2/full/pyodide.js You can also download a release from [Github releases](https://github.com/pyodide/pyodide/releases) (or build it yourself), include its contents in your distribution, and import the `pyodide.js` file there from a ` Pyodide test page
Open your browser console to see Pyodide output ``` ## Alternative Example ```html

You can execute any Python code. Just enter something in the box below and click the button.



Output:
``` ## Accessing Python scope from Javascript You can also access from Javascript all functions and variables defined in Python by using the {any}`pyodide.globals` object. For example, if you run the code `x = numpy.ones([3,3])` in Python, you can access the variable ``x`` from Javascript in your browser's developer console as `pyodide.globals.get("x")`. The same goes for functions and imports. See {ref}`type-translations` for more details. You can try it yourself in the browser console: ```js pyodide.runPython(`import numpy`); pyodide.runPython(`x=numpy.ones((3, 4))`); pyodide.globals.get('x').toJs(); // >>> [ Float64Array(4), Float64Array(4), Float64Array(4) ] // create the same 3x4 ndarray from js x = pyodide.globals.get('numpy').ones(new Int32Array([3, 4])).toJs(); // x >>> [ Float64Array(4), Float64Array(4), Float64Array(4) ] ``` Since you have full access to Python global scope, you can also re-assign new values or even Javascript functions to variables, and create new ones from Javascript: ```js // re-assign a new value to an existing variable pyodide.globals.set("x", 'x will be now string'); // create a new js function that will be available from Python // this will show a browser alert if the function is called from Python pyodide.globals.set("alert", alert); // this new function will also be available in Python and will return the squared value. pyodide.globals.set("square", x => x*x); // You can test your new Python function in the console by running pyodide.runPython(`square(3)`); ``` Feel free to play around with the code using the browser console and the above example. ## Accessing Javascript scope from Python The Javascript scope can be accessed from Python using the `js` module (see {ref}`type-translations_using-js-obj-from-py`). This module represents the global object `window` that allows us to directly manipulate the DOM and access global variables and functions from Python. ```python import js div = js.document.createElement("div") div.innerHTML = "

This element was created from Python

" js.document.body.prepend(div) ``` See {ref}`serving_pyodide_packages` to distribute Pyodide files locally.