首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在状态中使用解构赋值

在状态中使用解构赋值
EN

Stack Overflow用户
提问于 2019-04-19 15:54:41
回答 2查看 234关注 0票数 0
代码语言:javascript
复制
class BottomPanelProgramTabs extends React.Component<Props, State> {
  state = {
    activeTab: this.props.children[0].props.label,
  };

...

ESLint希望我使用解构赋值

代码语言:javascript
复制
this.props.children[0].props.label

你有什么建议吗?

EN

回答 2

Stack Overflow用户

发布于 2019-04-19 16:32:56

你可以这样做。For more reference about prefer-destructuring

代码语言:javascript
复制
class BottomPanelProgramTabs extends React.Component<Props, State> {
  constructor(){
        let [props] = this.props.children;
         state = {
          activeTab : props.label
         }

   }
票数 1
EN

Stack Overflow用户

发布于 2019-04-19 16:56:34

代码语言:javascript
复制
 class BottomPanelProgramTabs extends React.Component<Props, State> {

  state = {
    activeTab: 'default label'
  };

  componentDidMount = () => {

    const [{ props: { label } }] = this.props.children;

    this.setState({
      activeTab: label || 'default label',
      ...
    })
  }

  ...

您可以通过使用[]获取第一个元素并使用{}获取道具来混合析构。

例如的

使用[child]可以得到数组中的第一个元素。

代码语言:javascript
复制
const children = [{
    props: {
      label: 'Some label'
    }
  },
  {
    props: {
      label: 'Second label'
    }
  },

  ,
  {
    props: {
      label: 'another label'
    }
  }]
  
  const [child] = children;
  
  console.log(child);

为了获得props,我们可以通过添加返回props对象的[ {props} ]来继续混合销毁。

代码语言:javascript
复制
const children = [{
    props: {
      label: 'Some label'
    }
  },
  {
    props: {
      label: 'Second label'
    }
  },

  ,
  {
    props: {
      label: 'another label'
    }
  }]
  
  const [ {props} ] = children;
  
  console.log(props);

要从props获取label,will可以这样做:[{ props: { label } }]

代码语言:javascript
复制
const children = [{
    props: {
      label: 'Some label'
    }
  },
  {
    props: {
      label: 'Second label'
    }
  },

  ,
  {
    props: {
      label: 'another label'
    }
  }]
  
  const [{ props: { label } }] = children;
  
  console.log(label);

具有复杂data

代码语言:javascript
复制
const children = [{
    props: {
      label: [{
        data: {
          title: 'complex destructor'
        }
      },
      {
        data: {
          title: 'complex destructor 2'
        }
      }]
    }
  },
  {
    props: {
      label: 'Second label'
    }
  },

  ,
  {
    props: {
      label: 'another label'
    }
  }]

 const [{ props: { label: [ { data: { title } } ] } }] = children;

console.log(title)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55758475

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档