uniapp中打包应用后,组件在微信小程序和其他平台实现不同的样式

今天,我们来介绍一下,uniapp中如何实现打包应用后,组件在微信小程序和其他平台不同的样式,在这里,我们使用背景颜色进行演示,使用 UniApp 提供的 uni.getSystemInfoSync() 方法来获取系统信息,包括平台类型。以下是代码示例:

javascript 复制代码
<template>
  <view :class="bgClass"></view>
</template>

<script>
export default {
  data() {
    return {
      isWx: false,
    };
  },
  created() {
    // 获取系统信息
    const systemInfo = uni.getSystemInfoSync();
    this.isWx = systemInfo.platform === 'devtools' || systemInfo.platform === 'wechat'; // 判断是否为微信小程序
  },
  computed: {
    bgClass() {
      return this.isWx ? 'bg-wx' : 'bg-other';
    },
  },
};
</script>

<style>
.bg-wx {
  background-color: #ff0000; /* 微信小程序的背景颜色 */
}

.bg-other {
  background-color: #00ff00; /* 其他平台的背景颜色 */
}
</style>

解释:

  1. 获取系统信息 :在 created 生命周期钩子中,使用 uni.getSystemInfoSync() 方法获取系统信息,并判断平台是否为微信小程序。
  2. 计算属性 :根据 isWx 的值来决定使用哪个 CSS 类。
  3. 样式定义 :在 <style> 中定义了两个不同的背景颜色类。
相关推荐
hi大雄7 分钟前
我的 2025 —— 名为《开始的勇气》🌱
前端·年终总结
从文处安20 分钟前
「前端何去何从」一直写 Vue ,为何要在 AI 时代去学 React?
前端·react.js
aircrushin35 分钟前
OpenClaw“养龙虾”现象的社会技术学分析
前端·后端
明君8799744 分钟前
#Flutter 的官方Skills技能库
前端·flutter
yuki_uix1 小时前
重新认识 React Hooks:从会用到理解设计
前端·react.js
林太白1 小时前
ref和reactive对比终于学会了
前端
Apifox1 小时前
测试数据终于不用到处复制了,Apifox 自动化测试新增「共用测试数据」
前端·后端·测试
小小小小宇1 小时前
Mac龙虾保姆级完整部署指南
前端
睡不着的可乐1 小时前
vue2 和 vue3自定义指令有什么区别,都是怎么实现和使用一个指令
前端·vue.js
闲来没事抠鼻屎1 小时前
Web打印插件实战:轻量化JS打印方案vue-print-designer落地指南
前端