因此,我有一个名为homepage.blade.php
的Laravel视图,它包含以下内容:
<body>
<div id=root></div>
<script src="./js/app.js"></script>
</body>
内部app.js
import React from "react";
import ReactDOM from "react-dom";
import SignUp from "./components/SignUp";
if (document.getElementById("root")) {
ReactDOM.render(<SignUp />, document.getElementById("root"));
}
在SignUp.js
内部
import React from "react";
export default function SignUp() {
return (
<span className="text-xs font-bold uppercase"> Welcome, {!! auth()-> user() -> name !!} </span>
}
homepage.blade.php
由控制器中的一个函数调用,如下所示:
//inside the function in the Controller.php:
$user = User::create($attributes);
auth()->login($user);
return redirect('/homepage'); // homepage redirects to homepage.blade.php
The problem:我无法在将插入到homepage.blade.php
视图中的React组件SignUp.js
中插入行{!! auth()-> user() -> name !!}
。
问题:在React组件中有插入刀片代码的方法吗?还有更好的方法吗?
发布于 2022-02-04 17:13:30
你不能在js文件中使用刀片。正确的方法是使用<script></script>
标记定义刀片文件中的变量,如下所示:
<script>
const window.username = '{!! auth()-> user() -> name !!}';
<script src="./js/app.js"></script>
</script>
然后在app.js文件中使用定义的变量。
发布于 2022-02-04 16:57:54
你不能这样做。刀片只适用于MIME类型PHP上的脚本。您必须使用.php加载JS文件,以便能够呈现脚本。以下是你如何做到这一点:
https://stackoverflow.com/questions/70989848
复制相似问题