@selector 注意的地方

本文探讨了Objective-C中objc_msgSend的使用方法及其注意事项,特别是@selector在消息传递中的角色,强调了函数签名的重要性及如何避免因参数不匹配导致的程序崩溃。

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

objc_msgSend(self, @selector(msgBoxtitle:msg:), _(@"ReInput"), nil);

 

@selector(msgBoxtitle:msg:) 如果因为参数不完整,而写了一个函数名字布匹配的函数,那么系统将崩溃。

 

msgBoxtitle:msg: 函数名是全部,包括函数的参数修饰部分。这也是为什么object-c没有函数的重载,它是通过

对参数的描述来区分不同的函数。

### 原因分析 'SassError: expected selector' 错误通常源于 Sass 或 SCSS 文件中的语法错误或选择器定义不当,这使得 Sass 编译器无法正常解析文件内容[^1]。具体来说,在 Vue 项目中使用样式穿透 `/deep/` 报错的情况表明该写法已被弃用,并不再受支持;因此可能导致编译失败[^2]。 此外,此问题也可能由 `sass-loader` 和 `node-sass` 版本之间的兼容性引起。当两者版本不匹配时,可能会触发类似的编译错误。降低 `sass-loader` 至较低版本可以作为解决方案之一[^3]。 ### 解决方案 针对上述情况,有几种方法来解决问题: #### 方法一:更新深度作用选择器的书写方式 对于已废弃的选择器如 `/deep/` ,应替换为新的推荐形式 `::v-deep` 或者采用 CSS Modules 来实现相同效果。以下是修改后的代码示例: ```scss .van-cell { ::v-deep .van-cell__title { font-size: .3rem; font-weight: bold; color: #141C23; } } ``` #### 方法二:调整依赖包版本 如果怀疑是因为工具链版本冲突引起的,则可以通过安装特定版本组合的方式来尝试解决。例如,可以根据官方文档建议设置合适的 `sass-loader` 及其关联库版本。 #### 方法三:检查并修正潜在的语法错误 仔细审查所有涉及的 Sass/SCSS 文件,确保没有遗漏或者多余的字符影响到选择器的有效性。任何不符合语法规则的地方都可能引发此类异常。 ### 注意事项 - 如果团队成员在同一环境中操作却未遇相同问题,可能是本地开发环境配置差异所致。此时需同步各开发者机器上的相关软件及其版本。 - 对于 Mac 用户而言,虽然操作系统本身不太可能是直接原因,但仍要注意是否存在平台特有的路径处理或其他细微差别影响构建过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值