mirror of
https://github.com/dergigi/boris.git
synced 2025-12-17 22:54:30 +01:00
- Add project structure with TypeScript, React, and Vite - Implement nostr authentication using browser extension (NIP-07) - Add NIP-51 compliant bookmark fetching and display - Create minimal UI with login and bookmark components - Integrate applesauce-core and applesauce-react libraries - Add responsive styling with dark/light mode support - Include comprehensive README with setup instructions This is a minimal MVP for a nostr bookmark client that allows users to view their bookmarks according to NIP-51 specification.
61 lines
1.1 KiB
Markdown
61 lines
1.1 KiB
Markdown
# `react-dom`
|
|
|
|
This package serves as the entry point to the DOM and server renderers for React. It is intended to be paired with the generic React package, which is shipped as `react` to npm.
|
|
|
|
## Installation
|
|
|
|
```sh
|
|
npm install react react-dom
|
|
```
|
|
|
|
## Usage
|
|
|
|
### In the browser
|
|
|
|
```js
|
|
import { createRoot } from 'react-dom/client';
|
|
|
|
function App() {
|
|
return <div>Hello World</div>;
|
|
}
|
|
|
|
const root = createRoot(document.getElementById('root'));
|
|
root.render(<App />);
|
|
```
|
|
|
|
### On the server
|
|
|
|
```js
|
|
import { renderToPipeableStream } from 'react-dom/server';
|
|
|
|
function App() {
|
|
return <div>Hello World</div>;
|
|
}
|
|
|
|
function handleRequest(res) {
|
|
// ... in your server handler ...
|
|
const stream = renderToPipeableStream(<App />, {
|
|
onShellReady() {
|
|
res.statusCode = 200;
|
|
res.setHeader('Content-type', 'text/html');
|
|
stream.pipe(res);
|
|
},
|
|
// ...
|
|
});
|
|
}
|
|
```
|
|
|
|
## API
|
|
|
|
### `react-dom`
|
|
|
|
See https://reactjs.org/docs/react-dom.html
|
|
|
|
### `react-dom/client`
|
|
|
|
See https://reactjs.org/docs/react-dom-client.html
|
|
|
|
### `react-dom/server`
|
|
|
|
See https://reactjs.org/docs/react-dom-server.html
|