React项目中那些奇怪的写法

一、在一个React组件里看到一个奇怪的写法:javascript

 const {matchs} = this.props.matchs;

原来,是解构赋值,虽然据说过,可是看起来有点奇怪java

下面作个实验:react

 <script type="text/javascript">
        var props = {
            key1: 123 + "",
            key2: 456,
            key3: 789
        }
        const { key1 } = props
        console.log(key1, typeof (key1))

 </script>

原来能够减小很多代码量es6

 

二、以下npm

 

npm install graphql-tag --save
import gql from 'graphql-tag';
import { Query } from 'react-apollo';
 
const GET_DOGS = gql`
  {
    dogs {
      id
      breed
    }
  }
`;
 
const Dogs = ({ onDogSelected }) => (
  <Query query={GET_DOGS}>
    {({ loading, error, data }) => {
      if (loading) return 'Loading...';
      if (error) return `Error! ${error.message}`;
 
      return (
        <select name="dog" onChange={onDogSelected}>
          {data.dogs.map(dog => (
            <option key={dog.id} value={dog.breed}>
              {dog.breed}
            </option>
          ))}
        </select>
      );
    }}
  </Query>
);

 

很明显,return里这个箭头函数的参数将是传入一个对象, 而且极可能不止3个属性,所以进行结构赋值以取属性来用。只有当函数的参数是一个对象时,变量segmentfault

loading, error, data

才会经过解构赋值生成。若是函数调用时没提供参数,变量函数

loading, error, data

就不会生成,并报错。this

 

为何gal后面跟一个字符串?spa

 

原来是模板字符串的功能:它能够紧跟在一个函数名后面,该函数将被调用来处理这个模板字符串。这被称为“标签模板”功能(tagged template)code

alert`123`
// 等同于
alert(123)

 

参考:http://es6.ruanyifeng.com/#docs/string

 

三、

@withHeader
export default class Demo extends Component {
  render() {
    return (
      <div>
        我是一个普通组件
      </div>
    );
  }
}

在这里使用了ES7里的decorator,来提高写法上的优雅,可是实际上它只是一个语法糖,下面这种写法也是能够的:

const EnhanceDemo = withHeader(Demo);

参考:https://segmentfault.com/a/1190000010371752

相关文章
相关标签/搜索