如何为反应组件提供ID或属性

时间:2018-09-24 17:17:42

标签: html reactjs react-native kendo-ui custom-data-attribute

我们需要为我们的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” 属性,但这似乎不起作用。您能否提出这里的错误或解决方法?

1 个答案:

答案 0 :(得分:0)

您应该使用camelCase传递道具,因此应该像这样:

<Grid dataGrid="myGrid" />

Grid内,您可以这样指定:

const Grid = ({dataGrid}) => (
   <div data-grid={dataGrid} />
)

或者您可以仅将id设置为组件<Grid id="myGrid" />