Uniapp 条件编译详解

Uniapp 条件编译详解

条件编译是 Uniapp 中非常重要的功能,它允许开发者针对不同平台编写特定的代码,从而实现一套代码多端运行的效果。

一、基本语法

1. 以 #ifdef 或 #ifndef 开头

javascript 复制代码
// #ifdef 平台名称
平台特定代码
// #endif

// #ifndef 平台名称
非该平台代码
// #endif

2. 多平台判断

javascript 复制代码
// #ifdef MP-WEIXIN || H5
微信小程序或H5平台代码
// #endif

二、平台标识符

平台 标识符 说明
微信小程序 MP-WEIXIN
支付宝小程序 MP-ALIPAY
百度小程序 MP-BAIDU
字节跳动小程序 MP-TOUTIAO
QQ小程序 MP-QQ
H5 H5 浏览器环境
App APP 包括APP-PLUS和APP-NVUE
iOS APP-PLUS或IOS App的iOS平台
Android APP-PLUS或ANDROID App的Android平台
快应用 QUICKAPP-WEBVIEW 华为快应用

三、使用场景

1. 模板中使用

html 复制代码
<!-- 只在微信小程序中显示 -->
<!-- #ifdef MP-WEIXIN -->
<view>微信小程序特有内容</view>
<!-- #endif -->

<!-- 在H5和App中显示 -->
<!-- #ifdef H5 || APP -->
<view>H5和App显示的内容</view>
<!-- #endif -->

2. 样式中使用

css 复制代码
/* 只在App中生效的样式 */
/* #ifdef APP */
.my-view {
  padding-top: 20px;
}
/* #endif */

/* 非H5平台的样式 */
/* #ifndef H5 */
.my-text {
  font-size: 16px;
}
/* #endif */

3. JavaScript中使用

javascript 复制代码
// 平台特定的API调用
// #ifdef MP-WEIXIN
wx.login({
  success(res) {
    console.log(res.code);
  }
});
// #endif

// #ifdef H5
console.log('这是在浏览器环境中');
// #endif

4. 页面路由处理

javascript 复制代码
// 不同平台跳转方式不同
function navigateTo(url) {
  // #ifdef H5
  window.location.href = url;
  // #endif
  
  // #ifdef MP-WEIXIN
  wx.navigateTo({ url });
  // #endif
  
  // #ifdef APP
  uni.navigateTo({ url });
  // #endif
}

四、高级用法

1. 多条件组合

javascript 复制代码
// #ifdef MP-WEIXIN || MP-ALIPAY
// 微信或支付宝小程序特有逻辑
// #endif

2. 条件编译块嵌套

javascript 复制代码
// #ifdef APP
// #ifdef IOS
console.log('这是iOS平台');
// #endif
// #ifdef ANDROID
console.log('这是Android平台');
// #endif
// #endif

3. 文件整体条件编译

可以在文件顶部添加条件编译,整个文件只在特定平台被引入:

javascript 复制代码
// #ifdef MP-WEIXIN
// 整个文件只在微信小程序中有效
export default {
  data() {
    return {
      weixinSpecificData: true
    }
  }
}
// #endif

五、manifest.json 中的条件编译

json 复制代码
{
  "mp-weixin": {
    /* 微信小程序特有配置 */
  },
  "h5": {
    /* H5特有配置 */
  },
  "app-plus": {
    /* App特有配置 */
  }
}

六、package.json 中的条件编译

json 复制代码
{
  "uni-app": {
    "scripts": {
      "mp-weixin": {
        "title": "微信小程序"
      },
      "h5": {
        "title": "H5"
      }
    }
  }
}

七、注意事项

  1. 注释语法必须正确 :条件编译注释必须使用 // 而不能使用 /* */
  2. 空格要求#ifdef 和平台名称之间必须有空格
  3. 大小写敏感 :平台标识符必须完全匹配(如 MP-WEIXIN 不能写成 mp-weixin
  4. 文件条件编译:文件整体条件编译时,文件内容必须全部包含在条件编译块中
  5. 性能影响:条件编译不会增加最终包的体积,因为编译时会移除其他平台的代码

八、实际应用示例

1. 平台特定组件

html 复制代码
<template>
  <view>
    <!-- 公共部分 -->
    <view>所有平台都显示的内容</view>
    
    <!-- 平台特定部分 -->
    <!-- #ifdef MP-WEIXIN -->
    <weixin-specific-component />
    <!-- #endif -->
    
    <!-- #ifdef H5 -->
    <h5-specific-component />
    <!-- #endif -->
  </view>
</template>

<script>
// 平台特定的组件引入
// #ifdef MP-WEIXIN
import weixinSpecificComponent from './weixin-component.vue';
// #endif

// #ifdef H5
import h5SpecificComponent from './h5-component.vue';
// #endif

export default {
  components: {
    // #ifdef MP-WEIXIN
    weixinSpecificComponent,
    // #endif
    
    // #ifdef H5
    h5SpecificComponent
    // #endif
  }
}
</script>

2. API 兼容处理

javascript 复制代码
function getStorage(key) {
  // #ifdef MP-WEIXIN
  return wx.getStorageSync(key);
  // #endif
  
  // #ifdef H5
  return localStorage.getItem(key);
  // #endif
  
  // #ifdef APP
  return uni.getStorageSync(key);
  // #endif
}

通过合理使用条件编译,可以大大减少为不同平台维护多套代码的工作量,同时又能保证各平台的体验最佳。

相关推荐
Q_Q19632884753 小时前
python+uniapp基于微信美食点餐系统小程序
spring boot·python·微信·django·flask·uni-app·node.js
阿金要当大魔王~~4 小时前
uniapp 请求携带数据 \\接口传值 \\ map遍历数据
前端·javascript·uni-app
2501_915106327 小时前
HTTPS 爬虫实战指南 从握手原理到反爬应对与流量抓包分析
爬虫·网络协议·ios·小程序·https·uni-app·iphone
2501_916007477 小时前
iOS 上架技术支持全流程解析,从签名配置到使用 开心上架 的实战经验分享
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_916007471 天前
提升 iOS 26 系统流畅度的实战指南,多工具组合监控
android·macos·ios·小程序·uni-app·cocoa·iphone
砺能1 天前
uniapp生成的app添加操作日志
前端·uni-app
2501_915921431 天前
iOS 应用代上架流程,多工具组合与使用 开心上架 跨平台自动化上传指南
android·ios·小程序·uni-app·自动化·cocoa·iphone
知识分享小能手1 天前
uni-app 入门学习教程,从入门到精通,uni-app组件 —— 知识点详解与实战案例(4)
前端·javascript·学习·微信小程序·小程序·前端框架·uni-app
雪芽蓝域zzs1 天前
uniapp 修改android包名
android·uni-app
芒果沙冰哟1 天前
uniapp canvas实现手写签字功能(包括重签,撤回等按钮)
uni-app