eslint-config-ts-lib
Version:
ts-lib-scripts创建的ts库项目使用的ESLint配置
85 lines (67 loc) • 1.88 kB
Markdown
> 来自 [undefined](undefined) 的规则。
Currently, two ways are supported by React to refer to components. The first way, providing a string identifier, is now considered legacy in the official documentation. The documentation now prefers a second method -- referring to components by setting a property on the `this` object in the reference callback.
Examples of **incorrect** code for this rule:
```jsx
var Hello = createReactClass({
render: function () {
return <div ref="hello">Hello, world.</div>;
},
});
```
```jsx
var Hello = createReactClass({
componentDidMount: function () {
var component = this.refs.hello;
// ...do something with component
},
render: function () {
return <div ref="hello">Hello, world.</div>;
},
});
```
Examples of **correct** code for this rule:
```jsx
var Hello = createReactClass({
componentDidMount: function () {
var component = this.hello;
// ...do something with component
},
render() {
return (
<div
ref={(c) => {
this.hello = c;
}}
>
Hello, world.
</div>
);
},
});
```
```js
"react/no-string-refs": [<enabled>, {"noTemplateLiterals": <boolean>}]
```
When set to `true`, it will give warning when using template literals for refs.
Examples of **incorrect** code for this rule:
```jsx
var Hello = createReactClass({
render: function () {
return <div ref={`hello`}>Hello, world.</div>;
},
});
```
```jsx
var Hello = createReactClass({
render: function () {
return <div ref={`hello${index}`}>Hello, world.</div>;
},
});
```
- [react/no-string-refs 官方文档](https://github.com/yannickcr/eslint-plugin-react/blob/HEAD/docs/rules/no-string-refs.md)