问题描述
嗨,我学习React并需要帮助!
我收到此错误:
./ src / components / masonry / Masonry.js
278:23行:在声明的prop类型中输入错字:boolean react / no-typos
280:26行:声明的prop类型中的错字:boolean react / no-typos
282:20行:已声明prop类型的错字:boolean react / no-typos搜索关键字以详细了解每个错误。
但是在此codesandbox made by mimimimichael中可以正常使用
导致错误的所有PropTypes.boolean
都无法使用布尔值
我已经搜索过,但找不到答案,我想可能是版本冲突
请指教?
import React from "react";
import PropTypes from "prop-types";
import { withResizeDetector } from "react-resize-detector";
import VisibilitySensor from "react-visibility-sensor";
import { max,map,compact,last } from "lodash";
class Masonry extends React.Component {
constructor(props) {
super(props);
this.container = React.createRef();
this.list = React.createRef();
this.state = {
mounted: false,scrollTop: 0,scrollProgress: 0
};
this._onEnd = this._onEnd.bind(this);
this._isVisibleItem = this._isVisibleItem.bind(this);
this._setContainerHeight = this._setContainerHeight.bind(this);
this._onResize = this._onResize.bind(this);
this._onScroll = this._onScroll.bind(this);
}
componentDidMount() {
this.setState({
mounted: true
});
this.container.current.addEventListener("scroll",this._onScroll,false);
}
componentWillUnmount() {
this.container.current.removeEventListener("scroll",false);
}
componentWillReceiveProps(newProps) {
if (this.props.width !== newProps.width) {
setTimeout(this._onResize,0);
}
}
/**
* Do something when the container is scrolled
*/
_onScroll() {
const { scrollTop,scrollHeight } = this.container.current;
this.setState({
scrollTop,scrollProgress: (1 / scrollHeight) * scrollTop
});
}
/**
* Approximate previous scroll-position after container was resized
*/
_onResize() {
const { scrollProgress } = this.state;
let container = this.container.current;
container.scrollTop = scrollProgress * container.scrollHeight;
}
/**
* Let parent components know that we reached the end of display
*/
_onEnd(isVisible) {
if (!isVisible) return;
this.props.onEnd && this.props.onEnd();
}
_getContainerStyle() {
const { infinite,debug } = this.props;
const infiniteStyles = infinite
? {
position: "absolute",top: 0,left: 0,right: 0,bottom: 0,overflow: "auto"
}
: {};
return {
outline: debug && "1px solid seagreen",width: "100%",position: "relative",...infiniteStyles
};
}
_getListStyle() {
const { gutter } = this.props;
return {
padding: 0,margin: 0,listStyle: "none"
};
}
_getListItemStyle(index,item) {
const position = {
padding: 0,position: "absolute",...this._getItemDimensions(index,item)
};
return position;
}
// Picks the column in which to put the element
// and returns its index
_pickColumn() {
const columnHeights = this.columns.map(items => {
let lastItem = items[items.length - 1];
return lastItem ? lastItem.height + lastItem.top : 0;
});
const columnIndex = columnHeights.indexOf(Math.min(...columnHeights));
return columnIndex;
}
_getWidth() {
const { gutter,outerGutter } = this.props;
const colcount = this._getColumnCount();
const containerWidth =
this.container.current.offsetWidth -
(colcount - 1) * gutter -
(outerGutter ? 2 * gutter : 0);
return Math.floor(containerWidth / colcount);
}
_getDimensions({ item }) {
const { gutter,extraPx = 0 } = this.props;
const width = this._getWidth();
const height = Math.floor(width * item.ratio) + extraPx;
return {
width,height
};
}
_getLeft({ columnIndex }) {
const { gutter,outerGutter } = this.props;
return (
columnIndex * this._getWidth() +
columnIndex * gutter +
(outerGutter ? gutter : 0)
);
}
_getTop({ columnIndex }) {
const { outerGutter,gutter } = this.props;
const items = this.columns[columnIndex];
return items && items.length
? last(items).top + last(items).height + gutter
: outerGutter
? gutter
: 0;
}
_getItemDimensions(index,item) {
const columnIndex = this._pickColumn();
const { debug } = this.props;
const dimensions = {
outline: debug && "1px solid tomato",top: this._getTop({ columnIndex }),left: this._getLeft({ columnIndex }),...this._getDimensions({ item,columnIndex })
};
this.columns[columnIndex] = [...this.columns[columnIndex],dimensions];
return dimensions;
}
_isVisibleItem({ top,left,width,height }) {
const { scrollTop } = this.state;
const { offsetHeight,offsetWidth } = this.container.current;
const { safeSpace = offsetHeight / 2 } = this.props;
const topVisible = top >= scrollTop - height - safeSpace;
const bottomVisible = top <= scrollTop + offsetHeight + safeSpace;
return topVisible && bottomVisible;
}
_setContainerHeight() {
const el = this.list.current;
const lastItems = this.columns.map(items => {
let item = items[items.length - 1];
return item.top + item.height;
});
el.style.height = max(lastItems) + "px";
}
renderItem({ index,item,maxIndex }) {
const { items = [],itemRenderer } = this.props;
const Component = itemRenderer;
const style = this._getListItemStyle(index,item);
const isVisible = this._isVisibleItem(style);
if (index + 1 === maxIndex) {
this._setContainerHeight();
}
return isVisible ? (
<li key={item.id} style={style}>
<Component {...item} />
{items.length === index + 1 && (
<div
style={{
position: "absolute",top: -this.container.current.offsetHeight / 2,width: 1,height: 1
}}
>
<VisibilitySensor partialVisibility={true} onChange={this._onEnd} />
</div>
)}
</li>
) : null;
}
_getColumnCount() {
const { cols,width } = this.props;
const mqs = compact(
map(cols,(columnCount,key) => {
const applies = this.container.current.offsetWidth >= key;
return applies ? columnCount : false;
})
);
const colcount = last(mqs);
return colcount;
}
render() {
const { mounted } = this.state;
const { items = [] } = this.props;
if (mounted) {
this.columns = new Array(this._getColumnCount()).fill([]);
}
const maxIndex = items.length;
return (
<div style={this._getContainerStyle()} ref={this.container}>
<ul ref={this.list} style={this._getListStyle()}>
{mounted &&
items.map((item,index) =>
this.renderItem({ index,maxIndex })
)}
</ul>
</div>
);
}
}
Masonry.propTypes = {
columns: PropTypes.number.isRequired,safeSpace: PropTypes.number,items: PropTypes.array.isRequired,itemRenderer: PropTypes.func.isRequired,infinite: PropTypes.boolean,ERROR............
gutter: PropTypes.number,outerGutter: PropTypes.boolean,ERROR............
extraPx: PropTypes.number,debug: PropTypes.boolean ERROR............
};
export default withResizeDetector(Masonry);
我的Package.json
{
"name": "test-app","version": "0.1.0","private": true,"dependencies": {
"axios": "^0.19.2","lodash": "^4.17.19","react": "^16.8.4","react-dom": "^16.8.4","react-motion": "^0.5.2","react-resize-detector": "^5.0.7","react-router-dom": "^5.2.0","react-scripts": "^3.4.0","react-slick": "^0.27.3","react-tilt": "^0.1.4","react-transition-group": "^4.4.1","react-visibility-sensor": "^5.1.1","save": "^2.4.0","slick-carousel": "^1.8.1"
},"scripts": {
"start": "set PORT=3038&& react-scripts start","build": "react-scripts build","test": "react-scripts test","eject": "react-scripts eject","predeploy": "npm run build","deploy": "gh-pages -b master -d build"
},"eslintConfig": {
"extends": "react-app"
},"browserslist": [
">0.2%","not dead","not ie <= 11","not op_mini all"
],"devDependencies": {
"gh-pages": "^2.0.1"
}
}
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)