{"id":13450744,"url":"https://github.com/quisido/use-force-update","last_synced_at":"2025-08-21T10:31:38.624Z","repository":{"id":33200733,"uuid":"154867600","full_name":"quisido/use-force-update","owner":"quisido","description":"React Hook to force your function component to update","archived":false,"fork":false,"pushed_at":"2023-01-11T18:28:42.000Z","size":2710,"stargazers_count":182,"open_issues_count":0,"forks_count":11,"subscribers_count":5,"default_branch":"main","last_synced_at":"2024-05-10T18:58:12.377Z","etag":null,"topics":["hook","javascript","npm","npmjs","react","react-hooks","reactjs","typescript"],"latest_commit_sha":null,"homepage":"https://www.npmjs.com/package/use-force-update","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/quisido.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null},"funding":{"github":"CharlesStover"}},"created_at":"2018-10-26T17:05:46.000Z","updated_at":"2024-05-09T14:40:06.000Z","dependencies_parsed_at":"2023-01-15T00:00:20.860Z","dependency_job_id":null,"html_url":"https://github.com/quisido/use-force-update","commit_stats":null,"previous_names":["quisido/use-force-update","charlesstover/use-force-update"],"tags_count":2,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/quisido%2Fuse-force-update","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/quisido%2Fuse-force-update/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/quisido%2Fuse-force-update/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/quisido%2Fuse-force-update/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/quisido","download_url":"https://codeload.github.com/quisido/use-force-update/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":230507051,"owners_count":18236944,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["hook","javascript","npm","npmjs","react","react-hooks","reactjs","typescript"],"created_at":"2024-07-31T07:00:37.918Z","updated_at":"2024-12-19T22:08:31.429Z","avatar_url":"https://github.com/quisido.png","language":"JavaScript","funding_links":["https://github.com/sponsors/CharlesStover"],"categories":["Packages"],"sub_categories":[],"readme":"# useForceUpdate\n[![version](https://img.shields.io/npm/v/use-force-update.svg)](https://www.npmjs.com/package/use-force-update)\n[![minzipped size](https://img.shields.io/bundlephobia/minzip/use-force-update.svg)](https://www.npmjs.com/package/use-force-update)\n[![downloads](https://img.shields.io/npm/dt/use-force-update.svg)](https://www.npmjs.com/package/use-force-update)\n[![build](https://github.com/CharlesStover/use-force-update/actions/workflows/use-force-update.yml/badge.svg?branch=main\u0026event=push)](https://github.com/CharlesStover/use-force-update/actions/workflows/use-force-update.yml)\n\n`useForceUpdate` is a React Hook that forces your function component to\nre-render.\n\n`useForceUpdate` does not serve a purpose in and of itself. It is a tiny\npackage that aims to be integrated into larger hooks, making obsolete any class\nfunctionality that is still reliant on `this.forceUpdate()`.\n\n## Install\n\n* `npm install use-force-update` or\n* `yarn add use-force-update`\n\n## Use\n\nIn its simplest form, `useForceUpdate` re-renders a component.\n\n```jsx\nimport useForceUpdate from 'use-force-update';\n\nlet renderCount = 0;\n\nexport default function MyButton() {\n  const forceUpdate = useForceUpdate();\n\n  renderCount++;\n  return (\n    \u003c\u003e\n      \u003cp\u003eI have rendered {renderCount} times.\u003c/p\u003e\n      \u003cbutton onClick={forceUpdate}\u003e\n        Re-render\n      \u003c/button\u003e\n    \u003c/\u003e\n  );\n};\n```\n\nIn its ideal form, `useForceUpdate` integrates with event emitters, such as\nstate managers.\n\n```jsx\nimport { useEffect } from 'react';\nimport useForceUpdate from 'use-force-update';\nimport store from './store';\n\nexport default function MyButton() {\n  const forceUpdate = useForceUpdate();\n\n  const username = store.get('username');\n\n  useEffect(() =\u003e {\n    // When the username changes, re-render this component.\n    const selector = state =\u003e state.username;\n    const unsubscribe = store.subscribe(selector, forceUpdate);\n\n    // When we unmount, stop re-rendering this component.\n    return () =\u003e {\n      unsubscribe();\n    };\n  }, [forceUpdate]);\n\n  if (username === null) {\n    return \u003cp\u003eYou are not logged in.\u003c/p\u003e;\n  }\n\n  return \u003cp\u003eHello, {username}!\u003c/p\u003e;\n};\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fquisido%2Fuse-force-update","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fquisido%2Fuse-force-update","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fquisido%2Fuse-force-update/lists"}