JSX那些不一致的标准属性[一源一世界][之React]

通过阅读React的关于JSX的官方文档,我们知道在JSX声明标准HTML元素(如div)的属性时,有一些比较特殊的在命名上与标准属性有点出入,例如className

var myDivElement = <div className="foo" />;

经过JSX编译器后,它的实际JS代码如下:

var myDivElement = React.createElement("div", { className: "foo" });

显示,class是Javascript的保留关键字,所以不能当对象的key用,那还有哪些属性呢?我们直接看源码吧。

HTMLDOMPropertyConfig.js的源码中,就声明了JSX与HTML标准属性命名上不同的属性对应关系,目前一共有4个。

DOMAttributeNames: {
  acceptCharset: 'accept-charset',
  className: 'class',
  htmlFor: 'for',
  httpEquiv: 'http-equiv',
},

DOMProperty.jsinjectDOMPropertyConfig,就通过DOMAttributeNames取得JSX属性对应的标准属性及其值

if (DOMAttributeNames.hasOwnProperty(propName)) {
  var attributeName = DOMAttributeNames[propName];
  propertyInfo.attributeName = attributeName;
  ...
}

这样子就简单地完成了JSX属性与HTML标准属性的转换了


题外话,从JSX Gotchas这篇文章谈到对于标准的HTML元素,React只会渲染标准属性(如name),自定义的属性(如daniel)会被忽略掉,除非加前缀data-或aria-(如data-daniel or aria-daniel)。

那我们从源码来瞧瞧是不是这样。(注意:自定义组件类型的属性是不受上面规则的约束的,因为源码里面压根没处理嘛,哈)

DOMProperty.jsinjectDOMPropertyConfig代码中只是对domPropertyConfig.Properties进行遍历,domPropertyConfig.Properties定义了一些标准属性,所以非标准属性都会被忽略掉

var Properties = domPropertyConfig.Properties || {};
...

for (var propName in Properties) {
    ....
}

HTMLDOMPropertyConfig.js的源码中,可以看出前缀为data-aria-的属性即被判断为自定义属性。

isCustomAttribute: RegExp.prototype.test.bind(
  new RegExp('^(data|aria)-[' + DOMProperty.ATTRIBUTE_NAME_CHAR + ']*$')
),

--EOF--

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原教程内容详见精益 React 学习指南,这只是我在学习过程中的一些阅读笔记,个人觉得该教程讲解深入浅出,比目前大...
    leonaxiong阅读 7,831评论 1 18
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,680评论 1 92
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,195评论 4 61
  • 配方: 低粉:360 细糖:120g 盐:3g 黄奶油:60g 淡奶油:60g 纯牛奶:1020g 全蛋:360g...
    萝卜爱苹果阅读 1,495评论 0 0
  • 山中花农阅读 3,984评论 0 0