![](/img/trans.png)
[英]VueJS JSX: How can I listen to a "Click" event on a render function?
[英]How can I render some JSX with onClick event?
因此,當用戶按下按鈕時,我嘗試渲染一些 JSX,我嘗試通過 onClick 執行此操作,但它不起作用,JSX 不會在屏幕上渲染。 有沒有辦法做到這一點? 我的代碼是這樣的:
function RandomScreen() {
async function HandleClick() {
// make API post request
.then(function(response) {
return (<h1>{response.data}</h1>)
})
}
return (
<button onClick={HandleClick}>Click me</button>
)
}
我想你正在尋找這樣的東西:
function RandomScreen() {
const [data, setData] = useState(null);
async function HandleClick() {
fetch("https://jsonplaceholder.typicode.com/todos/1")
.then((response) => response.json())
.then((json) => {
console.log(json);
setData(json);
});
}
return (
<button onClick={HandleClick}>
Click me
{data && <h1>{JSON.stringify(data, null, 2)}</h1>}
</button>
);
}
例如,將您的數據存儲在 state
const [data, setData] = React.useState();
...
.then(function(response) {
setData(response.data);
})
在 JSX 中你可以處理顯示部分:
{data && <h1>{data}</h1>}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.