ReactNative 代码规范

本文介绍了React组件的最佳实践,包括组件的定义方式、属性类型检查、默认属性设置、命名规范及代码组织等方面的内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 1、每个文件只写一个组件,但是多个无状态组件可以放在单个文件中;

  • 2、有内部状态,方法或要对外暴露ref的组件,用类式组件;

  • 3、无内部状态,方法或无需对外暴露ref的组件,用函数式组件;

  • 4、有内部状态,方法或要对外暴露ref的组件,使用es7类静态属性;

class Button extends Component {
    static propTypes = {
        size: React.PropTypes.oneOf(['large', 'normal', 'small']),
        shape: React.PropTypes.oneOf(['default', 'primary', 'ghost']),
        disabled: React.PropTypes.bool
    };

    static defaultProps = {
        size: 'normal',
        shape: 'default',
        disabled: false
    };
}
  • 5、无内部状态,方法或无需对外暴露ref的组件,使用类静态属性写法;
const HelloMessage = ({name}) => {
  return 
Hello {name}
; } HelloMessage.propTypes = { name: React.PropTypes.string }; HelloMessage.defaultProps = { name: 'camille666' }
  • 6、PropTypes必须;

  • 7、为了调试方便,在组件最上方写displayName;

class Some extends Component {
  static displayName = 'Some';
}
  • 8、react组件文件用jsx,用大驼峰命名jsx文件;

  • 9、jsx的属性值总是使用双引号,其他用单引号;


  • 10、在自闭合组件前加一个空格;

  • 11、不要在jsx{}里两边加空格;

  • 12、不要在等号两边加空格;

  • 13、jsx属性名总是使用驼峰式风格;

  • 14、如果属性值为true,可以直接省略;


  • 15、遍历数组,输出相同的React组件,属性key必须;
[, , ]
  • 16、总是在Refs里使用回调函数;
  • 17、将多行的jsx标签写在()里,单行可忽略();
// 在render方法中
return 
dddd
; return (我是一个盒子)
  • 18、render方法必须有值返回;

  • 19、没有子元素,自闭合;


  • 20、按照以下顺序排序方法;
A、static methods and properties
B、lifecycle methods: displayName, propTypes, contextTypes , childContextTypes, mixins, statics, defaultProps, constructor, getDefaultProps, getInitialState,  state, getChildContext, componentWillMount, componentDidMount, componentWillReceiveProps, shouldComonentUpdate, componentWillUpdate, componentDidUpdate, componentWillUnmount
C、custom methods
D、render method
  • 21、不要在componentDidMount或componentDidUpdate中调用setState,除非在绑定回调函数中设置State;
class Hello extends Component {
    componentDidMount() {
        this.onMount(newName => {
            this.setState({
                name: newName
            });
        });
    }
    render() {
        return 
Hello {this.state.name}
; } }
  • 22、不要给函数添加下划线前缀;

下划线前缀在某些语言中通常表示私有变量或者函数,但是js中没有原生支持所谓的私有变量,所有的变量函数都是共有的。

<think>好的,用户的问题是关于React Native官方推荐的代码风格、规范和最佳实践。我需要先回忆一下React Native的官方文档和相关资源,确保提供的信息准确可靠。首先,React Native本身并没有一个独立的代码规范文档,但通常会遵循React的最佳实践,并结合JavaScript或TypeScript的社区标准。比如,Airbnb的JavaScript风格指南在社区中比较流行,可能被推荐使用。此外,Facebook的代码风格也可能影响React Native,因为React Native是由Facebook开发的。 接下来,用户可能需要具体的配置工具,比如ESLint和Prettier,这些工具可以帮助自动格式化代码,保持一致性。需要提到如何设置这些工具,可能包括安装特定的插件或配置文件,比如使用eslint-config-airbnb或eslint-plugin-react-native。 另外,组件和代码结构方面,React Native推荐使用函数组件和Hooks,而不是类组件,这符合React的最新实践。文件命名规范也很重要,比如使用PascalCase for组件文件,camelCase for其他文件。 样式方面,建议使用StyleSheet API而不是内联样式,以及如何组织样式代码。可能还需要提到使用Flexbox进行布局,因为这是React Native中主要的布局方式。 测试部分,推荐使用Jest和React Testing Library,这也是React Native社区常用的测试工具。 最后,需要确保所有建议都有官方或社区广泛认可的来源,比如React Native官方文档、ESLint的配置文档、Airbnb的指南等,并在引用时正确标注。同时,生成的相关问题要覆盖用户可能进一步关心的方面,比如配置ESLint的步骤、核心组件命名规则、样式管理工具等。</think>关于React Native代码规范,官方建议结合JavaScript/TypeScript社区标准并遵循以下核心实践: 一、基础工具链 1. 代码格式化使用$Prettier$进行自动排版,配合$ESLint$进行静态检查[^1] 2. 推荐配置组合: ```javascript // .eslintrc.js module.exports = { extends: [ 'airbnb', 'plugin:react-native/all', 'prettier' ], plugins: ['react-native'], rules: { 'react-native/no-inline-styles': 'warn' } } ``` 二、组件与代码结构规范 1. 组件定义优先使用函数组件: ```javascript // Good const MyComponent = ({title}) => ( <View> <Text>{title}</Text> </View> ); // Bad class MyComponent extends React.Component { render() { return /*...*/ } } ``` 2. 文件命名规则: - 组件文件:$PascalCase$(如$LoginButton.js$) - 工具类文件:$camelCase$(如$dateUtils.js$) 三、样式规范 1. 推荐使用StyleSheet API: ```javascript const styles = StyleSheet.create({ container: { flex: 1, padding: 16 } }); ``` 2. 布局应优先使用Flexbox布局系统[^2] 四、测试规范 1. 单元测试使用$Jest$框架 2. 组件测试使用$React Testing Library$
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值