# 只跨 Web 与小程序的应用
# 背景介绍
通常情况下,cml 框架会生成跨 H5、小程序、客户端的应用。为了 H5、小程序、客户端初始样式呈现效果一致,cml 会添加一致性基础样式。在开发模式下,构建会严格校验 CMSS 语法,只允许书写跨 H5、小程序、客户端都通用的 CMSS 规则。因此,受限于客户端的 CMSS 渲染能力,开发会有诸多限制,另一方面,当开发者只需要跨 H5 和小程序应用时,开发会变得很轻便。
通过下面的表格,展示 CMSS 跨端 能力差异:
CSS属性 | H5 | 小程序 | weex |
---|---|---|---|
布局 | all | all | flexbox |
盒模型 | all | all | 只支持display:border-box |
float浮动 | ✅ | ✅ | ❌ |
display:inline-block|none | ✅ | ✅ | ❌ |
ID选择器 | ✅ | ✅ | ❌ |
类选择器 | ✅ | ✅ | ✅ |
属性选择器 | ✅ | ✅ | ❌ |
级联选择器、派生选择器(后代、子元素、相邻兄弟) | ✅ | ✅ | ❌ |
选择器分组 | ✅ | ✅ | ✅ |
伪类(:active|:focus) | ✅ | ✅ | ✅ |
伪类(:hover|:link|:visited|:first-child|:lang) | ✅ | ✅ | ❌ |
伪元素(:first-letter|:first-line|:before|:after) | ✅ | ✅ | ❌ |
百分比定值 | ✅ | ✅ | ❌ |
line-height:1 | ✅ | ✅ | ❌ |
尺寸 | px|rem|em|vw|vh | px|rpx | px |
!important | ✅ | ✅ | ❌ |
# 项目初始化与配置
以 merge config 的方式修改项目根目录下的
chameleon.config.js
,如下:
cml.config.merge({
platforms: ['web', 'wx', 'alipay', 'baidu'],
});
# CMSS
此时,CMSS 语法和可用属性,不再受限于客户端的渲染。CMSS 遵循 W3C 层叠样式表(Cascading Style Sheets,缩写为 CSS)规范,在此基础上,小程序的标准样式会有一些限制。
# 一致性基础样式可选
如果你希望去除小程序、客户端的的一致性基础样式,修改项目根目录下的 chameleon.config.js
,如下:
cml.config.merge({
baseStyle: {
wx: false,
alipay: false,
baidu: false,
web: true,
weex: false,
},
});
如果你希望更细粒度的去配置某一组件或者页面是否去除基本样式,可以在对应组件或者页面的 json 文件中配置 baseStyle 字段,baseStyle 为 false 时表示该组件或页面不添加默认样式,不配置该字段时是默认添加默认样式的。示例如下:
<script cml-type="json">
{
"base": {
"baseStyle": true,
"usingComponents": {
"demo-com": "/components/demo-com/demo-com"
}
},
"web": {
"baseStyle": false
},
"wx": {
"baseStyle": true,
"navigationBarTitleText": "index",
"backgroundTextStyle": "dark",
"backgroundColor": "#E2E2E2"
},
"alipay": {
"baseStyle": false,
"defaultTitle": "index",
"pullRefresh": false,
"allowsBounceVertical": "YES",
"titleBarColor": "#ffffff"
}
}
</script>