React

如何同步更新state

由于setState方法是异步的,而通常很多时候在一个生命周期里更新state后需要在另一个生命周期里使用这个state。

下面介绍几个方法

// 1
this.setState({}, () => {
this.doSomething();
}); doSomething() {
console.log(this.state);
} // 2 使用setState // 其他
this.setState((prevState, props) => {
return { counter: prevState.counter + 1 };
});

mongodb

Object_id

由于Object_id是对象,因此在比较的时候一定不能直接比较两个ID是否相等,即不能if (a == b), 通过查阅官方的文档,了解到可以这样用: if (a.toString() === b.toString())

mongoose: virtual populate

在使用mongoose进行表关联查询的时候,我将查询出来的数据在后端打印出来,但是发现打印不出来任何东西。

我还以为是代码写错了,应该一番资料的查阅,了解到真实的情况是这样的: "通过virual查询出来的数据,打印出来是无法看见的,因为它的类型是***(我也不知道)的,需要将它转换为对象,才可以打印出来"。

同样,还有一个地方需要注意:

通过virtual查询出来的数据,如果不对结果进行操作,那么返回到前端的数据就是"_doc", 但是如果要对查询的结果进行操作,此时操作的数据不是"_doc", 而是整个对象, 因此需要过滤一次(const docs = results.map(x => x._doc))。

mongodb shell导出到csv

mongoexport --host localhost --db seed_crm --collection customers --type=csv --out customer.csv --fields firstname,middlenamae,lastname

node

axios与hapi.js结合使用

// get
axios.get('/xx', {
params: {
a,
b,
c,
},
}); // schema
function xx() {
return {
query: {
a: Joi....
}
};
} // post
axios.post('/xx', {
a,
b,
c,
}); // schema
function xx() {
return {
payload: {
a: Joi
}
};
}

代码技巧

forEach+if+push ===> filter+concat

单从代码的整洁度来讲,这是一个很不错的方式。

// 只是简单的举例
let results = [];
const data = [1, 1, 2, 2, 3, 3];
data.forEach(x => {
if (x === 2) {
results.push(x);
}
}); // to this
let results = [];
const data = [1, 1, 2, 2, 3, 3];
results = results.concat(data.filter(x => x === 2));

Promise await

超过2个await建议使用Promise.all()

ES6解构

const value1 = values[0];
const value2 = values[1]; // to this, 数组的解构
const [value1, value2] = values;

数组的几个方法

对于数组的几个常见的方法,要使用return null 或者 return false, 我知道这是什么意思, 就是不太好表达出来。

对象取值兼容

由于经常涉及到需要取对象的某某属性值,但是该对象可能不存在某某值,因此就会导致报错。故一般使用的办法有两个:

  1. 使用loadsh库。
  2. 做兼容。如下:
const defaultBy = (Person || {}).default;
// 或者这样的
const defaultBy = Person.default || '';

find

多使用ES6里面的find方法,很好用的。

mongoose

在mongoose的model里面没有某个字段,因为需求,需要向数据库里插入某个字段。然后查询数据打印出来,可以看见这个数据,但是在使用的时候,它的值都是undefined, 后来才知道,这是mongoose的一个机制,需要在schame里面,将直接插入的那个字段给加上。

Promise.resolve

resolve函数里面只能跟一个值,如果要resolve多个值,需要用对象包裹起来。

Promise.all

Promise.all需要所有的Promise都resolve或者reject, 如果只有一部分完成了这两个操作,那么是会出问题的。

React数据传递

x={true} 与 x="true"在子组件里,得到的数据结果是不一样的。

请看这里: JSX Boolean

crm踩坑记(三)的更多相关文章

  1. crm踩坑记(二)

    Linux tmux 如何查看 tmux如何进行滚动呢? prefix + [, prefix为tmux的前置动作,默认是ctrl + b. 使用方向键或者pageUp来进行翻页. q可以退出滚动模式 ...

  2. 【React踩坑记三】React项目报错Can't perform a React state update on an unmounted component

    意思为:我们不能在组件销毁后设置state,防止出现内存泄漏的情况 分析出现问题的原因: 我这里在组件加载完成的钩子函数里调用了一个EventBus的异步方法,如果监听到异步方法,则会更新state中 ...

  3. crm踩坑记(一)

    目录 antd es6 Object.entries() Object.keys() Object.getOwnPropertyNames() 很神奇的用法!!! eslint 傻逼 其他 参考 an ...

  4. 【React踩坑记三】React项目报错Can't perform a React state update on an unmounted component

    意思为:我们不能在组件销毁后设置state,防止出现内存泄漏的情况 分析出现问题的原因: 我这里在组件加载完成的钩子函数里调用了一个EventBus的异步方法,如果监听到异步方法,则会更新state中 ...

  5. Spark踩坑记——Spark Streaming+Kafka

    [TOC] 前言 在WeTest舆情项目中,需要对每天千万级的游戏评论信息进行词频统计,在生产者一端,我们将数据按照每天的拉取时间存入了Kafka当中,而在消费者一端,我们利用了spark strea ...

  6. Spark踩坑记——从RDD看集群调度

    [TOC] 前言 在Spark的使用中,性能的调优配置过程中,查阅了很多资料,之前自己总结过两篇小博文Spark踩坑记--初试和Spark踩坑记--数据库(Hbase+Mysql),第一篇概况的归纳了 ...

  7. EOS踩坑记

    [EOS踩坑记] 1.每个account只能更新自己的contract,即使两个account的秘钥相同,也不允许. 如下,使用alice的权限来更新james的contract.会返回 Missin ...

  8. Spark踩坑记:Spark Streaming+kafka应用及调优

    前言 在WeTest舆情项目中,需要对每天千万级的游戏评论信息进行词频统计,在生产者一端,我们将数据按照每天的拉取时间存入了Kafka当中,而在消费者一端,我们利用了spark streaming从k ...

  9. Vue + TypeScript + Element 搭建简洁时尚的博客网站及踩坑记

    前言 本文讲解如何在 Vue 项目中使用 TypeScript 来搭建并开发项目,并在此过程中踩过的坑 . TypeScript 具有类型系统,且是 JavaScript 的超集,TypeScript ...

随机推荐

  1. 面向对象编程 —— java实现函数求导

    文章目录 ★引子 ★求导 ★最初的想法 ★初步的想法 ★后来的想法 ★最后的想法 ★编程范式 ★结尾 首先声明一点,本文主要介绍的是面向对象(OO)的思想,顺便谈下函数式编程,而不是教你如何准确地.科 ...

  2. 前端构建工具之争——Webpack vs Gulp 谁会被拍死在沙滩上

    .table tr>td:nth-child(1){width: 2em !important;padding-left: .6rem !important;padding-right: .6r ...

  3. 使用DataFlow表达ControlFlow的一些思考

    一.控制流 从接触面向过程语言开始,使用控制流编程的概念已是司空见惯. if (condition) { // do something } else { // do something else } ...

  4. uva 1418 - WonderTeam

    题意:你n支球队进行比赛,每两支队伍之间进行2场比赛,胜得3分,平得1分,输得0分,比赛后挑选出一个梦之队,要求进球总数最多,胜利场数最多,失球总数最少,并且三种都不能与其它对比列第一.问说梦之队的最 ...

  5. tp的秘密

    入口文件index.php define('APP_DEBUG',True); 改为false* memory_get_usage 获取本套系统目前内存* tp框架中ThinkPHP\Library\ ...

  6. PHP生成 uuid

    // 生成UUID,并去掉分割符 function guid() { if (function_exists('com_create_guid')){ $uuid = com_create_guid( ...

  7. VS2015 密钥key

    亲测可用: HMGNV-WCYXV-X7G9W-YCX63-B98R2

  8. JAVA中静态修饰符static的学习(初学)

    静态修饰符static,用于修饰类中的成员变量和成员函数. 用static修饰的成员变量也可叫做类变量. 什么时候使用静态 什么时候定义静态成员变量?     当对象中出现共享数据时,将该数据定义为静 ...

  9. CS Round#50 D min-races

    Min Races Time limit: 1000 msMemory limit: 256 MB   In a racing championship there are N racing driv ...

  10. vue 二进制文件的下载(解决乱码和解压报错)

    问题描述:项目中使用的是vue框架进行开发,因为文件下载存在权限问题,所以并不能通过 a 链接的 href 属性直接赋值 URL进行下载, (如果你的文件没有下载权限,可以直接通过href属性赋值UR ...