Send multiple images with Vercel Blob
Answered
European anchovy posted this in #help-forum
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
European anchovyOP
I'm using Next.js 14, Vercel Blob, TypeScript. I have an Comment section and users can add images to comment. So I'm searching add multiple images to Vercel Blob with Server Actions.
data:image/s3,"s3://crabby-images/c3682/c3682af9fca1551c914fe25595a019951583a133" alt="Image"
Answered by Ray
try this
async function uploadImage(formData: FormData) {
"use server";
const files = formData.getAll("image") as File[];
const blobs = await Promise.all(
files.map((file) =>
put(file.name, file, {
access: "public",
})
)
);
revalidatePath("/");
return blobs;
}
return (
<form action={uploadImage}>
<label htmlFor="image">Image</label>
<input type="file" id="image" name="image" multiple />
<button>Upload</button>
</form>
)
2 Replies
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
@European anchovy I'm using Next.js 14, Vercel Blob, TypeScript. I have an Comment section and users can add images to comment. So I'm searching add multiple images to Vercel Blob with Server Actions.
data:image/s3,"s3://crabby-images/4052e/4052ede4a21942fdd16cacc37f3a6f9ad141ebbf" alt="Avatar"
try this
async function uploadImage(formData: FormData) {
"use server";
const files = formData.getAll("image") as File[];
const blobs = await Promise.all(
files.map((file) =>
put(file.name, file, {
access: "public",
})
)
);
revalidatePath("/");
return blobs;
}
return (
<form action={uploadImage}>
<label htmlFor="image">Image</label>
<input type="file" id="image" name="image" multiple />
<button>Upload</button>
</form>
)
Answer
data:image/s3,"s3://crabby-images/4052e/4052ede4a21942fdd16cacc37f3a6f9ad141ebbf" alt="Avatar"
@Ray try this
ts
async function uploadImage(formData: FormData) {
"use server";
const files = formData.getAll("image") as File[];
const blobs = await Promise.all(
files.map((file) =>
put(file.name, file, {
access: "public",
})
)
);
revalidatePath("/");
return blobs;
}
return (
<form action={uploadImage}>
<label htmlFor="image">Image</label>
<input type="file" id="image" name="image" multiple />
<button>Upload</button>
</form>
)
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
European anchovyOP
Ray thank you so much man you're a lifesaver 🫶