我们需要为我们的React组件提供一些标识符,以便我们可以在这些控件上进行自动化测试用例编写。
import React from 'react';
import ReactDOM from 'react-dom';
import { Grid, GridColumn as Column } from '@progress/kendo-react-grid';
import products from './products.json';
class App extends React.Component {
state = {
gridData: products
}
render() {
return (
<div>
<Grid
data-grid="myGrid"
style={{ height: '400px' }}
data={this.state.gridData}
>
<Column field="ProductID" title="ID" width="40px" />
<Column field="ProductName" title="Name" width="200px" />
<Column field="Category.CategoryName" title="CategoryName" />
<Column field="UnitPrice" title="Price" width="80px" />
<Column field="UnitsInStock" title="In stock" width="80px" />
<Column field="Discontinued" width="120px"
cell={(props) => (
<td>
<input disabled type="checkbox" checked={props.dataItem[props.field]} />
</td>
)} />
</Grid>
</div>
);
}
}
ReactDOM.render(
<App />,
document.querySelector('my-app')
);
我们尝试向网格提供 data-grid =“ myGrid” 属性,但这似乎不起作用。您能否提出这里的错误或解决方法?
答案 0 :(得分:0)
您应该使用camelCase
传递道具,因此应该像这样:
<Grid dataGrid="myGrid" />
在Grid
内,您可以这样指定:
const Grid = ({dataGrid}) => (
<div data-grid={dataGrid} />
)
或者您可以仅将id
设置为组件<Grid id="myGrid" />