uniapp 中的 #ifndef 条件编译

在 UniApp 中,#ifndef条件编译 的语法,意思是 "if not defined"(如果未定义)。

基本语法

javascript 复制代码
#ifndef 平台名称
// 这里的代码只在指定平台不存在时编译
#endif

实际应用示例

1. 平台特定代码

javascript 复制代码
// 只有在非 H5 平台才编译这段代码
#ifndef H5
console.log('这段代码在 H5 平台不会执行');
// 可以写一些小程序特有的 API 调用
#endif

// 只有在非微信小程序才编译
#ifndef MP-WEIXIN
console.log('这段代码在微信小程序不会执行');
#endif

2. 与 #ifdef 配合使用

javascript 复制代码
#ifdef MP-WEIXIN
console.log('只在微信小程序执行');
#else
console.log('在除微信小程序外的其他平台执行');
#endif

3. 多平台判断

javascript 复制代码
#ifndef APP-PLUS && !H5
console.log('既不是 App 也不是 H5 平台');
#endif

常用平台标识符

  • H5 - H5 平台
  • MP-WEIXIN - 微信小程序
  • MP-ALIPAY - 支付宝小程序
  • APP-PLUS - App 平台
  • MP - 所有小程序平台

实际使用场景

javascript 复制代码
// 根据不同平台使用不同的 API
#ifndef H5
// 小程序和 App 中使用 uni 的 API
uni.showToast({
  title: '提示信息'
});
#endif

#ifdef H5
// H5 平台使用浏览器原生 API
alert('提示信息');
#endif

总结#ifndef 让你可以针对不同平台编写不同的代码,在编译时只会保留对应平台的代码,其他平台的代码会被过滤掉。

相关推荐
IT_陈寒13 分钟前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu35 分钟前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript
这是程序猿1 小时前
Spring Boot自动配置详解
java·大数据·前端
文心快码BaiduComate1 小时前
干货|Comate Harness Engineering工程实践指南
前端·后端·程序员
还有多久拿退休金1 小时前
一张栈的图,治好你面试答不出 script 阻塞的病
前端·javascript
光辉GuangHui1 小时前
Agent Skill 也需要测试:如何搭建 Skill 评估框架
前端·后端·llm
To_OC1 小时前
我终于搞懂 Claude Code 核心逻辑!90%的人都用错了模式
前端·ai编程
蓝宝石的傻话1 小时前
Headless浏览器的隐形陷阱:为什么你的AI自动化工具抓不到页面早期错误?
前端
irving同学462381 小时前
Node 后端实战:JWT 认证与生产级错误处理
前端·后端
莽夫搞战术1 小时前
【Google Stitch】AI原生画布重新定义设计,让想法变成可交互界面
前端·人工智能·ui