R<match.call(expand.dots=FALSE)详解>

本文深入探讨了R语言中match.call()函数的使用方法,特别是expand.dots参数的作用。通过对比expand.dots为TRUE和FALSE时的行为差异,揭示了省略号参数(...)的解析机制。

在R语言很多源码中会看到match.call(expand.dots=FALSE)的代码,刚开始还是看不懂这是什么意思。查一下API:
https://www.rdocumentation.org/packages/base/versions/3.5.1/topics/match.call

在这里插入图片描述
简单看,这个函数会在一般都是写在另外一个函数里边。其会返回其宿主函数体的入参的匹配关系。具体看下面的代码:
在下面的这段代码中,我在expand_FALSE中调用了match.call()函数,并输出expand_FALSE的调用具体形式,并输出expand_FALSE的所有参数名称,以及参数的个数。

expand_FALSE<-function (formula, data, subset, na.action = na.pass, weights, 
    offset, cluster, strata, scores = NULL, yx = c("none", "matrix"), 
    ytype = c("vector", "data.frame", "matrix"), nmax = c(yx = Inf, 
        z = Inf), ...) 
{
     cl <- match.call(expand.dots = FALSE)
     print('=======================================')
     print(cl)
     print('=======================================')

     clnam <- names(cl)[-1L]
     print(clnam)
     print(length(clnam))
     

}

在这里插入图片描述

可以看到expand_FALSE函数的实参与形参之间的对应关系,以及该函数的参数的个数为13个。

match.call()中的默认参数expand_dots=TRUE,那么这个参数的取值有什么实际意义呢?请看下面的代码:

expand_TRUE<-function (formula, data, subset, na.action = na.pass, weights, 
    offset, cluster, strata, scores = NULL, yx = c("none", "matrix"), 
    ytype = c("vector", "data.frame", "matrix"), nmax = c(yx = Inf, 
        z = Inf), ...) 
{
     cl <- match.call(expand.dots = TRUE)
     print('=======================================')
     print(cl)
     print('=======================================')

     clnam <- names(cl)[-1L]
     print(clnam)
     print(length(clnam))
}

这段代码与上面的代码不同之处在于我将match.call()中的expand.dots又FALSE改成了TRUE,执行结果有什么不同呢?

在这里插入图片描述

可以看到这里的执行结果中参数个数变成了15个。说明了什么,如果expand.dots=FALSE,那么函数会将“…”单独看作一个参数,但是当该值为TRUE的时候,"…"会被解析称三个参数。

题外话:

自从今年七月初从学校毕业,到公司报道之后就好懒,都没怎么更新博客。这算是真正意义上的又一篇博客吧。

### Vue 中 'key' 是保留属性的警告问题解决方案 在 Vue.js 开发过程中,可能会遇到 `[Vue warn]: Invalid prop: key is a reserved property` 的警告。这是因为 `key` 属性是一个由 Vue 预定义并用于内部优化的特殊属性,因此它不能作为自定义组件的 `props` 使用。 以下是详细的分析和解决方法: #### 1. 错误原因 当尝试将 `key` 定义为子组件的一个 `prop` 时,会触发此警告。因为 `key` 已经被 Vue 占用,用来唯一标识 DOM 元素或组件实例以便于虚拟 DOM 的高效更新[^4]。 #### 2. 解决方案 为了消除该警告,可以采取以下措施之一: - **重命名 Prop** 将 `key` 替换为其他不会冲突的名字,比如 `itemKey` 或者类似的名称。这可以通过修改子组件中的 `props` 定义来完成。 ```javascript // 子组件 (ChildComponent.vue) export default { props: { itemKey: { // 修改后的 prop 名称 type: String, required: true } }, mounted() { console.log('Received Key:', this.itemKey); } }; ``` - **移除不必要的 Prop 定义** 如果确实不需要通过 `props` 来传递数据,则可以直接删除对 `key` 的声明,并确保父级只将其作为模板内的键值使用。 ```vue <!-- 父组件 --> <template> <child-component v-for="item in items" :key="item.id"></child-component> </template> <script> import ChildComponent from './ChildComponent'; export default { components: { ChildComponent }, data() { return { items: [{ id: 1 }, { id: 2 }] }; } }; </script> ``` - **使用 Alias 别名映射** 若希望保持语义化的同时又避开关键字冲突,可以在父组件中创建一个新的变量代替原始的 `key` 字段再绑定到目标属性上去。 ```html <!-- Parent Component --> <template> <custom-element :alias-key="element.key"/> </template> ``` #### 3. 注意事项 尽管更改了外部接口设计从而解决了当前的技术难题,但在项目维护期间仍需注意团队成员之间对于新字段含义的理解一致性;另外也要记得及时更新文档说明这些改动之处以免造成后续开发人员困惑。 ```javascript // 正确示例:避免直接使用 key 作为 prop export default { props: ['uniqueIdentifier'], // 更改 prop 名称为 uniqueIdentifier }; ``` ```html <!-- 正确示例:父组件正确传递参数 --> <my-component v-bind:unique-identifier="'someValue'" /> ```
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值