Итак, я пытаюсь создать функцию обновления статьи, и это код:
СтатьяКонтроллер:
public function update(Request $request, Article $article)
{
$request->validate([
'title' => 'required',
'body' => 'required',
'thumbnail' => 'nullable|mimes:png,jpg,jpeg',
]);
// If new thumbnail uploaded
if ($request->hasFile('thumbnail')) {
$thumbnail = $request->file('thumbnail')->store('thumbnail');
$article->update([
'title' => $request->title,
'body' => $request->body,
'thumbnail' => $thumbnail
]);
} else {
// No new thumbnail
$article->update([
'title' => $request->title,
'body' => $request->body,
]);
}
return redirect('/admin');
}
а это взгляд по инерции реагирует:
import React, { useState } from "react";
import Navbar from "../components/Navbar";
import { Editor } from "@tinymce/tinymce-react";
import { useForm } from "@inertiajs/inertia-react";
export default function EditArticle({ article }) {
const { data, setData, patch, errors, reset, processing } = useForm({
title: article.title,
body: article.body,
thumbnail: null
});
const [isOpen, setIsOpen] = useState(false);
function onSubmitEventHandler(e) {
e.preventDefault();
patch(`/articles/${article.id}/edit`, { onSuccess: () => reset() });
}
function openModalEventHandler() {
setIsOpen(!isOpen);
}
function handleThumbnailChange(e) {
setData('thumbnail', e.target.files[0]);
}
return (
<>
<Navbar />
<form className = "mt-24" onSubmit = {onSubmitEventHandler} encType = "multipart/form-data">
{
isOpen &&
<>
<div className = "fixed inset-0 flex items-center justify-center z-40">
<div className = "p-4 rounded-lg flex flex-col bg-white text-black z-50 relative">
<div onClick = {openModalEventHandler} className = "hover:cursor-pointer absolute -top-2 -right-2 shadow-md p-2 bg-white rounded-full">
<img src = "/icon/closeIcon.svg" className = "w-4" alt = "Close Icon" />
</div>
<h2 className = "text-2xl font-semibold">Edit Article</h2>
<label htmlFor = "title" className = "mt-5 text-sm">Title:</label>
<input type = "text" id = "title" className = "rounded-lg border py-2 px-3" value = {data.title} onChange = {(e) => setData('title', e.target.value)} />
<label htmlFor = "thumbnail" className = "mt-5 text-sm">Thumbnail:</label>
<input type = "file" className = "mt-2" id = "thumbnail" onChange = {handleThumbnailChange} />
<button type = "submit" disabled = {processing} className = {`mt-4 py-2 px-4 bg-darkerBlue rounded-lg text-white ${processing && 'opacity-25'}`}>Save Article</button>
{errors.title &&
<p className = "mt-2 text-sm text-red-700">{errors.title}</p>
}
{errors.body &&
<p className = "mt-2 text-sm text-red-700">{errors.body}</p>
}
{errors.thumbnail &&
<p className = "mt-2 text-sm text-red-700">{errors.thumbnail}</p>
}
</div>
<div onClick = {openModalEventHandler} className = "fixed inset-0 bg-black opacity-35"></div>
</div>
</>
}
<Editor
apiKey='5d3gmavobfl1gplfh7eithg9chuj3shiru72msgp1kescjzi'
init = {{
toolbar: 'undo redo | blocks fontfamily fontsize | bold italic underline strikethrough | table | addcomment showcomments | align lineheight | checklist numlist bullist indent outdent | charmap | removeformat',
height: 520,
}}
value = {data.body}
onEditorChange = {(newValue, editor) => setData('body', newValue)}
/>
<div onClick = {openModalEventHandler} className = "hover:bg-gray-200 hover:cursor-pointer bg-white transition fixed right-3 bottom-5 rounded-full p-4 card-shadow">
Save
</div>
</form>
</>
)
}
Когда я редактирую только заголовок или поля тела, ошибок нет.
Но когда я пытаюсь загрузить файл и отправить форму, возникает ошибка:
Поле заголовка является обязательным. Поле тела является обязательным.
Хотя я заполнил поля заголовка и тела.
ОБНОВЛЕНО
Поскольку загрузка файлов с использованием запроса multipart/form-data изначально не поддерживается, вы должны использовать запрос POST
вместо PATCH
или PUT
.
Или вы можете попробовать подменить метод, выполнив:
useForm({
title: article.title,
body: article.body,
thumbnail: null,
_method: "patch" // Add _method to payload
});
post(`/articles/${article.id}/edit`, {
onSuccess: () => reset()
})
Или вы можете использовать маршрутизатор:
import { router } from '@inertiajs/react'
router.post('/articles/${article.id}/edit', {
...data,
_method: "patch",
});
Вот официальная документация:
Я попробовал, но это не работает. Вот сообщение об ошибке: Метод POST не поддерживается для маршрута Articles/51/editThumbnail. Поддерживаемые методы: PATCH. Это код: Route::patch('/articles/{article}/editThumbnail', 'updateThumbnail')->middleware('auth'); const {данные, setData, сообщение, ошибки, сброс, обработка } = useForm({thumbnail:article.thumbnail}); функция onSubmitThumbnailChangeHandler (e) { e.preventDefault (); console.info(data.thumbnail); post(/articles/${article.id}/editThumbnail
, { _method: 'patch' }) }
Я отредактирую свой ответ, вы можете проверить еще раз
Используйте панель «Сеть» инструментов разработчика вашего браузера, чтобы проверить запрос. Когда вы отправляете файл, содержат ли отправленные данные формы заголовок и тело?