依賴(lài)環(huán)境:node >= 8.10.0、npm >= 5.6.0
建議使用nvm管理 Node 版本,暫不支持使用 yarn、cnpm 等進(jìn)行安裝。
npm i -g chameleon-tool
安裝成功后,執(zhí)行 cml -v 查看當(dāng)前版本, cml -h 查看幫助文檔。
Web 端可以點(diǎn)擊模擬器內(nèi)頁(yè)面右上角打開(kāi) 新的瀏覽器窗口。
Native 端的效果請(qǐng)下載 Chameleon Playground (目前可下載 Android 端,iOS 端即將發(fā)布)或者下載 Weex Playground 掃碼預(yù)覽
小程序端請(qǐng)下載對(duì)應(yīng)小程序開(kāi)發(fā)工具,打開(kāi)項(xiàng)目根目錄下的 /dist/[wx|alipay|baidu|其他] 目錄預(yù)覽。
對(duì)于字節(jié)跳動(dòng)小程序,需要按照字節(jié)跳動(dòng)小程序接入教程配置完畢之后,可以在 dist/tt 下用字節(jié)跳動(dòng)小程序開(kāi)發(fā)者工具打開(kāi)對(duì)應(yīng)的應(yīng)用程序
生成的目錄結(jié)構(gòu)如下,詳細(xì)介紹參見(jiàn)目錄結(jié)構(gòu)。
├── chameleon.config.js // 項(xiàng)目的配置文件
├── dist // 打包產(chǎn)出目錄
├── alipay // 支付寶小程序代碼
├── baidu // 百度小程序代碼
├── wx // 微信小程序代碼
├── tt // 頭條小程序代碼
├── qq // QQ小程序代碼
├── xx // 其他終端
├── mock // 模擬數(shù)據(jù)目錄
├── node_modules // npm包依賴(lài)
├── package.json
└── src // 項(xiàng)目源代碼
├── app // app啟動(dòng)入口
├── components // 組件文件夾
├── pages // 頁(yè)面文件夾
├── router.config.json // 路由配置
└── store // 全局狀態(tài)管理
編輯器中使用.cml的插件語(yǔ)法高亮,參見(jiàn)編輯器插件,插件持續(xù)覆蓋更多編輯器。
替換src/pages/index/index.cml文件,刪除src/pages/index/index.cml文件中的所有代碼,然后替換為下面的代碼,體驗(yàn) CML 語(yǔ)法。
<template>
<view>
<!-- 數(shù)據(jù)綁定與計(jì)算屬性 -->
<text>{{ message }}</text>
<text class="class1">{{ message2 }}</text>
<!-- 條件與循環(huán)渲染 -->
<view c-if="{{showlist}}">
<view c-for="{{array}}" c-for-index="idx" c-for-item="itemName" c-key="city">
<text> {{ idx }}: {{ itemName.city }}</text>
</view>
</view>
<!-- 事件綁定 -->
<view c-bind:tap="changeShow"><text>切換展示</text></view>
</view>
</template>
<script>
class Index {
data = {
message: 'HelloCML',
array: [
{
city: '北京',
},
{
city: '上海',
},
{
city: '廣州',
},
],
showlist: true,
};
computed = {
message2: function() {
return 'computed' + this.message;
},
};
watch = {
showlist(newVal, oldVal) {
console.log(`showlist changed:` + newVal);
},
};
methods = {
changeShow() {
this.showlist = !this.showlist;
},
};
created() {
console.log('生命周期');
}
}
export default new Index();
</script>
<style scoped>
.class1 {
color: #f00;
}
</style>
<script cml-type="json">
{
}
</script>
項(xiàng)目根目錄下 執(zhí)行 cml init page, 輸入頁(yè)面名稱(chēng) first-page
$ cml init page
? Please input page name:
回車(chē),即可生成頁(yè)面 組件src/pages/first-page/first-page.cml。
項(xiàng)目根目錄下 執(zhí)行 cml init component,選擇Normal component,輸入 first-com, 回車(chē),即可生成文件components/first-com/first-com.cml。 組件也是 cml 文件 結(jié)構(gòu)上與頁(yè)面相同。
拷貝如下代碼到first-com.cml
<template>
<view>
<text class="first-com-text">我是組件first-com</text>
</view>
</template>
<script>
class FirstCom {}
export default new FirstCom();
</script>
<style scoped>
.first-com-text {
color: #0f0;
}
</style>
<script cml-type="json">
{
}
</script>
然后在剛才的src/pages/index/index.cml中引用first-com
<script cml-type="json">
{
"base": {
"usingComponents": {
"first-com": "components/first-com/first-com"
}
}
}
</script>
template 中使用 first-com 組件。
<template>
<view>
<first-com></first-com>
</view>
</template>
經(jīng)過(guò)以上操作,你已經(jīng)學(xué)會(huì)了組件的引用,豐富的組件等待著你去學(xué)習(xí)!
chameleon.config.js為項(xiàng)目的配置文件,以后定制化構(gòu)建會(huì)使用到,比如是否帶 hash,是否壓縮等等,可以在項(xiàng)目根目錄下執(zhí)行cml build,執(zhí)行完成后,項(xiàng)目根目錄的dist文件夾下生成 build 模式的文件。
mock/api/index.js 文件內(nèi)容如下,可以本地模擬 api 請(qǐng)求。
訪問(wèn) localhost:8000/api/getMessage 即可看到模擬的 api 返回。
端口以實(shí)際啟動(dòng)為準(zhǔn),默認(rèn) 8000.
module.exports = [
{
method: ['get', 'post'],
path: '/api/getMessage',
controller: function(req, res, next) {
res.json({
total: 0,
message: [
{
name: 'HelloCML',
},
],
});
},
},
];
chameleon-tool中內(nèi)置了 todolist 的項(xiàng)目模板,通過(guò)命令cml init project --demo todo 即可生成該模板,按照 1.2 節(jié)中的說(shuō)明啟動(dòng)項(xiàng)目,即可看到如下頁(yè)面
經(jīng)過(guò)以上的介紹和實(shí)踐操作,相信你已經(jīng)了解了 CML 的基本使用,本文檔其余部分將涵蓋剩余功能和其他高級(jí)功能的詳盡細(xì)節(jié),所以請(qǐng)務(wù)必完整閱讀整個(gè)文檔!
更多建議: