如何使用Redux中的axios库自动为发布到API服务器的数据生成唯一ID

普拉纳米

我有一个redux表单,用于接收用户的数据并将其发布到后端API服务器。在将数据发布到服务器时,我想为每个发布到的数据集生成唯一的ID。服务器,以便以后可以使用该ID来引用该特定集合并将其显示给用户。那么,如何在将一组数据发布到服务器时自动生成该唯一ID?

我的redux-form的代码如下:

import React, { Component } from 'react';
import { Field, reduxForm } from 'redux-form';
import { Link } from 'react-router-dom';
import { connect } from 'react-redux';
import { createPosts } from '../actions/posts_action';

class CreatePost extends Component {
  constructor() {
    super();
    this.state = {
      selectValue : ''
  };
  this.handleChange = this.handleChange.bind(this);
  this.renderCategory = this.renderCategory.bind(this);
}

  renderField(field) {
      return(
        <div className="title-design">
            <label className="label-design"> {field.label} </label>
            <input
              type="text"
              className="title-input"
              {...field.input}
            />
            <div className="text-help  has-danger">
              {field.meta.touched ? field.meta.error : ''}
            </div>
      </div>
      );
  }

  handleChange(e) {
    const value=e.target.value;
    this.props.change("categories",value);
    this.setState({selectValue: value}, () => {
      console.log(value)
    });
  }

  renderCategory(field) {
    return(
      <div className="title-design">
        <label className="label-design">{field.label} </label>
          <Field name="category" className="title-input" component="select">
            <option></option>
            <option value="react">React</option>
            <option value="redux">Redux</option>
            <option value="udacity">Udacity</option>
          </Field>

          <div className="text-help has-danger">
            {field.meta.touched ? field.meta.error : ''}
          </div>
      </div>
    );
  }

    onSubmit(values) {
      this.props.createPosts(values, () => {
          this.props.history.push('/');
      });
    }



    render() {
      const { handleSubmit } = this.props;

      return (
        <form onSubmit={handleSubmit(this.onSubmit.bind(this))}>
          <Field
            label="Title for Post"
            name="title"
            component={this.renderField}
          />

          <Field
            label="Post Content"
            name="body"
            component={this.renderField}
          />

          <Field
            label="Category"
            name="category"
            component={this.renderCategory}
            />



          <button type="submit" className="btn btn-primary">Submit</button>
          <Link  to="/">
            <button className="cancel-button">Cancel</button>
          </Link>
        </form>
      );
    }
}

function validate(values) {
  const errors = {} ;

  if (!values.title) {
      errors.title = "Enter a title";
  }

  if (!values.body) {
    errors.body = "Enter some content";
    }

  if(!values.category) {
    errors.category = "Please select a category";
  }

  if (!values.id) {
      errors.id = "ID not generated";
  }

  return errors;
}

export default reduxForm({
  validate : validate,          //validate
  form : 'CreatePostForm'
})(
  connect(null,{ createPosts })(CreatePost)
);

创建新帖子动作创建者如下:

//Action Creator for creating posts
export function createPosts(values, callback) {

  return dispatch => {
    return axios.post(`${API}/posts`,values,{headers})
      .then((data) => {
        callback();
        console.log(data)
      dispatch({
        type: CREATE_POST,
        payload: data
      })
    })
  }
}

用于创建帖子的Reducer

import _ from 'lodash';
import { FETCH_POSTS, FETCH_POST, CREATE_POST } from '../actions/posts_action';

export default function(state = {}, action) {
  switch (action.type) {
    case FETCH_POST:
      // const post = action.payload.data;
      // const newState  = { ...state,  };
      // newState[post.id] = post;
      // return newState;
      return {...state, [action.payload.id]: action.payload};

    case FETCH_POSTS:
     return {posts: { ...state.posts, ...action.payload }};

    case CREATE_POST:
      return {posts: { ...state, ...action.payload}};

     default:
      return state;
  }

}

那么,如何为发送到服务器的每组数据生成ID?

编辑1:

我试图在我的onSubmit()方法上添加uuid,如下所示,但是它不起作用。我坐着不应该怎么做,或者我必须以其他方式来做?

  onSubmit(values) {

          this.props.createPosts(values, () => {
            uuidv1();
          this.props.history.push('/');
      });
    }

编辑2:

服务器的帖子文件:

const clone = require('clone')

let db = {}

const defaultData = {
  "8xf0y6ziyjabvozdd253nd": {
    id: '8xf0y6ziyjabvozdd253nd',
    timestamp: 1467166872634,
    title: 'Udacity is the best place to learn React',
    body: 'Everyone says so after all.',
    author: 'thingtwo',
    category: 'react',
    voteScore: 6,
    deleted: false,
    commentCount: 2
  },
  "6ni6ok3ym7mf1p33lnez": {
    id: '6ni6ok3ym7mf1p33lnez',
    timestamp: 1468479767190,
    title: 'Learn Redux in 10 minutes!',
    body: 'Just kidding. It takes more than 10 minutes to learn technology.',
    author: 'thingone',
    category: 'redux',
    voteScore: -5,
    deleted: false,
    commentCount: 0
  }
}

function getData (token) {
  let data = db[token]
  if (data == null) {
    data = db[token] = clone(defaultData)
  }
  return data
}

function getByCategory (token, category) {
  return new Promise((res) => {
    let posts = getData(token)
    let keys = Object.keys(posts)
    let filtered_keys = keys.filter(key => posts[key].category === category && !posts[key].deleted)
    res(filtered_keys.map(key => posts[key]))
  })
}

function get (token, id) {
  return new Promise((res) => {
    const posts = getData(token)
    res(
      posts[id].deleted
        ? {}
        : posts[id]
    )
  })
}

function getAll (token) {
  return new Promise((res) => {
    const posts = getData(token)
    let keys = Object.keys(posts)
    let filtered_keys = keys.filter(key => !posts[key].deleted)
    res(filtered_keys.map(key => posts[key]))
  })
}

function add (token, post) {
  return new Promise((res) => {
    let posts = getData(token)

    posts[post.id] = {
      id: post.id,
      timestamp: post.timestamp,
      title: post.title,
      body: post.body,
      author: post.author,
      category: post.category,
      voteScore: 1,
      deleted: false,
      commentCount: 0
    }

    res(posts[post.id])
  })
}

function vote (token, id, option) {
  return new Promise((res) => {
    let posts = getData(token)
    post = posts[id]
    switch(option) {
        case "upVote":
            post.voteScore = post.voteScore + 1
            break
        case "downVote":
            post.voteScore = post.voteScore - 1
            break
        default:
            console.log(`posts.vote received incorrect parameter: ${option}`)
    }
    res(post)
  })
}

function disable (token, id) {
    return new Promise((res) => {
      let posts = getData(token)
      posts[id].deleted = true
      res(posts[id])
    })
}

function edit (token, id, post) {
    return new Promise((res) => {
        let posts = getData(token)
        for (prop in post) {
            posts[id][prop] = post[prop]
        }
        res(posts[id])
    })
}

function incrementCommentCounter(token, id, count) {
  const data = getData(token)
  if (data[id]) {
    data[id].commentCount += count
  }
}

module.exports = {
  get,
  getAll,
  getByCategory,
  add,
  vote,
  disable,
  edit,
  getAll,
  incrementCommentCounter
}
Billjamesdev

好吧,通常您会让服务器生成该ID,然后将其作为axios调用的响应的一部分发送回去,但是如果您真的想在客户端上生成一个ID,我建议您使用uuid,其中有多种UUID生成器:https//www.npmjs.com/package/uuid

来自文档的示例:

const uuidv4 = require('uuid/v4');
uuidv4(); // -> '110ec58a-a0f2-4ac4-8393-c866d813b8d1' 

您已经添加了更多代码,我认为最好在服务器上使用uuidv4()为您服务;就像是:

function add (token, post) {
  return new Promise((res) => {
    let posts = getData(token)
    let id = uuidv4();

    posts[id] = {
      id: id,
      timestamp: post.timestamp,
      title: post.title,
      body: post.body,
      author: post.author,
      category: post.category,
      voteScore: 1,
      deleted: false,
      commentCount: 0
    }

    res(posts[id])
  })
}

这样,在服务器上生成了id。客户端不再需要依赖uuid,并且您不会“信任”客户端以生成有效的id。该ID将作为响应的一部分呈现回客户端,然后您可以在进行编辑等操作时从客户端使用它。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

如何在Redux中使用axios库将数据发布到API服务器

如何使用angularJS,Web API将数据发布到服务器

如何使用axios根据Redux中的某些特定属性从api服务器过滤记录

axios不会将数据发布到服务器

如何使用retrofit2将json数据发布到android中的服务器?

排球库不能将数据发布到服务器

使用 curl 或 webhooks 将数据从外部服务器发布到数据库

在Redux中,将数据发布到服务器的最佳方法是什么?

跨多个独立服务器生成唯一ID

获取序列中唯一的最后一行。数据库服务器

如何在Web服务器群集上生成唯一ID

curl问题:如何使用Windows cmd中的curl将json格式的数据发布到服务器?

使用 MVP Android 将数据发布到服务器

无法使用 JSONObjectRequest 将数据发布到服务器

如何在ionic 3中将特定行数据发布到服务器

如何将Android中的数据以JSON格式发布到服务器?

如何将JSON数据发布到iOS中的服务器?

如何使用ajax将XML数据发布到服务器?

如何使用Objective C将数据发布到Web服务器?

PostgreSQL:使用单个功能将数据库复制到同一服务器中

在 android 应用程序中为服务器使用创建唯一 id 的最佳方法

Node JS如何将图像与请求数据一起发布到另一个服务器/ API

使用mutipart发布将发布数据发布到服务器

Vue axios将数据作为对象发布到Spring后端服务器

通过 axios 将数据发布到服务器时,csrf 是否足以保证安全?

如何在Spark数据框中创建唯一的自动生成的ID列

NodeJS,Axios-将文件从本地服务器发布到另一台服务器

如何在单个 Postgres 服务器中为多个数据库使用嵌入式 Debezium?

如何将使用JSON格式的表发布到DolphinDB中的MQTT服务器