stml頁面

2020-12-29 10:53 更新

stml介紹 stml(single template markup language)文件是一個專用的文件類型,其結(jié)構(gòu)和Vue的單文件組件 (SFC)相似,用類Html語法描述一個組件/頁面。

一個stml文件一般包含三種類型的頂級語言塊<template>,<script>和<style>,同時支持引入外部js或者css文件,以及其他stml組件。

stml文件最終被分別編譯為APP、小程序代碼。

App端加載stml頁面的方式

在config.xml中全局配置avm字段。配置后打開頁面默認(rèn)使用原生渲染引擎,當(dāng)打開標(biāo)準(zhǔn)H5頁面時,需將openWin、openFrame等方法的avm參數(shù)設(shè)置為false。

<preference name="avm" value="true"/>

使用openWin、openFrame等方法打開頁面時設(shè)置avm參數(shù)。

api.openWin({
    name: 'test',
    url: '../pages/test.stml',
    avm: true
});

代碼示例

一個典型的.stml文件代碼如下:

<template>
    <view>
        <view class="header">
            <text>{this.data.title}</text>
        </view>
        <view class="content">
            <text>{this.data.content}</text>
        </view>
        <view class="footer">
            <text>{this.data.footer}</text>
        </view>
    </view>
</template>
<style>
    .header {
      height: 45px;
    }
    .content {
      flex-direction:row;
    }
    .footer {
      height: 55px;
    }
</style>
<script>
    export default {
        name: 'api-test',

        
        apiready(){
            console.log("Hello APICloud");
        },


        data(){
            return {
                title: 'Hello App',
                content: 'this is content',
                footer: 'this is footer'
            }
        }
    }
</script>

代碼塊描述 <template>:stml文件允許最多包含一個template塊,且template下僅允許包含一個子節(jié)點(diǎn)。template塊類似于標(biāo)準(zhǔn)HTML中的body標(biāo)簽。

<script>:stml文件允許最多包含一個script塊,script塊類似于標(biāo)準(zhǔn)Html的script標(biāo)簽。該塊內(nèi)可使用import方式引入外部js,被引入的js內(nèi)容將被編譯到最終的js組件中。例如:

<script>
    import './path/utils.js';


    export default {
        name: 'api-test',
    }
</script>

<style>:stml文件允許包含一個或多個style塊,style塊類似于標(biāo)準(zhǔn)Html的style標(biāo)簽。該塊支持以src的方式引入外部css,被引入的css內(nèi)容將被編譯到最終的js組件中。例如:

<style src='./path/common.css' />
<style>
    .header{
        height: 45px;
    }
</style>

編譯器會解析stml文件,提取每個語言塊,分別編譯導(dǎo)出為APP(JS組件 / 頁面)、H5(SPA)、小程序(WXML / WXSS / JS)代碼,用于不同終端的渲染。

編譯后的App js代碼參考:

class ApiTest extends Component {

  
    data = {
        title: 'Hello App',
        content: 'this is content',
        footer: 'this is footer'
    }

    
    apiready () {
        console.log("Hello APICloud");
    }


    render() {
        return (
            <view>
                <view class='header'>
                    <text>{this.data.title}</text>
                </view>
                <view class='content'>
                    <text>{this.data.content}</text>
                </view>
                <view class='footer'>
                    <text>{this.data.footer}</text>
                </view>
            </view>
        );
    }
}


ApiTest.css = {
    '.header': {
        height: '45px'
    },
    '.content': {
        flex: 1
    },
    '.footer': {
        height: '55px'
    }
}


avm.define('api-test', ApiTest);
avm.render(<api-test />, 'body');

該代碼為編譯中間過程的臨時代碼,是ES6規(guī)范的代碼,符合avm.js單語言片段模式要求。在輸出之前,還會經(jīng)過一系列的處理,最終被編譯為ES5規(guī)范的代碼,用于DeepEngine或者標(biāo)準(zhǔn)瀏覽器執(zhí)行。

avm.define avm.define函數(shù)用于聲明或者定義一個組件。接收兩個參數(shù),組件名(例如"a-button")和組件對象。

avm.render avm.render函數(shù)用于聲明將已定義的組件渲染到某元素上。默認(rèn)渲染到body,body為窗口或者頁面的根元素。

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號