最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - TS2339: Property 'id' does not exist on type '{}' - Stack Overflow

programmeradmin0浏览0评论

I have a React form with Material-UI. I would like to get the id from the URL link using useParams and make some API requests in order to populate form-data:

http://localhost:3001/ticket-profile/9459377

Main app.tsx:

function App() {
  return (
      <Router>
        <Navbar />
        <Switch>
          <Route path='/ticket-profile/:id' ponent={TicketProfile} />
        </Switch>
      </Router>
  );
}

I use this code to open a new page and pass id param:

history.push(`/ticket-profile/${id}`)

I need to get the data into this page:

export default function TicketProfile(props: any) {
    let { id } = useParams();
    
    const [ticket, setTicket] = useState<TicketDTO[]>([]);

    useEffect(() => {
        getSingleTicket();    
    }, []);

    const getSingleTicket = async () => {
        getTicket(id)
            .then((resp) => {
                setTicket(resp.data);               
    }

But for this line let { id } I get:

TS2339: Property 'id' does not exist on type '{}'.

Do you know how I can fix this issue?

I have a React form with Material-UI. I would like to get the id from the URL link using useParams and make some API requests in order to populate form-data:

http://localhost:3001/ticket-profile/9459377

Main app.tsx:

function App() {
  return (
      <Router>
        <Navbar />
        <Switch>
          <Route path='/ticket-profile/:id' ponent={TicketProfile} />
        </Switch>
      </Router>
  );
}

I use this code to open a new page and pass id param:

history.push(`/ticket-profile/${id}`)

I need to get the data into this page:

export default function TicketProfile(props: any) {
    let { id } = useParams();
    
    const [ticket, setTicket] = useState<TicketDTO[]>([]);

    useEffect(() => {
        getSingleTicket();    
    }, []);

    const getSingleTicket = async () => {
        getTicket(id)
            .then((resp) => {
                setTicket(resp.data);               
    }

But for this line let { id } I get:

TS2339: Property 'id' does not exist on type '{}'.

Do you know how I can fix this issue?

Share Improve this question asked Oct 3, 2021 at 9:13 Peter PenzovPeter Penzov 1,766156 gold badges499 silver badges905 bronze badges 2
  • Try useParams<{id: string}>() or something like that – Shivam Jha Commented Oct 3, 2021 at 9:20
  • you have to pass the id route param in TicketProfile's props in Router – Nikos M. Commented Oct 3, 2021 at 9:20
Add a ment  | 

1 Answer 1

Reset to default 8

Using React Router with typescript suggests you need to pass the you are expecting.

From the page:

The useParams() method returns an object, and directly taking the property TS will prompt that the property does not exist in the empty object. According to the specification of TS, an interface can be defined in the dynamic routing ponent to define the parameters of routing.

Example:

// Home.tsx
interface RouteParams {
    id: string
}
export default () => {
    const params = useParams<RouteParams>();
    return (
        <div>
            { params.id }
        </div>
    )
}

Use this:

 let { id } = useParams<{id: string}>();
发布评论

评论列表(0)

  1. 暂无评论