diff --git a/examples/web/react/components/button/button.tsx b/examples/web/react/components/button/button.tsx
index 8e26fb5d425d5113dfab94027feea8d205495d62..21adf1062f478afc7bd8f5bc6fccba32bcc2c2fe 100644
--- a/examples/web/react/components/button/button.tsx
+++ b/examples/web/react/components/button/button.tsx
@@ -43,13 +43,28 @@ export const Button: FC<ButtonProps> = ({
         onFile && onFile(file);
         event.target.value = "";
     };
+    const onKeyPress = (event: React.KeyboardEvent) => {
+        if (event.key == "Enter") {
+            onClick && onClick();
+        }
+    };
     const renderSimple = () => (
-        <span className={classes()} onClick={onClick}>
+        <span
+            className={classes()}
+            onClick={onClick}
+            onKeyPress={onKeyPress}
+            tabIndex={0}
+        >
             {text}
         </span>
     );
     const renderComplex = () => (
-        <span className={classes()} onClick={onClick}>
+        <span
+            className={classes()}
+            onClick={onClick}
+            onKeyPress={onKeyPress}
+            tabIndex={0}
+        >
             {image && <img src={image} alt={imageAlt || text || "button"} />}
             {file && (
                 <input type="file" accept={accept} onChange={onFileChange} />