用于搜索功能的烧瓶震荡端点的正确结构

如何解决用于搜索功能的烧瓶震荡端点的正确结构

我正在创建一个网站,向用户提供有关日历事件的信息。我正在寻找有关端点体系结构的最佳实践。

我创建了一个搜索功能,该功能返回标题用户输入匹配的所有日历事件。这似乎很容易。我的Flask-Restful服务器上有返回事件的端点。

我想做的是也“保存”搜索条目,以便用户拥有与该事件和所有其他保存的搜索相匹配的将来事件的提要。像这样:

## GET (RETURNS) A LIST OF ALL EVENTS WHICH MATCH SAVED USER SEARCHES
api.add_resource(UserFeed,'/profile/<int:profile_id/searches/events/')

## GET (RETURNS) A LIST OF ALL SEARCHES WHICH THE USER HAS SAVED
api.add_resource(UserFeed,'/profile/<int:profile_id/searches/')

作为一个有问题的标签,是否还会在/profile/<int:profile_id>/settings/之类的位置进行用户设置?

当前端点

# Route_1
## GET (RETURNS) A LIST OF ALL EVENTS
## POST (CREATES) AN EVENT
api.add_resource(EventsList,'/events')

# Route_2
## GET (RETURNS) A LIST OF EVENTS BY MATCHING TITLE
api.add_resource(EventsListSearch,'/events/search/<string:query_title>')

搜索组件

import React,{Component} from "react";
import Form from 'react-bootstrap/Form'
import Events from './event/Events'



class Search extends Component{
  state = {
    searchCriteria: '',searchResults:[]
  }


  handleSubmit = async (event) => {
    event.preventDefault();
    fetch('http://127.0.0.1:5002/events/search/'+this.state.searchCriteria)
    .then(res => res.json())
    .then((resultsData) => {
      this.setState({
        searchResults: resultsData
      })
      console.log(resultsData);
    })
    .catch(console.log)

  };

render(){
  return (
    <div className="search container">
    <Form onSubmit={this.handleSubmit}>
      <Form.Group controlId="formBasicEmail">
        <Form.Label></Form.Label>
        <Form.Control type="text"
          value=""
          onChange={event => this.setState({ searchCriteria: event.target.value })}
          placeholder="Search by event title" />
        <Form.Text className="text-muted">
        "National Convention" or "Race". For tags use square brackets: "[earthquake]"
        </Form.Text>
      </Form.Group>
    </Form>



        <div>

              {this.state.searchResults
                  .map(event =>(
                    <Events event={event} />

                  )
                )
              }
        </div>

        </div>
      )




}
}


export default Search;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?