English 中文(简体)
How can I query my API in React in a way that has dynamically defined queries?
原标题:

I m using Django Rest Framework and React, but this is more of a conceptual question.

I ve noticed that when querying data from an API, especially on a React-esque frontend, I always run into the same issues.

  1. API responses are not intrinsically typed
  2. I cannot specific exactly what fields I d like to get back from the API
  3. I can t specify dynamic type-safe filtering and sorting.

In an ideal world, I d like to be able to do something like this:

// Using a user model as an example.
export function UserComponent(props: ...){

  // `data` is inferred to be of type Pick<User, "email", "lastActive">
  const data = myCustomAPIFetch<User>({
    model: User 
    fields: [User.email, User.lastActive],
    filters: {
      [User.firstName]: "Linus"
    } // Similar syntax for sorting
  })

  return (...)
}

This solves all three issues - it returns the proper type object, filtering/sorting is type-safe, and the exact fields that I want back can be specified.

The solutions that I ve researched here solve some of the problems, but not all.

Graphql - solves #2 and can solve #1, but from what I understand I have to make a new query/resolver for each filter or sort I want to do. Not ideal.

Protobuf - types are cross-language (huge plus), but can only specify a static schema. Can t ask for only the user s email back without making a new message type.

tRPC - only for TS stacks, also doesn t solve #2 or #3.

问题回答

暂无回答




相关问题
How to get two random records with Django

How do I get two distinct random records using Django? I ve seen questions about how to get one but I need to get two random records and they must differ.

Moving (very old) Zope/Plone Site to Django

I am ask to move data from a (now offline) site driven by Plone to a new Django site. These are the version informations I have: Zope Version (unreleased version, python 2.1.3 ) Python Version 2.1....

Can Django models use MySQL functions?

Is there a way to force Django models to pass a field to a MySQL function every time the model data is read or loaded? To clarify what I mean in SQL, I want the Django model to produce something like ...

Flexible pagination in Django

I d like to implement pagination such that I can allow the user to choose the number of records per page such as 10, 25, 50 etc. How should I go about this? Is there an app I can add onto my project ...

is it convenient to urlencode all next parameters? - django

While writing code, it is pretty common to request a page with an appended "next" query string argument. For instance, in the following template code next points back to the page the user is on: &...

Pragmatically adding give-aways/freebies to an online store

Our business currently has an online store and recently we ve been offering free specials to our customers. Right now, we simply display the special and give the buyer a notice stating we will add the ...

热门标签