React 未在 html 上加载
React not loading on html
我正在尝试向没有节点的 html 页面添加反应。
function Hello(){
return (
<div>
<p>Hello World</p>
</div>
)
}
ReactDOM.render(<Hello />, document.getElementById('root'))
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>React</title>
</head>
<body>
<div id="root"></div>
</body>
<script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
<script src="https://unpkg.com/react@18/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@18/umd/react-dom.development.js"></script>
<script type="text/babel" src="main.js"></script>
</html>
main.js就是javascript。
你能帮我解决这个问题吗?
谢谢
也许如果您将脚本放在 <body>
中,它可能会起作用,因为必须加载元素才能被选择器找到。
例如:
<body>
<div id="root"></div>
<!-- Scripts Here -->
</body>
在我的浏览器 (Firefox) 中有效!
使用ReactDOM.createRoot(rootNode).render(<App />);
参考- https://17.reactjs.org/docs/concurrent-mode-reference.html#createroot
好吧,我不知道为什么会发生这种情况,但只有当反应代码在另一个文件中时才会发生这种情况。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>React</title>
</head>
<body>
<div id="root"></div>
<div id="ot"></div>
</body>
<script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
<script src="https://unpkg.com/react@17/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js"></script>
<script type="text/babel">
var t = 0;
function App(){
function enter(e){
e.preventDefault()
t++
document.getElementById('ot').innerHTML = `You Clicked The Button ${t} times`
}
return (
<div>
<button onClick={enter}>Click me</button>
</div>
)
}
const root = document.getElementById('root');
ReactDOM.render(<App />, root)
</script>
</html>
之所以可行,是因为出于某种原因,react 在不同的文件中对我不起作用,我必须使用内联 js。谢谢大家的帮助,我希望我能帮助其他人解决同样的问题。顺便说一句,控制台没有错误
我正在尝试向没有节点的 html 页面添加反应。
function Hello(){
return (
<div>
<p>Hello World</p>
</div>
)
}
ReactDOM.render(<Hello />, document.getElementById('root'))
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>React</title>
</head>
<body>
<div id="root"></div>
</body>
<script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
<script src="https://unpkg.com/react@18/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@18/umd/react-dom.development.js"></script>
<script type="text/babel" src="main.js"></script>
</html>
main.js就是javascript。 你能帮我解决这个问题吗? 谢谢
也许如果您将脚本放在 <body>
中,它可能会起作用,因为必须加载元素才能被选择器找到。
例如:
<body>
<div id="root"></div>
<!-- Scripts Here -->
</body>
在我的浏览器 (Firefox) 中有效!
使用ReactDOM.createRoot(rootNode).render(<App />);
参考- https://17.reactjs.org/docs/concurrent-mode-reference.html#createroot
好吧,我不知道为什么会发生这种情况,但只有当反应代码在另一个文件中时才会发生这种情况。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>React</title>
</head>
<body>
<div id="root"></div>
<div id="ot"></div>
</body>
<script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
<script src="https://unpkg.com/react@17/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js"></script>
<script type="text/babel">
var t = 0;
function App(){
function enter(e){
e.preventDefault()
t++
document.getElementById('ot').innerHTML = `You Clicked The Button ${t} times`
}
return (
<div>
<button onClick={enter}>Click me</button>
</div>
)
}
const root = document.getElementById('root');
ReactDOM.render(<App />, root)
</script>
</html>
之所以可行,是因为出于某种原因,react 在不同的文件中对我不起作用,我必须使用内联 js。谢谢大家的帮助,我希望我能帮助其他人解决同样的问题。顺便说一句,控制台没有错误