# 特性 ### 特性配置规则 下面介绍feature的声明、定义以及使用方法。 - feature的声明 在部件的bundle.json文件中通过feature_list来声明部件的feature列表,每个feature都必须以"**{部件名}**"开头。示例如下: ``` { "name": "@ohos/xxx", "component": { "name": "partName", "subsystem": "subsystemName", "features": [ "{partName}_feature_A" ] } } ``` features中可以为部件声明多个feature。 - feature的定义 在部件内可通过以下方式定义feature的默认值: ``` declare_args() { {partName}_feature_A = true } ``` 该值是此部件的默认值,产品可以在部件列表中重载该feature的值。 feature需给部件内多个模块使用时,建议把feature定义在部件的全局gni文件中,各个模块的BUILD.gn中import该gni文件。 - feature的使用 BUILD.gn文件中可通过以下方式进行根据feature决定部分代码或模块参与编译: ``` if ({partName}_feature_A) { sources += [ "xxx.c" ] } # 某个特性引入的依赖,需要通过该feature进行隔离 if ({partName}_feature_A) { deps += [ "xxx" ] external_deps += [ "xxx" ] } # bundle.json中不支持if判断,如果bundle.json中包含的sub_component需要被裁减,可以定义group进行裁减判断 group("testGroup") { deps = [] if ({partName}_feature_A) { deps += [ "xxx" ] } } ``` 也可以通过以下方式为模块定义代码宏进行代码级差异化配置: ``` if ({partName}_feature_A) { defines += ["FEATUREA_DEFINE"] } ```