Router.push() 在不同时间的工作方式不同

IT技术 javascript reactjs next.js router
2022-08-01 01:59:05

我想在单击按钮router.push()时使用更改 url 。Search但是,据我所知,此功能有时有效,有时无效。在最终版本中,按下按钮后,用户应该被重定向到/search在输入字段中输入文本的页面。但是,这没有发生,我在我的代码中找不到任何错误。

那是我的搜索功能index.js

const [searchInput, setSearchInput] = useState("");
    const router = useRouter()


    const Search = () => {
        router.push({
            pathname: "/search",
            query: {
                city: searchInput,
            }
            },
        );
    };

这就是我的形式index.js

<form className={"flex flex-col items-center mt-44 flex-grow"}>
            <h1 className={"flex justify-center font-bold pt-20 text-4xl"}>Enter address</h1>

            <div className={"flex w-full mt-5 hover:shadow-lg focus-within:shadow-lg max-w-md rounded-full border border-gray-200 px-5 py-3 items-center sm:max-w-xl lg:max-w-2xl"}>

                <input
                    value={searchInput}
                    onChange={(e) => setSearchInput(e.target.value)}
                    type={"text"} className={"flex-grow focus:outline-none"}/>
                <SearchIcon className={"h-5 text-gray-500"}/>
            </div>


            <div className={"flex flex-col w-1/2 space-y-2 justify-center mt-8 sm:space-y-0 sm:flex-row sm:space-x-4"}>
                <button
                    onClick={Search}
                    className={"btn"}>Search</button>
            </div>
        </form>

也许这与我的 WebStorm 配置有关,因为它有时有效,有时无效。老实说,我没有任何想法。

1个回答

默认的表单提交可能会干扰您的Search功能。

你可能想要这样的东西:

    const Search = (e) => {
        e.preventDefault();

        router.push({
            pathname: "/search",
            query: {
                city: searchInput,
            }
            },
        );
    };

有关更多信息,请参见此处:https ://www.robinwieruch.de/react-preventdefault/