gpt4 book ai didi

javascript - ReactJS react-grid-layout 切换静态属性

转载 作者:行者123 更新时间:2023-12-03 01:54:20 35 4
gpt4 key购买 nike

我已经学习 React 几天了,这次我尝试创建一个可拖动小部件的网格,我在 github 上找到了这个库:react-grid-layout这是这样做的。

这一次,我尝试在单击按钮时切换可拖动或静态属性,但这样做时遇到了一些麻烦。

这是我的App.js:

import React, { Component } from 'react';
import {InputText} from 'primereact/components/inputtext/InputText';
import GridLayout from 'react-grid-layout';
import './App.css';

class App extends Component {
render() {
var layout = [
{i: 'a', x: 0, y: 0, w: 10, h: 4},
{i: 'b', x: 1, y: 0, w: 3, h: 2},
{i: 'c', x: 4, y: 0, w: 1, h: 2}
];
return (
<React.Fragment>
<button onClick={this.toggleStatic (layout)}>Enable</button>
<GridLayout className="layout" layout={layout} cols={30} rowHeight={30} width={1200} onDragStop={this.onDragStop}>
<div key="a">a</div>
<div key="b">b</div>
<div key="c">c</div>
</GridLayout>
</React.Fragment>
);
}

toggleStatic(layout) {
console.log('Layout', layout);
}

onDragStop(layout) {
layout[0].static = true;
console.log(layout);
}
}

export default App;

我的index.js:

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import registerServiceWorker from './registerServiceWorker';
import 'react-grid-layout/css/styles.css';
import 'react-resizable/css/styles.css';
import 'primereact/resources/themes/omega/theme.css';
import 'primereact/resources/primereact.min.css';

ReactDOM.render(<App />, document.getElementById('root'));
registerServiceWorker();

还有我的index.css:

body {
margin: 0;
padding: 0;
font-family: sans-serif;
}

.react-grid-item:not(.react-grid-placeholder) {
background-color: #ccc;
border: 1px solid black;
}

.layout {
background-color: #333;
}

.title {
font-weight: bold;
}

如果我检查我的控制台,在重新加载页面后,我会在任何点击之前将我的布局登录到其中:

Layout […]
​0: Object { i: "a", x: 0, y: 0, … }
1: Object { i: "b", x: 1, y: 0, … } ​
2: Object { i: "c", x: 4, y: 0, … } ​
length: 3
__proto__: Array []

但是如果我将我的按钮更改为:

<button onClick={this.toggleStatic}>Enable</button>

即从中删除参数 layout ,我在控制台中得到以下输出:

Layout Proxy
<target>: Object { … }
<handler>: Object { … }

现在,当拖动任何组件时,我的代码会将第一个小部件的 static 更改为 true,我试图在单击按钮时更改所有组件.

我发现这篇关于图书馆问题的帖子:Assign static dinamically/programatically ,但他们正在使用 react-redux

我发现他们也使用这个:

const mapStateToProps = state => {
return {
...state.dashboard.asMutable()
};
};

但我不确定那是做什么的。

任何至少将 layout var 接收到 toggleStatic 中的建议对我来说可能就足够了。

最佳答案

{this.toggleStatic (layout)} 将在 render 上触发该函数,而不是 onClick,因此您必须更改:

<button onClick={this.toggleStatic (layout)}>Enable</button>

至:

<button onClick={() => this.toggleStatic(layout)}>Enable</button>

然后,当您单击按钮时,您将获得布局。

状态中添加布局:

// ...
class App extends Component {
state = {
layout: [
{i: 'a', x: 0, y: 0, w: 10, h: 4},
{i: 'b', x: 1, y: 0, w: 3, h: 2},
{i: 'c', x: 4, y: 0, w: 1, h: 2}
]
}
render() {
return (
<React.Fragment>
<button onClick={() => this.toggleStatic(this.state.layout)}>Enable</button>
<GridLayout className="layout" layout={this.state.layout} cols={30} rowHeight={30} width={1200} onDragStop={this.onDragStop}>
<div key="a">a</div>
<div key="b">b</div>
<div key="c">c</div>
</GridLayout>
</React.Fragment>
);
}

// ...

然后在 toggleStatic 函数中执行如下操作:

toggleStatic(layout){
var newLayout = layout.map(l => {
return {...l, static: !l.static || true}
})
this.setState({
layout: newLayout
})
}

关于javascript - ReactJS react-grid-layout 切换静态属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50298107/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com