let number = 1;
const callback = () => {
console.log('callback', number);
};
class Scroll {
constructor(callback) {
this.callback = callback;
}
}
const scroll = new Scroll(() => console.log(number));
number = 2;
scroll.callback();
demo链接:http://js.jirengu.com/xeninan...
这种情况打印的是2,跟预期是一样的
import React from "react";
import ReactDOM from "react-dom";
class Scroller {
constructor(callback) {
console.log("hehe");
this.callBack = callback;
}
doSomething() {
this.callBack();
}
}
const Demo = (props) => {
const [scroller, setScroller] = React.useState(null);
const onScrollerClick = () => {
scroller.doSomething();
};
React.useEffect(() => {
setScroller(
new Scroller(() => {
const { callback } = props;
callback();
})
);
}, []);
return (
<div>
<button onClick={onScrollerClick}>scroller</button>
</div>
);
};
const Container = () => {
const [count, setCount] = React.useState(1);
const onCountClick = () => {
setCount((preState) => {
const newState = preState + 1;
return newState;
});
};
const callback = () => {
console.log(count);
};
return (
<div>
<button onClick={onCountClick}>{count}</button>
<Demo callback={callback} />
</div>
);
};
class App extends React.Component {
render() {
return <Container />;
}
}
ReactDOM.render(<App />, document.getElementById("container"));
demo链接:https://codesandbox.io/s/reac...
先点击count改变count的值,再点击scroller打印count,发现每次打印的都是初始值。
求解答