亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

ReactJS:轉發器中的假路徑問題

ReactJS:轉發器中的假路徑問題

蕭十郎 2023-06-15 16:03:32
我創建了一個中繼器,因此當用戶單擊加號圖標時,會附加一個帶有兩個輸入標簽的新行。下面是我的代碼:repeater.jsimport React from "react"const Details = (props) => {  return (    props.Desc !== '' ?      props.Desc.map((val, idx) => {        let desc = ` desc-${idx}`, file = `file-${idx}`        return (          <tr key={val.index}>            <td> Description</td>              <td >                <input type="text" defaultValue={val.desc} name="desc" data-id={idx} id={desc} className="form-control " />              </td>            <td className="mr-2">  Files</td>            <td>              <input type="file" defaultValue={file} name="file" id={file} data-id={idx} className="form-control " />            </td>            <td>              {                idx === 0 ? <button onClick={() => props.add()} type="button" className="btn btn-primary text-center"><i className="fa fa-plus-circle" aria-hidden="true"></i></button>                  : <button className="btn btn-danger" onClick={(() => props.delete(val))} ><i className="fa fa-minus" aria-hidden="true"></i></button>              }            </td>          </tr >        )      })      : null  )}export default Details細節.jsimport React, { Fragment, Component } from 'react'import Details from './repeater.js'class CreateDetail extends Component {    constructor(props) {        super(props);        this.state = {            inputList: [{ index: Math.random(), desc: "", file: "" }],        }    }    onSubmit = (e) => {        console.log('data : ', this.state.inputList[0]);    }     handleChange = (e) => {         if (["desc", "file"].includes(e.target.name)) {             let Desc = [...this.state.inputList]             inputList[e.target.dataset.id][e.target.name] = e.target.value;         } else {             this.setState({ [e.target.name]: e.target.value })         }     }但是我面臨一個問題,當我使用輸入標簽的類型“文件”并上傳圖像時,我收到了如下所示的假路徑。C:\fakepath\6t8Zh249QiFmVnkQdCCtHK.jpg我只在 repeater遇到這個問題。如果我在轉發器外部使用類型為“文件”的輸入標簽,那么我將收到正確的路徑。假路徑是主要問題,因為如果我提取文件名并將其上傳到 s3,則空圖像將上傳到 s3。如何在轉發器中上傳文件?
查看完整描述

1 回答

?
蝴蝶不菲

TA貢獻1810條經驗 獲得超4個贊

瀏覽器不允許獲取文件的本地路徑。您可以將數據用作表單數據并將其存儲在狀態中并可以將其發送到 S3。喜歡


      handleChange = (e) => {

             let formData = new FormData

for (var i = 0; i < e.target.files.length; i++) {

    formData.append(e.target.name, e.target.files[i])

}

             .....


         }


查看完整回答
反對 回復 2023-06-15
  • 1 回答
  • 0 關注
  • 139 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號